CN103124967A - 用于将应用服务器连接到集群的数据库的系统和方法 - Google Patents
用于将应用服务器连接到集群的数据库的系统和方法 Download PDFInfo
- Publication number
- CN103124967A CN103124967A CN201180039809XA CN201180039809A CN103124967A CN 103124967 A CN103124967 A CN 103124967A CN 201180039809X A CN201180039809X A CN 201180039809XA CN 201180039809 A CN201180039809 A CN 201180039809A CN 103124967 A CN103124967 A CN 103124967A
- Authority
- CN
- China
- Prior art keywords
- database
- cluster
- data source
- application server
- connection
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
- G06F15/163—Interprocessor communication
- G06F15/173—Interprocessor communication using an interconnection network, e.g. matrix, shuffle, pyramid, star, snowflake
- G06F15/17306—Intercommunication techniques
- G06F15/17318—Parallel communications techniques, e.g. gather, scatter, reduce, roadcast, multicast, all to all
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
- G06F16/2358—Change logging, detection, and notification
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/25—Integrating or interfacing systems involving database management systems
- G06F16/252—Integrating or interfacing systems involving database management systems between a Database Management System and a front-end application
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
- G06F16/278—Data partitioning, e.g. horizontal or vertical partitioning
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/04—Network management architectures or arrangements
- H04L41/042—Network management architectures or arrangements comprising distributed management centres cooperatively managing the network
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/06—Management of faults, events, alarms or notifications
- H04L41/0686—Additional information in the notification, e.g. enhancement of specific meta-data
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/35—Switches specially adapted for specific applications
- H04L49/356—Switches specially adapted for specific applications for storage area networks
- H04L49/358—Infiniband Switches
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
- H04L67/1034—Reaction to server failures by a load balancer
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1095—Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/14—Session management
- H04L67/142—Managing session states for stateless protocols; Signalling session states; State transitions; Keeping-state mechanisms
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/14—Session management
- H04L67/146—Markers for unambiguous identification of a particular session, e.g. session cookie or URL-encoding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/14—Multichannel or multilink protocols
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
- H04L67/1004—Server selection for load balancing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
- H04L67/1027—Persistence of sessions during load balancing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/14—Session management
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10T—TECHNICAL SUBJECTS COVERED BY FORMER US CLASSIFICATION
- Y10T409/00—Gear cutting, milling, or planing
- Y10T409/30—Milling
- Y10T409/30868—Work support
- Y10T409/308792—Indexable
- Y10T409/308848—Indexable including dividing head
- Y10T409/308904—Multiple row dividing head
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10T—TECHNICAL SUBJECTS COVERED BY FORMER US CLASSIFICATION
- Y10T409/00—Gear cutting, milling, or planing
- Y10T409/30—Milling
- Y10T409/30868—Work support
- Y10T409/309016—Work support with work holder or guide
- Y10T409/309072—Work support with work holder or guide including cutter limited to rotary motion
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10T—TECHNICAL SUBJECTS COVERED BY FORMER US CLASSIFICATION
- Y10T409/00—Gear cutting, milling, or planing
- Y10T409/30—Milling
- Y10T409/30868—Work support
- Y10T409/309128—Work support with means to adjust work support vertically
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10T—TECHNICAL SUBJECTS COVERED BY FORMER US CLASSIFICATION
- Y10T409/00—Gear cutting, milling, or planing
- Y10T409/30—Milling
- Y10T409/309352—Cutter spindle or spindle support
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10T—TECHNICAL SUBJECTS COVERED BY FORMER US CLASSIFICATION
- Y10T409/00—Gear cutting, milling, or planing
- Y10T409/30—Milling
- Y10T409/309352—Cutter spindle or spindle support
- Y10T409/309408—Cutter spindle or spindle support with cutter holder
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Computer Hardware Design (AREA)
- Computer Security & Cryptography (AREA)
- Mathematical Physics (AREA)
- Software Systems (AREA)
- Computing Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Multi Processors (AREA)
- Computer And Data Communications (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
系统和方法可以支持使用数据源将应用服务器连接到集群的数据库。集群的数据库包括多个数据库实例,并与通知服务相关联。通知服务可以被集群的数据库用来广播描述多个数据库实例中的状态变化的通知。数据源包括管理到集群的数据库中的多个数据库实例的一组连接的连接池。数据源操作为向所述通知服务进行注册,以接收关于所述集群的数据库的变化的通知,其中,应用服务器操作为在运行时自适应地根据集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
Description
版权声明
此专利文献的说明书的一部分包含受版权保护的材料。版权所有者不反对任何人影印专利文献或专利说明书,因为它出现在专利商标局专利文件或记录中,但在别的方面却保留所有版权。
技术领域
本发明一般涉及诸如中间件之类的计算机系统和软件,特别是涉及用于管理到集群的数据库的连接的系统。
背景技术
在诸如Oracle Weblogic服务器之类的应用服务器的背景中,用户可以通过配置数据源来配置应用服务器中的数据库连接性。应用服务器上的应用可以使用诸如标准Java命名和目录接口(JNDI)之类的目录服务来查找特定数据源,然后,请求数据库连接。当完成连接时,应用可以通过应用服务器断开数据库连接。应用服务器管理员和软件开发人员/程序员都可以创建数据源。这些是本发明的各实施例旨在解决的一般领域。
发明内容
根据一个实施例,提供了支持使用数据源将应用服务器连接到集群的数据库的系统和方法。集群的数据库包括多个数据库实例,并与通知服务组件相关联。通知服务组件可以被集群的数据库用来广播描述多个数据库实例中的状态变化的通知。数据源包括管理到集群的数据库中的多个数据库实例的一组连接的连接池。数据源操作为向通知服务组件进行注册,以接收涉及集群的数据库的变化的通知,其中,应用服务器操作为在运行时自适应地根据集群的数据库的任何状态变化,配置和管理到集群的数据库的连接。
根据本发明的一个方面,提供了支持将应用服务器连接到数据库系统的数据库系统,所述数据库系统是集群的数据库,包括:多个数据库实例;以及,与多个数据库实例相关联的通知服务组件,其中,通知服务组件可以被集群的数据库用来广播描述集群的数据库中的状态变化的通知;其中,通知服务组件从与应用服务器相关联的数据源接收注册,应用服务器用于接收有关集群的数据库的变化的通知以及在运行时自适应地根据集群的数据库的状态变化,由数据源配置和管理到集群的数据库的连接。
优选地,集群的数据库的状态变化包括下列各项之一:一个或多个数据库实例已经被非计划的运行中断停止或清除,以及,在运行中断之后添加或重新启动数据库实例。
根据本发明的另一个方面,提供了支持将应用服务器连接到集群的数据库的应用服务器,包括:管理到所述集群的数据库中的所述多个数据库实例的一组连接的连接池;以及,与所述连接池相关联的单一数据源;其中,所述数据源操作为向所述集群的数据库的通知服务组件进行注册,以接收涉及所述集群的数据库的变化的通知,其中,所述应用服务器操作为在运行时自适应地根据所述集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
优选地,所述数据源给数据库提供快速的连接故障转移能力,并对数据库服务事件作出响应,以确保到数据库实例的每一所述连接都是有效的。
优选地,所述数据源操作为使用度量来监视由所述应用服务器采取的动作。
优选地,所述数据源操作为轮询到所述集群的数据库中的所述多个数据库实例的所述一组连接,作为所述通知服务组件的替代方案。
优选地,所述数据源操作为从所述通知服务组件接收包含负载平衡咨询事件的通知。
优选地,所述数据源确保全局事务的背景内的所有数据库操作都涉及同一数据库实例。
优选地,所述数据源支持所述集群的数据库中的目标数据库实例的平稳的关闭操作。
优选地,所述数据源允许在关闭和重新创建一个或多个物理连接之前完成任何正在进行中的事务。
优选地,所述数据源清理空闲连接,以便对连接的新请求不被发送到所述集群的数据库中的所述目标数据库实例。
附图说明
图1示出了根据一个实施例的用于将应用服务器连接到集群的数据库的多数据源系统的图示。
图2示出了根据一个实施例的用于将应用服务器连接到集群的数据库的Gridlink数据源系统的图示。
图3示出了根据一个实施例的用于将应用服务器连接到由集群的数据库所提供的不同的服务Gridlink数据源系统的图示。
图4示出了根据一个实施例的使用用于将应用服务器连接到集群的数据库的Gridlink数据源的示例性流程图。
图5示出了根据一个实施例的支持数据库负载平衡咨询事件的Gridlink数据源系统的图示。
图6示出了根据一个实施例的支持集群的数据库中的数据库状态改变事件的Gridlink数据源系统的图示。
图7示出了根据一个实施例的支持分布式事务(XA)的Gridlink数据源系统的图示。
图8示出了根据一个实施例的支持数据库平稳的关闭的Gridlink数据源系统的图示。
图9示出了根据一个实施例的使用数据库连接模块的Gridlink数据源系统的图示。
图10示出了根据一个实施例的用于配置与Gridlink数据源相关联的多个监听器的向导页面的图示。
图11示出了根据一个实施例的用于配置与Gridlink数据源相关联的通知服务客户端的向导页面的图示。
具体实施方式
本发明是作为示例示出的,而不仅限于各个附图的图形,在附图中,类似的附图标记表示类似的元件。应该注意,在本发明中对“一个”或“某些”实施例的引用不一定是指同一个实施例,而这样的引用表示至少一个。
另外,此处所提供的对本发明的各实施例的描述使用Oracle真实应用集群(RAC)数据库系统作为集群的数据库环境的说明性示例。对所属领域的技术人员显而易见的是,可以使用其他类型的集群的数据库环境,而没有任何限制。
集群的数据库或数据库集群可以包括多个互连的计算机或服务器,表现为对最终用户和应用而言好像它们是一个服务器。与在数据库和实例之间具有一对一关系的单实例数据库不同,集群的数据库在数据库和实例之间具有一对多关系。例如,Oracle RAC数据库系统使用户能使用Oracle Clusterware基础架构将多个服务器绑定到一起,来聚集Oracle数据库,以便它们作为单一系统来操作。OracleRAC数据库系统可以具有许多实例,所有的这些实例都访问一个数据库。多个服务器的组合的处理能力可以提供比单一服务器所能提供的更大的吞吐量和可缩放性。
图1示出了根据一个实施例的用于将应用服务器连接到集群的数据库的多数据源系统的图示。如图1所示,多数据源103是一个或多个单个数据源131、132、133上的数据源抽象。多数据源根据指定的策略,诸如负载平衡策略以及故障转移策略,从成员数据源中的每一个提供Java数据库连接(JDBC)连接121、122、123。此外,多数据源配置要求每一成员数据源获取到特定数据库实例的连接。
Gridlink数据源
根据一个实施例,提供了支持使用数据源(此处称为“Gridlink数据源”)将应用服务器连接到集群的数据库的系统和方法。集群的数据库包括多个数据库实例,并与通知服务组件相关联。通知服务组件可以被集群的数据库用来广播描述该多个数据库实例中的状态变化的通知。数据源包括管理到集群的数据库中的多个数据库实例的一组连接的连接池。数据源操作为向通知服务组件进行注册,以接收涉及集群的数据库的变化的通知,其中,应用服务器操作为在运行时自适应地根据集群的数据库的任何状态变化,配置和管理到集群的数据库的连接。
根据一个实施例,gridlink数据源可以使用表示针对数据库集群的服务的单一数据源配置。gridlink数据源可以对通知事件作出响应,以提供快速的连接故障转移、运行时连接负载平衡和数据库实例平稳的关闭。另外,还可以在全局事务Id级别支持分布式事务(XA)亲和性。
例如,Oracle RAC数据库系统可以支持客户端通知,以传播有关数据库集群的状态的信息。JDBC数据源配置允许指定服务URL以提供RAC连接性。JDBC数据源配置还包括监视向RAC集群提供JDBC连接的统计和可管理性的支持。
根据一个实施例,Gridlink数据源通过利用数据库集群通知的能力以提供更简单配置的形式的更好的总体连接性、对数据库节点故障的更快响应、对数据库集群资源的更好利用,以及改善的运行时监视以及管理,来克服多数据源解决方案的缺点。另外,可以支持Gridlink数据源以及多数据源的混合配置。
图2示出了根据一个实施例的用于将应用服务器连接到集群的数据库的Gridlink数据源系统的图示。如图2所示,Gridlink数据源203是与应用服务器201相关联的单一数据源。Gridlink数据源通过单个数据源方式(该方式降低使用集群的数据库所需的配置和管理复杂度)来简化集群的数据库202与应用服务器的使用。Gridlink数据源包括连接池205,该连接池205又包含去往数据库集群中的不同的数据库实例211、212、213的一组异构连接221、222、223。也如图2所示,不同的数据库实例连接到共享存储器204。
根据一个实施例,对连接池中的连接的管理基于在连接池上配置的静态设置214,诸如最小/最大容量、超时等等,以及有关从通知服务组件206接收到的事件消息210中的连接池的实时信息,该信息通知数据库集群内的任何状态变化的数据源。当应用207、208或209从数据源请求连接时,基于连接池接收到的负载平衡信息,以及来自池中的正在使用中的连接的当前分布,从连接池中选择合适的连接,并向应用提供。
应用服务器可以向通知服务组件进行注册以接收诸如数据库事件消息之类的通知,并因此快速地了解集群数据库中的任何状态变化。通过使用这些状态变化通知事件,应用服务器可以智能地修改其连接池,使得系统可以提供连续、可靠并且有效的对集群数据库的访问。
根据一个实施例,当没有配置通知服务或它不能正确地操作时,可以作为通知服务的替代方案来应用连接轮询。当使用连接轮询时,系统可以通过对各个连接执行SQL操作,来确定各个JDBC连接的生存能力,并检测集群的集群拓扑中的变化。
通过与通知服务方式进行比较,连接轮询方式以额外的运行时开销以及潜在的对数据库实例节点故障的延迟检测为代价。此外,连接轮询方式潜在地遭受虚警,该虚警可能会导致对数据源池的不必要的禁用以及可能正在被应用使用的有效连接的结束。
图3示出了根据一个实施例的用于将应用服务器连接到由集群的数据库所提供的不同的服务的Gridlink数据源系统的图示。如图3所示,集群的数据库302可以提供不同的服务311、312以及313,每一个服务都可以是跨不同的数据库实例可分配的数据库工作负荷抽象,以提供特定服务质量。
也如图3所示,应用服务器环境301可包括多个应用服务器实例303和304。每一应用服务器实例可包括带有单一连接池307和308的单一数据源305和306。Gridlink数据源系统向集群的数据库提供连接321、322、323、324和325,并以无约束的方式支持对数据库服务的消费,以便提供与集群的数据库的更深的集成。
例如,Oracle数据库服务可以是用于管理Oracle数据库中的工作负荷的逻辑抽象。数据库服务可以提供对于工作负荷、对工作负荷的优先级排序、对于实际事务的性能度量,以及当性能目标被违犯时的警告和动作的单一系统映像。数据库服务可以使数据库管理员能配置工作负荷、管理工作负荷、启用/禁用工作负荷,以及作为单一实体来测量工作负荷。数据库服务还可以将工作负荷分割为在逻辑上不相交的组。每一服务表示带有共同的属性、服务级别的阈值以及优先级的工作负荷。
图4示出了根据一个实施例的使用用于将应用服务器连接到集群的数据库的Gridlink数据源的示例性流程图。如图4所示,在步骤401中,通知服务组件可以与集群的数据库中的多个数据库实例相关联。此外,在步骤402中,数据源可以与包含到集群的数据库中的多个数据库实例的一组连接的连接池相关联。在步骤403中,数据源可以向通知服务组件进行注册以接收有关集群的数据库的变化的通知。在步骤404中,数据源在运行时从通知服务接收描述集群的数据库中的状态变化的通知。然后,在步骤405中,数据源根据集群的数据库的状态变化自适应地配置和管理到集群的数据库的连接。
根据一个实施例,Gridlink数据源的配置可以利用持续的JDBC描述符豆(bean)。JDBC描述符豆可以标识Gridlink数据源并指定数据库通知服务客户端配置信息。JDBC描述符豆可以使用XML文件来实现Gridlink数据源功能。下面是用于配置连接到Oracle RAC数据库系统的Gridlink数据源的示例性XML文件。
负载平衡咨询事件
根据一个实施例,集群的数据库可以基于由数据库管理员(DBA)设置的性能目标,来提供运行时负载平衡服务,以跨数据库实例分发连接,以便提供更好的吞吐量以及对资源的更加有效的使用。负载平衡咨询服务发出通知客户端有关集群的当前状态的事件,包括有关将连接指向哪里的建议。
图5示出了根据一个实施例的支持数据库负载平衡咨询事件的Gridlink数据源系统的图示。如图5所示,应用服务器501可以接收由集群的数据库502所发出的负载平衡咨询事件消息510,并相应地调整到数据库节点或实例511、512以及513的数据库连接521、522,以及523。系统可以在运行时对数据源执行负载平衡配置选项,允许应用服务器基于从数据库接收到的负载平衡咨询消息来调度数据库连接。因此数据库连接被定向到特定数据库节点,以满足由数据库管理员所设置的性能目标。
运行时负载平衡咨询服务组件506和单个数据源503结合的使用可以简化初始配置以及对数据源的正在进行的维护。通过使用Gridlink数据源系统,应用服务器不需要数据库拓扑信息即可支持负载平衡,因为数据库指示负载平衡活动。Gridlink数据源系统通过降低正确地配置中间层所需的信息量,来帮助数据源的初始构建。另外,由于数据库层可以随着时间而变化并且服务可以被重新定位到新的或不同的数据库实例上,Gridlink数据源系统不需要配置变更来反映变化的数据库拓扑。
例如,如图5所示,当在应用服务器中接收到的负载平衡咨询事件消息指出数据库实例A繁忙而数据库实例C空闲时,Gridlink数据源系统可以通过将新的连接指派到数据库实例C,来重新调整连接池中的连接,以实现由DBA设置的负载平衡目标,以取得以更高的吞吐量达到更好的负载的分布。
根据一个实施例,除基于负载平衡信息来重新调整连接池中的连接之外,还可以在有空闲的连接可用时,根据负载平衡百分比/权重来向应用组件给出现有的连接。
数据库状态改变事件
图6示出了根据一个实施例的支持数据库状态改变事件的Gridlink数据源系统的图示。如图6所示,应用服务器601可以从集群的数据库602中接收由通知服务组件606所发出的数据库状态改变事件消息610。数据库状态改变事件可包括数据库实例的意外的运行中断,或新数据库实例的添加。
根据一个实施例,Gridlink数据源系统允许应用服务器自适应地对数据库集群中的状态变化作出响应,诸如通过立即撤回、关闭和丢弃到已经被非计划的运行中断停止或清除的数据库实例的连接,来处理运行中断。如图6所示,在应用服务器中接收到的数据库状态改变事件消息可以指出数据库实例B612的运行中断。相应地,Gridlink数据源603可以指示连接池605断开数据库连接622,以便与Gridlink数据源相关联的应用607、608或609可以通过诸如数据库实例A611或数据库实例C613之类的另一个数据库实例重新连接到数据库,以避免数据库服务中的中断。
如上面的示例所示,通过使用数据库状态改变事件,Gridlink数据源系统不需要周期性地轮询这些连接,以确保它们是有效的,或影响到幸存的节点的未涉及的连接。这可以减轻对连接的测试的依赖,以确保应用不被给予无效连接,并且应用服务器被给予快速地从由于数据库节点故障而变失效的连接中释放应用的信息,而不会产生不必要的延迟。
除处理意外的数据库运行中断之外,Gridlink数据源还允许应用服务器主动地重新分配其连接组,以支持添加新数据库实例或在运行中断之后重新启动数据库实例的情况。这可使应用服务器充分利用集群的数据库内的资源。此外,通过使用数据库服务模型,系统还可使数据库管理员对数据库服务/实例分配进行更改,然后,通过受影响的应用服务器连接池无缝地应用这些更改,无需对连接池配置进行配置更改。它也去除了创建多个数据源的复杂布局以表示集群的数据库的专用实例的必要性。
此外,通过使用数据库状态改变事件,Gridlink数据源还可以提供快速的连接故障转移能力,并对集群的数据库服务和诸如{UP,DOWN}事件之类的节点事件作出响应,以确保池中的物理连接的报留始终指向有效数据库节点。此外,Gridlink数据源还确保物理连接的保留很好地在可用的数据库节点之间分布。可以作为数据源上的配置设置,启用快速连接故障转移行为。可以使度量可用,以允许管理员监视并审查在接收到数据库通知事件时应用服务器对其数据源已采取什么动作。
分布式事务(XA)亲和性(affinity)
根据一个实施例,分布式事务(XA)亲和性被用来确保在全局事务的背景内对数据库集群执行的所有数据库操作都被定向到同一个数据库实例。可以基于全局事务id,而不是通过单个数据源,来确立亲和性,以确保从为相同数据库集群配置的不同的数据源中获取的连接都与同一个数据库实例相关联。两阶段提交优化可以得到Gridlink数据源的支持,还可以参与XA亲和性。
图7示出了根据一个实施例的支持分布式事务(XA)的Gridlink数据源系统的图示。如图7所示,使用Gridlink数据源的应用服务器环境701可以通过确保对集群的数据库702执行的全局事务的所有数据库操作都涉及同一个数据库实例711来支持全局事务。在一个实施例中,对于XA事务的第一连接请求721被负载平衡,并被指派了亲和性背景720。使用第一连接的亲和性背景将所有随后的连接请求722、723以及724路由到同一个数据库实例。
数据库平稳的计划的停机
根据一个实施例,当针对数据库节点/服务被进行停机操作,对应地发出指出请求了停机的数据库事件时,发生平稳的计划的停机。图8示出了根据一个实施例的支持数据库平稳的停机的Gridlink数据源系统的图示。如图8所示,应用服务器801可以接收由通知服务组件806从集群的数据库802所发出的数据库停机事件消息810。数据库停机事件消息指出数据库实例A811被计划为停机。
为了支持数据库的平稳的计划的停机,应用服务器可能不会立即中止当检测到数据库停机目标不再接受新连接时正在被使用的连接821。相反,Gridlink数据源803允许任何正在进行中的事务在关闭并重新创建物理连接之前完成,而同时清理空闲连接,以便对连接的新请求不被发送到活动的停机模式下的数据库目标。
数据源可以检测连接到数据库停机目标的活动连接,并标记它们,以便它们当相关联的事务完成并且连接返回到连接池805时被关闭并重新创建。可能不会在接收到停机事件时或检测到禁止的连接请求时立即产生异常,以便允许任何正在进行中的事务完成。另外,池中的连接到数据库停机目标的任何空闲连接都可以被抢先地关闭。系统还允许数据源绕过数据库停机目标路由新请求,而允许正在进行中的事务完成,允许数据库停机操作对正在运行的应用是透明的。
通用连接池(UCP)库
根据一个实施例,诸如通用连接池(UCP)库之类的数据库连接模块可以被用来将应用服务器连接到集群的数据库。UCP库是从数据库服务器的角度来看在逻辑上是JDBC驱动器的扩展的客户机侧库。除提供通用JDBC连接汇聚实现之外,数据库连接模块还可以为集群的数据库支持高可用性和性能能力。
图9示出了根据一个实施例的使用数据库连接模块的Gridlink数据源系统的图示。应用服务器901可以利用UCP库910的集群数据库集成支持,以通过Gridlink数据源903与集群的数据库902进行连接。
根据一个实施例,在不需要使用由UCP库所提供的JDBC连接汇聚特征的情况下,Gridlink数据源可以连接到数据库集群,并利用由UCP库所支持的其他能力,诸如快速连接故障转移,运行时连接负载平衡和XA连接亲和性。
根据一个实施例,连接模块可以使用应用服务器计时器和工作管理器,以便对诸如Java虚拟机(JVM)之类的资源进行更好的利用和管理。另外,API还可以允许应用服务器获取集群的数据库咨询,以更有效地跨数据库实例分配连接并更好地对数据库集群拓扑中的变化作出响应。例如,可以重构UCP的RAC能力,并以RAC模块API的形式将它们暴露于应用服务器。此API可以响应于RAC集群拓扑中的变化以及对于运行时连接负载平衡以及连接亲和性的咨询,提供回调通知。API还提供应用服务器可以用来记录及其他诊断目的的通知事件回调。API可以浮出(surface)可以用于RAC数据源运行时监视的有关RAC集群节点的统计计数和状态信息。
根据一个实施例,UCP可以被设计为提供连接汇聚和数据库集成特征的独立Java库。如此,UCP库可以管理其自己的线程和计时器。UCP可以提供计时器和工作管理器SPI,该SPI允许应用服务器当UCP API在应用服务器进程内被访问时在应用服务器的实例中插入计时器和工作管理器,供UCP内部使用。这可以允许UCP库所使用的线程和计时器的增大的控制和运行时可见性。另外,即使在在相同以及分开的应用服务器实例上访问不同的数据源的情况下,也可以利用由UCP所提供的亲和性能力,以指派基于全局事务Id的连接。
数据源创建向导
根据一个实施例,数据源创建向导可以支持创建被配置成与诸如Oracle RAC数据库之类的集群的数据库连接的Gridlink数据源。创建Gridlink数据源包括设置连接到数据库服务所需的数据库监听器地址信息以及通知服务客户端配置信息。
例如,为了与Oracle RAC数据库连接,数据源创建向导可以提供两种指定连接目标的方式。第一种方式使用JDBC URL格式的connect descriptor,如下面所示,用于指定数据源的不同的监听器。
第二种方式是向导驱动的方式,该方式允许监听器条目中的每一个被分别地指定,从这些条目可以最终构建最后的JDBC URL。向导驱动的方式使用户能指定并测试多个监听器和通知服务客户端,以便创建和更新Gridlink数据源。
图10示出了根据一个实施例的用于配置与Gridlink数据源相关联的多个监听器的向导页面1000的图示。如图10所示,Gridlink数据源可以连接到带有名称“Inrac”的数据库服务。此Gridlink数据源与三个监听器相关联,三个监听器被配置成分别使用主机和端口多元组:leftp:1521、rightp:1521,或centerp:1521。可以分别地测试每一监听器,以便验证连接有效,并且如果对于特定监听器有任何问题,则向用户回报。
图11示出了根据一个实施例的用于配置与Gridlink数据源相关联的通知服务客户端的向导页面1100的图示。如图11所示,Gridlink数据源进一步与被配置成使用主机和端口多元组:leftp:1526的通知服务客户端相关联。还可以分别地测试通知服务客户端。另外,Gridlink数据源可以与额外的通知服务客户端相关联(如果必要的话)。
本发明可以使用一个或多个常规通用或专门数字计算机、计算设备、机器,或微处理器,包括一个或多个处理器、存储器和/或根据本发明的原理编程的计算机可读存储介质,来方便地实现。对于那些精通软件技术的人来说显而易见的是,可以由熟练的程序员基于本发明的原理轻松地编制适当的软件代码。
在某些实施例中,本发明包括计算机程序产品,该产品是其中存储了指令的存储介质或计算机可读介质,这些指令可以用来对计算机进行编程,以执行本发明的任何一个进程。存储介质可以包括,但不仅限于,任何类型的盘,包括软盘、光盘、DVD、CD-ROM、微驱动,以及磁光盘、ROM、RAM、EPROM、EEPROM、DRAM、VRAM、闪存设备、磁卡或光卡,纳米系统(包括分子存储器IC),或适于存储指令和/或数据的任何类型的介质或设备。
前面的对本发明的描述只是为了说明和描述。它不是详尽的说明或将本发明限于所公开的准确的形式。那些精通本技术的专业人员将认识到,可以进行许多修改。所选择和描述的实施例只是为了最好地说明本发明的原理以及其实际应用,并使精通本技术的其他人懂得,带有适合于特定用途的各种修改的各实施例的本发明也是可以接受的。本发明的范围由下面的权利要求以及它们的等效内容进行定义。
Claims (35)
1.一种支持将应用服务器连接到集群的数据库的系统,包括:
与所述集群的数据库中的多个数据库实例相关联的通知服务组件,其中,所述通知服务组件被所述集群的数据库用来广播描述所述集群的数据库中的状态变化的通知;以及
与所述应用服务器相关联的数据源,其中,数据源与连接池相关联,所述连接池管理到所述集群的数据库中的所述多个数据库实例的一组连接;
其中,所述数据源操作为向所述通知服务组件进行注册,以接收关于所述集群的数据库的变化的通知,其中,所述应用服务器操作为在运行时自适应地根据所述集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
2.如权利要求1所述的系统,其中:
所述集群的数据库的所述状态变化包括下列各项之一:
一个或多个数据库实例已经被非计划的运行中断停止或清除,以及
在运行中断之后添加或重新启动数据库实例。
3.如权利要求1或2所述的系统,其中:
所述数据源操作为给数据库提供快速的连接故障转移能力,并对数据库服务事件作出响应,以确保到数据库实例的每一所述连接都是有效的。
4.根据权利要求1到3中的任何一个所述的系统,其中:
所述数据源操作为使用度量来监视由所述应用服务器采取的动作。
5.根据权利要求1到4中的任何一个所述的系统,其中:
所述数据源操作为轮询到所述集群的数据库中的所述多个数据库实例的所述一组连接,作为所述通知服务组件的替代方案。
6.根据权利要求1到5中的任何一个所述的系统,其中:
所述数据源操作为从所述通知服务组件接收包含负载平衡咨询事件的通知。
7.根据权利要求1到6中的任何一个所述的系统,其中:
所述数据源操作为确保全局事务的背景内的所有数据库操作都关于同一数据库实例。
8.根据权利要求1到7中的任何一个所述的系统,其中:
所述数据源操作为支持所述集群的数据库中的目标数据库实例的平稳的关闭操作。
9.如权利要求8所述的系统,其中:
所述数据源操作为允许在关闭和重新创建一个或多个物理连接之前完成任何正在进行中的事务。
10.如权利要求8或9所述的系统,其中:
所述数据源操作为清理空闲连接,以便对连接的新请求不被发送到所述集群的数据库中的所述目标数据库实例。
11.一种用于支持将应用服务器连接到集群的数据库的方法,包括:
提供与所述集群的数据库中的多个数据库实例相关联的通知服务组件,其中,所述通知服务组件被所述集群的数据库用来广播描述所述集群的数据库中的状态变化的通知;
提供与所述应用服务器相关联的数据源,其中,所述数据源与连接池相关联,所述连接池包含到所述集群的数据库中的所述多个数据库实例的一组连接;以及
允许所述数据源向所述通知服务组件进行注册,以接收关于所述集群的数据库的变化的通知,其中,所述应用服务器操作为在运行时自适应地根据所述集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
12.如权利要求11所述的方法,其中:
所述集群的数据库的状态变化包括下列各项之一:
一个或多个数据库实例已经被非计划的运行中断停止或清除,以及
在运行中断之后添加或重新启动数据库实例。
13.如权利要求11或12所述的方法,还包括:
所述数据源给数据库提供快速的连接故障转移能力,并对数据库服务事件作出响应,以确保到数据库实例的每一所述连接都是有效的。
14.根据权利要求11到13中任一权利要求所述的方法,还包括:
所述数据源使用度量来监视由所述应用服务器采取的动作。
15.根据权利要求11到14中任一权利要求所述的方法,还包括:
所述数据源轮询到所述集群的数据库中的所述多个数据库实例的所述一组连接,作为所述通知服务的替代方案。
16.根据权利要求11到15中任一权利要求所述的方法,还包括:
所述数据源从所述通知服务组件接收包含负载平衡咨询事件的通知。
17.根据权利要求11到16中任一权利要求所述的方法,还包括:
所述数据源确保全局事务的背景内的所有数据库操作都关于同一数据库实例。
18.根据权利要求11到17中任一权利要求所述的方法,还包括:
所述数据源支持所述集群的数据库中的目标数据库实例的平稳的关闭操作。
19.如权利要求18所述的方法,还包括:
所述数据源允许在关闭和重新创建一个或多个物理连接之前完成任何正在进行中的事务。
20.如权利要求18或19所述的方法,还包括:
所述数据源清理空闲连接,以便对连接的新请求不被发送到所述集群的数据库中的所述目标数据库实例。
21.一种包括程序可读指令的计算机程序,所述程序可读指令当被加载到一个或多个计算机系统中并由它们执行时,导致所述一个或多个计算机系统执行如权利要求11到20中任一权利要求所述的方法。
22.一种包括存储了如权利要求21所述的计算机程序的计算机可读存储介质的计算机程序产品。
23.一种数据库系统,支持将应用服务器连接到所述数据库系统,所述数据库系统是集群的数据库,包括:
多个数据库实例;以及
与所述多个数据库实例相关联的通知服务组件,其中,所述通知服务组件被所述集群的数据库用来广播描述所述集群的数据库中的状态变化的通知;
其中,所述通知服务组件从与应用服务器相关联的数据源接收注册,所述应用服务器用于接收关于所述集群的数据库的变化的通知以及在运行时自适应地根据集群的数据库的状态变化,由所述数据源配置和管理到所述集群的数据库的连接。
24.如权利要求23所述的系统,其中:
所述集群的数据库的所述状态变化包括下列各项之一:
一个或多个数据库实例已经被非计划的运行中断停止或清除,以及
在运行中断之后添加或重新启动数据库实例。
25.一种应用服务器,用于支持将所述应用服务器与集群的数据库连接,包括:
管理到所述集群的数据库中的所述多个数据库实例的一组连接的连接池;以及
与所述连接池相关联的单一数据源;
其中,所述数据源操作为向所述集群的数据库的通知服务组件进行注册,以接收关于所述集群的数据库的变化的通知,其中,所述应用服务器操作为在运行时自适应地根据所述集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
26.如权利要求25所述的系统,其中:
所述数据源给数据库提供快速的连接故障转移能力,并对数据库服务事件作出响应,以确保到数据库实例的每一所述连接都是有效的。
27.如权利要求25所述的系统,其中:
所述数据源操作为使用度量来监视由所述应用服务器采取的动作。
28.如权利要求25所述的系统,其中:
所述数据源操作为轮询到所述集群的数据库中的所述多个数据库实例的所述一组连接,作为所述通知服务组件的替代方案。
29.如权利要求25所述的系统,其中:
所述数据源操作为从所述通知服务组件接收包含负载平衡咨询事件的通知。
30.如权利要求25所述的系统,还包括:
所述数据源确保全局事务的背景内的所有数据库操作都涉及同一数据库实例。
31.如权利要求25所述的系统,还包括:
所述数据源支持所述集群的数据库中的目标数据库实例的平稳的关闭操作。
32.如权利要求31所述的系统,其中:
所述数据源允许在关闭和重新创建一个或多个物理连接之前完成任何正在进行中的事务。
33.如权利要求31所述的系统,其中:
所述数据源清理空闲连接,以便对连接的新请求不被发送到所述集群的数据库中的所述目标数据库实例。
34.一种用于导致计算机系统执行下列步骤的计算机程序:
提供与集群的数据库中的多个数据库实例相关联的通知服务,其中,所述通知服务组件被所述集群的数据库用来广播描述所述集群的数据库中的状态变化的通知;
提供与应用服务器相关联的数据源,其中,数据源与连接池相关联,所述连接池包含到所述集群的数据库中的所述多个数据库实例的一组连接;以及
允许所述数据源向所述通知服务进行注册,以接收关于所述集群的数据库的变化的通知,其中,所述应用服务器操作为在运行时自适应地根据所述集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
35.在其上存储了当执行时导致系统执行以下操作的指令的机器可读的介质:
提供与集群的数据库中的多个数据库实例相关联的通知服务组件,其中,所述通知服务组件被所述集群的数据库用来广播描述所述集群的数据库中的状态变化的通知;
提供与应用服务器相关联的数据源,其中,所述数据源与连接池相关联,所述连接池包含到所述集群的数据库中的所述多个数据库实例的一组连接;以及
允许所述数据源操作为向所述通知服务组件进行注册,以接收关于所述集群的数据库的变化的通知,其中,所述应用服务器操作为在运行时自适应地根据所述集群的数据库的状态变化,配置和管理到所述集群的数据库的连接。
Applications Claiming Priority (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US38328510P | 2010-09-15 | 2010-09-15 | |
US61/383,285 | 2010-09-15 | ||
US38422710P | 2010-09-17 | 2010-09-17 | |
US61/384,227 | 2010-09-17 | ||
US13/168,506 | 2011-06-24 | ||
US13/168,506 US9092460B2 (en) | 2010-09-15 | 2011-06-24 | System and method for using a gridlink data source to connect an application server with a clustered database |
PCT/US2011/051459 WO2012037163A1 (en) | 2010-09-15 | 2011-09-13 | System and method for connecting an application server with a clustered database |
Publications (2)
Publication Number | Publication Date |
---|---|
CN103124967A true CN103124967A (zh) | 2013-05-29 |
CN103124967B CN103124967B (zh) | 2017-09-22 |
Family
ID=46933441
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201180039809.XA Active CN103124967B (zh) | 2010-09-15 | 2011-09-13 | 用于将应用服务器连接到集群的数据库的系统和方法 |
Country Status (5)
Country | Link |
---|---|
US (7) | US8756329B2 (zh) |
EP (1) | EP2616966B1 (zh) |
JP (2) | JP2013541764A (zh) |
CN (1) | CN103124967B (zh) |
WO (1) | WO2012037163A1 (zh) |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104331406A (zh) * | 2013-12-20 | 2015-02-04 | 乐视网信息技术(北京)股份有限公司 | 一种数据库容量控制方法及装置 |
CN104468274A (zh) * | 2014-12-16 | 2015-03-25 | 深圳大学 | 一种集群监控管理方法及系统 |
CN104503751A (zh) * | 2014-12-16 | 2015-04-08 | 深圳中兴网信科技有限公司 | 基于soa的数据源切换方法和基于soa的数据源切换系统 |
CN104794026A (zh) * | 2015-04-29 | 2015-07-22 | 上海新炬网络信息技术有限公司 | 一种集群实例多数据源绑定的故障转移方法 |
CN105100185A (zh) * | 2014-05-06 | 2015-11-25 | 甲骨文国际公司 | 事务中间件机器环境中处理数据库状态通知的系统和方法 |
CN105302565A (zh) * | 2015-11-10 | 2016-02-03 | 河海大学 | 一种基于Java的自带连接池管理的数据持久化组件 |
CN106095571A (zh) * | 2016-06-07 | 2016-11-09 | 中国建设银行股份有限公司 | 多rac集群系统、数据访问方法及装置 |
CN106716360A (zh) * | 2014-09-24 | 2017-05-24 | 甲骨文国际公司 | 支持多租户应用服务器环境中的补丁修补的系统和方法 |
US10742568B2 (en) | 2014-01-21 | 2020-08-11 | Oracle International Corporation | System and method for supporting multi-tenancy in an application server, cloud, or other environment |
US10853055B2 (en) | 2014-09-24 | 2020-12-01 | Oracle International Corporation | System and method for supporting patching in a multitenant application server environment |
CN112835866A (zh) * | 2019-11-25 | 2021-05-25 | 深圳云天励飞技术有限公司 | 数据库的实现方法、装置、电子设备及存储介质 |
CN113297173A (zh) * | 2021-05-24 | 2021-08-24 | 阿里巴巴新加坡控股有限公司 | 分布式数据库集群管理方法及装置、电子设备 |
US11237814B2 (en) | 2017-08-17 | 2022-02-01 | Oracle International Corporation | System and method for supporting custom hooks during patching in an application server environment |
Families Citing this family (102)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007143278A2 (en) | 2006-04-12 | 2007-12-13 | Soft Machines, Inc. | Apparatus and method for processing an instruction matrix specifying parallel and dependent operations |
CN101627365B (zh) | 2006-11-14 | 2017-03-29 | 索夫特机械公司 | 多线程架构 |
US8499298B2 (en) * | 2010-01-28 | 2013-07-30 | International Business Machines Corporation | Multiprocessing transaction recovery manager |
US11030598B2 (en) | 2010-03-02 | 2021-06-08 | Lightspeed Commerce Usa Inc. | System and method for remote management of sale transaction data |
US10699261B2 (en) | 2010-03-02 | 2020-06-30 | Shopkeep Inc. | System and method for remote management of sale transaction data |
US9965755B2 (en) | 2011-02-28 | 2018-05-08 | Shopkeep.Com, Inc. | System and method for remote management of sale transaction data |
US9317844B2 (en) | 2010-03-02 | 2016-04-19 | Shopkeep.Com, Inc. | System and method for remote management of sale transaction data |
US10735304B2 (en) | 2011-02-28 | 2020-08-04 | Shopkeep Inc. | System and method for remote management of sale transaction data |
US8756329B2 (en) | 2010-09-15 | 2014-06-17 | Oracle International Corporation | System and method for parallel multiplexing between servers in a cluster |
US9185054B2 (en) | 2010-09-15 | 2015-11-10 | Oracle International Corporation | System and method for providing zero buffer copying in a middleware machine environment |
WO2012037491A2 (en) | 2010-09-17 | 2012-03-22 | Soft Machines, Inc. | Single cycle multi-branch prediction including shadow cache for early far branch prediction |
EP2689327B1 (en) | 2011-03-25 | 2021-07-28 | Intel Corporation | Executing instruction sequence code blocks by using virtual cores instantiated by partitionable engines |
CN103635875B (zh) | 2011-03-25 | 2018-02-16 | 英特尔公司 | 用于通过使用由可分区引擎实例化的虚拟核来支持代码块执行的存储器片段 |
KR101620676B1 (ko) | 2011-03-25 | 2016-05-23 | 소프트 머신즈, 인크. | 분할가능한 엔진에 의해 인스턴스화된 가상 코어를 이용한 코드 블록의 실행을 지원하는 레지스터 파일 세그먼트 |
US9086909B2 (en) | 2011-05-17 | 2015-07-21 | Oracle International Corporation | System and method for supporting work sharing muxing in a cluster |
WO2012162189A1 (en) | 2011-05-20 | 2012-11-29 | Soft Machines, Inc. | An interconnect structure to support the execution of instruction sequences by a plurality of engines |
TWI666551B (zh) | 2011-05-20 | 2019-07-21 | 美商英特爾股份有限公司 | 以複數個引擎作資源與互連結構的分散式分配以支援指令序列的執行 |
US10095562B2 (en) | 2013-02-28 | 2018-10-09 | Oracle International Corporation | System and method for transforming a queue from non-blocking to blocking |
US9378045B2 (en) | 2013-02-28 | 2016-06-28 | Oracle International Corporation | System and method for supporting cooperative concurrency in a middleware machine environment |
US9110715B2 (en) | 2013-02-28 | 2015-08-18 | Oracle International Corporation | System and method for using a sequencer in a concurrent priority queue |
US8689237B2 (en) | 2011-09-22 | 2014-04-01 | Oracle International Corporation | Multi-lane concurrent bag for facilitating inter-thread communication |
US9606844B2 (en) * | 2011-09-28 | 2017-03-28 | Microsoft Technology Licensing, Llc | Remotely-hosted interactive client-server session |
EP2783280B1 (en) | 2011-11-22 | 2019-09-11 | Intel Corporation | An accelerated code optimizer for a multiengine microprocessor |
CN104040491B (zh) | 2011-11-22 | 2018-06-12 | 英特尔公司 | 微处理器加速的代码优化器 |
US20130339927A1 (en) * | 2011-12-02 | 2013-12-19 | Digium, Inc. | Communications Platform Supporting Stateless Application Development |
USD746851S1 (en) | 2012-03-29 | 2016-01-05 | Shopkeep.Com, Inc. | Point of sale device display screen or portion thereof with graphical user interface |
CN102695049B (zh) * | 2012-05-09 | 2015-06-10 | 浙江宇视科技有限公司 | 码流发送方法和装置 |
US8965921B2 (en) * | 2012-06-06 | 2015-02-24 | Rackspace Us, Inc. | Data management and indexing across a distributed database |
CN102882864B (zh) * | 2012-09-21 | 2015-10-28 | 南京斯坦德云科技股份有限公司 | 一种基于InfiniBand云计算网络的虚拟化系统 |
US9953317B2 (en) | 2013-03-13 | 2018-04-24 | Shopkeep.Com, Inc. | Method and system for secure key rotation |
US9886279B2 (en) | 2013-03-15 | 2018-02-06 | Intel Corporation | Method for populating and instruction view data structure by using register template snapshots |
KR101708591B1 (ko) | 2013-03-15 | 2017-02-20 | 소프트 머신즈, 인크. | 블록들로 그룹화된 멀티스레드 명령어들을 실행하기 위한 방법 |
US9904625B2 (en) | 2013-03-15 | 2018-02-27 | Intel Corporation | Methods, systems and apparatus for predicting the way of a set associative cache |
US9891924B2 (en) | 2013-03-15 | 2018-02-13 | Intel Corporation | Method for implementing a reduced size register view data structure in a microprocessor |
WO2014150991A1 (en) | 2013-03-15 | 2014-09-25 | Soft Machines, Inc. | A method for implementing a reduced size register view data structure in a microprocessor |
WO2014150806A1 (en) | 2013-03-15 | 2014-09-25 | Soft Machines, Inc. | A method for populating register view data structure by using register template snapshots |
US10140138B2 (en) | 2013-03-15 | 2018-11-27 | Intel Corporation | Methods, systems and apparatus for supporting wide and efficient front-end operation with guest-architecture emulation |
WO2014150971A1 (en) | 2013-03-15 | 2014-09-25 | Soft Machines, Inc. | A method for dependency broadcasting through a block organized source view data structure |
US10275255B2 (en) | 2013-03-15 | 2019-04-30 | Intel Corporation | Method for dependency broadcasting through a source organized source view data structure |
US9811342B2 (en) | 2013-03-15 | 2017-11-07 | Intel Corporation | Method for performing dual dispatch of blocks and half blocks |
US9569216B2 (en) | 2013-03-15 | 2017-02-14 | Soft Machines, Inc. | Method for populating a source view data structure by using register template snapshots |
KR102083390B1 (ko) | 2013-03-15 | 2020-03-02 | 인텔 코포레이션 | 네이티브 분산된 플래그 아키텍처를 이용하여 게스트 중앙 플래그 아키텍처를 에뮬레이션하는 방법 |
JP6256904B2 (ja) * | 2013-04-18 | 2018-01-10 | インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation | 処理の要求を振り分ける装置及び方法 |
US9268798B2 (en) * | 2013-04-26 | 2016-02-23 | Oracle International Corporation | Support for cloud-based multi-tenant environments using connection labeling |
US9338193B2 (en) * | 2013-05-31 | 2016-05-10 | International Business Machines Corporation | Remote procedure call with call-by-reference semantics using remote direct memory access |
US9720970B2 (en) | 2013-06-06 | 2017-08-01 | Oracle International Corporation | Efficient storage and retrieval of fragmented data using pseudo linear dynamic byte array |
US9600546B2 (en) | 2013-06-06 | 2017-03-21 | Oracle International Corporation | System and method for marshaling massive database data from native layer to java using linear array |
US9785687B2 (en) | 2013-06-06 | 2017-10-10 | Oracle International Corporation | System and method for transparent multi key-value weighted attributed connection using uni-tag connection pools |
US9569472B2 (en) | 2013-06-06 | 2017-02-14 | Oracle International Corporation | System and method for providing a second level connection cache for use with a database environment |
US9747341B2 (en) | 2013-06-06 | 2017-08-29 | Oracle International Corporation | System and method for providing a shareable global cache for use with a database environment |
US10049022B2 (en) * | 2013-06-24 | 2018-08-14 | Oracle International Corporation | Systems and methods to retain and reclaim resource locks and client states after server failures |
US20150006478A1 (en) * | 2013-06-28 | 2015-01-01 | Silicon Graphics International Corp. | Replicated database using one sided rdma |
US9774652B2 (en) * | 2013-12-13 | 2017-09-26 | Sap Se | Systems to provide database updates |
US9774739B2 (en) | 2014-03-20 | 2017-09-26 | Genesys Telecommunications Laboratories, Inc. | Resource sharing in a peer-to-peer network of contact center nodes |
US9588830B2 (en) * | 2014-03-20 | 2017-03-07 | Genesys Telecommunications Laboratories, Inc. | Local survivability in a distributed contact center environment |
CN105335378A (zh) * | 2014-06-25 | 2016-02-17 | 富士通株式会社 | 多数据源的信息处理装置、服务器及方法 |
CN104092758B (zh) * | 2014-07-14 | 2018-01-12 | 南京斯坦德云科技股份有限公司 | 一种分布式高速云存储服务器集群系统的读取方法 |
CN105373420B (zh) * | 2014-08-28 | 2019-12-06 | 北京奇虎科技有限公司 | 数据传输方法及装置 |
EP3191958A1 (en) | 2014-09-08 | 2017-07-19 | Microsoft Technology Licensing, LLC | Application transparent continuous availability using synchronous replication across data stores in a failover cluster |
US9632887B2 (en) * | 2014-09-19 | 2017-04-25 | International Business Machines Corporation | Automatic client side seamless failover |
CN104539713B (zh) * | 2014-12-31 | 2018-10-09 | 北京奇虎科技有限公司 | 业务请求处理方法和装置 |
US10346367B1 (en) * | 2015-04-30 | 2019-07-09 | Amazon Technologies, Inc. | Load shedding techniques for distributed services with persistent client connections to ensure quality of service |
US10701037B2 (en) * | 2015-05-27 | 2020-06-30 | Ping Identity Corporation | Scalable proxy clusters |
US10140121B2 (en) | 2015-07-21 | 2018-11-27 | Oracle International Corporation | Sending a command with client information to allow any remote server to communicate directly with client |
US9846759B2 (en) * | 2015-07-30 | 2017-12-19 | Taiwan Semiconductor Manufacturing Company, Ltd. | Global connection routing method and system for performing the same |
CN105677693B (zh) * | 2015-09-18 | 2020-02-18 | 联动优势科技有限公司 | 一种访问数据库的方法及装置 |
IL242353B (en) * | 2015-10-29 | 2021-01-31 | Verint Systems Ltd | System and method for soft failovers for proxy servers |
US10284621B2 (en) | 2015-11-09 | 2019-05-07 | International Business Machines Corporation | Session management |
CN105279279B (zh) * | 2015-11-16 | 2019-01-25 | 天津南大通用数据技术股份有限公司 | 从低速数据源加载压缩数据文件的方法及装置 |
CN105577797A (zh) * | 2015-12-25 | 2016-05-11 | 北京像素软件科技股份有限公司 | 一种跨服务器数据互通的系统和方法 |
US10015086B2 (en) * | 2016-04-29 | 2018-07-03 | Intuit Inc. | Multi GTM based routing to avoid latencies |
CN105812393A (zh) * | 2016-05-24 | 2016-07-27 | 浪潮电子信息产业股份有限公司 | 一种网站防护装置和方法 |
US11169982B2 (en) | 2016-06-30 | 2021-11-09 | Microsoft Technology Licensing, Llc | Dynamic deactivation of cold database in database service |
CN106254421A (zh) * | 2016-07-19 | 2016-12-21 | 北京中科同向信息技术有限公司 | 一种基于虚拟云的技术 |
US10742748B2 (en) | 2016-08-12 | 2020-08-11 | Oracle International Corporation | System and method for supporting live addition of a tenant in a connection pool environment |
US10824750B2 (en) | 2016-08-12 | 2020-11-03 | Oracle International Corporation | System and method for performing connection validation in a multi-tenant environment |
US10909211B2 (en) | 2016-08-12 | 2021-02-02 | Oracle International Corporation | System and method for control of maximum connections in a connection pool environment |
US11290540B2 (en) | 2016-08-12 | 2022-03-29 | Oracle International Corporation | System and method for use of server-side connection pool tagging in a multi-tenant environment |
US9612927B1 (en) * | 2016-09-14 | 2017-04-04 | International Business Machines Corporation | Managing server processes with proxy files |
US10310841B2 (en) | 2016-09-16 | 2019-06-04 | Oracle International Corporation | System and method for handling lazy deserialization exceptions in an application server environment |
US10681012B2 (en) | 2016-10-26 | 2020-06-09 | Ping Identity Corporation | Methods and systems for deep learning based API traffic security |
US11093838B2 (en) * | 2017-05-10 | 2021-08-17 | Microsoft Technology Licensing, Llc | Adaptive selection of user to database mapping |
CN107302499B (zh) * | 2017-06-26 | 2020-12-18 | 北京赛特斯信息科技股份有限公司 | 无需拷贝报文缓存的nfv协议报文收发方法 |
CN107391686A (zh) * | 2017-07-24 | 2017-11-24 | 威创软件南京有限公司 | 一种可视化配置数据采集系统实现方法 |
US11100058B2 (en) | 2017-09-06 | 2021-08-24 | Oracle International Corporation | System and method for connection concentration in a database environment |
EP3471007B1 (en) | 2017-10-13 | 2022-02-23 | Ping Identity Corporation | Methods and apparatus for analyzing sequences of application programming interface traffic to identify potential malicious actions |
CN108111578B (zh) * | 2017-11-28 | 2021-06-04 | 国电南瑞科技股份有限公司 | 基于nio的配电终端数据采集平台接入终端设备的方法 |
US10860239B2 (en) * | 2018-05-04 | 2020-12-08 | EMC IP Holding Company LLC | Fan-out asynchronous replication caching |
US10705753B2 (en) | 2018-05-04 | 2020-07-07 | EMC IP Holding Company LLC | Fan-out asynchronous replication logical level caching |
US11477197B2 (en) * | 2018-09-18 | 2022-10-18 | Cyral Inc. | Sidecar architecture for stateless proxying to databases |
US11470084B2 (en) | 2018-09-18 | 2022-10-11 | Cyral Inc. | Query analysis using a protective layer at the data source |
US11477217B2 (en) | 2018-09-18 | 2022-10-18 | Cyral Inc. | Intruder detection for a network |
US11496475B2 (en) | 2019-01-04 | 2022-11-08 | Ping Identity Corporation | Methods and systems for data traffic based adaptive security |
US11275765B2 (en) * | 2019-01-28 | 2022-03-15 | EMC IP Holding Company LLC | Storage systems configured for storage volume addition in synchronous replication using active-active configuration |
US10938933B2 (en) | 2019-05-14 | 2021-03-02 | International Business Machines Corporation | Managing dynamic configuration-based database connections using a proxy datasource |
CN111708560A (zh) * | 2020-06-17 | 2020-09-25 | 云和恩墨(北京)信息技术有限公司 | 数据库高可用管理系统的自动化部署方法及装置 |
US11611540B2 (en) * | 2020-07-01 | 2023-03-21 | Vmware, Inc. | Protection of authentication data of a server cluster |
US11070621B1 (en) * | 2020-07-21 | 2021-07-20 | Cisco Technology, Inc. | Reuse of execution environments while guaranteeing isolation in serverless computing |
CN114157658B (zh) * | 2021-12-06 | 2024-03-01 | 京东科技信息技术有限公司 | 镜像仓库部署方法、装置、电子设备和计算机可读介质 |
US20230224361A1 (en) * | 2022-01-12 | 2023-07-13 | Vmware, Inc. | Service-aware global server load balancing |
US11809839B2 (en) | 2022-01-18 | 2023-11-07 | Robert Lyden | Computer language and code for application development and electronic and optical communication |
CN115344366B (zh) * | 2022-08-10 | 2023-10-31 | 中电金信软件有限公司 | 连接池对象的切换方法、装置、电子设备及可读存储介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070198684A1 (en) * | 2006-02-22 | 2007-08-23 | Kazunori Mizushima | Method and system for data processing with connection pool for the same |
CN101408899A (zh) * | 2008-11-21 | 2009-04-15 | 北京中企开源信息技术有限公司 | 一种网站多数据源切换方法和装置 |
CN101661499A (zh) * | 2009-03-25 | 2010-03-03 | 福建省电力有限公司 | 电力应用支撑系统及其分布式实时数据中心 |
Family Cites Families (107)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5109384A (en) | 1988-11-02 | 1992-04-28 | Tseung Lawrence C N | Guaranteed reliable broadcast network |
US5333274A (en) | 1991-10-15 | 1994-07-26 | International Business Machines Corp. | Error detection and recovery in a DMA controller |
US6424992B2 (en) | 1996-12-23 | 2002-07-23 | International Business Machines Corporation | Affinity-based router and routing method |
US6192389B1 (en) | 1997-03-28 | 2001-02-20 | International Business Machines Corporation | Method and apparatus for transferring file descriptors in a multiprocess, multithreaded client/server system |
US6427161B1 (en) | 1998-06-12 | 2002-07-30 | International Business Machines Corporation | Thread scheduling techniques for multithreaded servers |
US6571274B1 (en) | 1998-11-05 | 2003-05-27 | Beas Systems, Inc. | Clustered enterprise Java™ in a secure distributed processing system |
GB2348985A (en) | 1999-04-15 | 2000-10-18 | Ibm | Centralized affinity maintenance in a workload managed client/server system |
US6701367B1 (en) | 1999-09-24 | 2004-03-02 | Sun Microsystems, Inc. | Mechanism for enabling customized session managers to interact with a network server |
WO2001073550A2 (en) * | 2000-03-29 | 2001-10-04 | Nextset Software Inc. | System and method of generating and using proxy beans |
US20030120822A1 (en) | 2001-04-19 | 2003-06-26 | Langrind Nicholas A. | Isolated control plane addressing |
US7209921B2 (en) | 2000-09-01 | 2007-04-24 | Op40, Inc. | Method and system for deploying an asset over a multi-tiered network |
US20020174136A1 (en) | 2000-12-14 | 2002-11-21 | Ducan Cameron | Method and system for high performance transaction processing using a relational database management system |
JP2002218577A (ja) | 2001-01-24 | 2002-08-02 | Nec Corp | 通信ネットワーク、波長多重装置、光スイッチ装置及びそれらに用いる光リンク属性・状態管理方法 |
JP2002259948A (ja) | 2001-03-02 | 2002-09-13 | Tdk Corp | 次処理決定方法、検査方法および検査装置 |
US7831731B2 (en) | 2001-06-12 | 2010-11-09 | Hewlett-Packard Development Company, L.P. | Method and system for a modular transmission control protocol (TCP) rare-handoff design in a streams based transmission control protocol/internet protocol (TCP/IP) implementation |
US7409420B2 (en) | 2001-07-16 | 2008-08-05 | Bea Systems, Inc. | Method and apparatus for session replication and failover |
US6895590B2 (en) | 2001-09-26 | 2005-05-17 | Intel Corporation | Method and system enabling both legacy and new applications to access an InfiniBand fabric via a socket API |
US7143227B2 (en) | 2003-02-18 | 2006-11-28 | Dot Hill Systems Corporation | Broadcast bridge apparatus for transferring data to redundant memory subsystems in a storage controller |
US6886041B2 (en) | 2001-10-05 | 2005-04-26 | Bea Systems, Inc. | System for application server messaging with multiple dispatch pools |
US6983465B2 (en) | 2001-10-11 | 2006-01-03 | Sun Microsystems, Inc. | Method and apparatus for managing data caching in a distributed computer system |
US7376953B2 (en) | 2001-10-29 | 2008-05-20 | Hewlett-Packard Development Company, L.P. | Apparatus and method for routing a transaction to a server |
US20030110232A1 (en) | 2001-12-11 | 2003-06-12 | International Business Machines Corporation | Distributing messages between local queues representative of a common shared queue |
JP2003196229A (ja) | 2001-12-28 | 2003-07-11 | Sony Corp | バス・インタフェースにおけるデータ転送方法およびバス・インタフェース |
US7403996B2 (en) | 2002-02-21 | 2008-07-22 | Bea Systems, Inc. | Systems and methods for migratable services |
CA2415043A1 (en) | 2002-12-23 | 2004-06-23 | Ibm Canada Limited - Ibm Canada Limitee | A communication multiplexor for use with a database system implemented on a data processing system |
US7554993B2 (en) * | 2003-03-27 | 2009-06-30 | Hewlett-Packard Development Company, L.P. | Method and apparatus for performing connection management with multiple stacks |
US8108534B2 (en) | 2003-05-08 | 2012-01-31 | Jda Software Group, Inc. | Data integration system with programmatic source and target interfaces |
US7536673B2 (en) | 2003-07-22 | 2009-05-19 | Sap Ag | Application business object processing |
US7043518B2 (en) | 2003-07-31 | 2006-05-09 | Cradle Technologies, Inc. | Method and system for performing parallel integer multiply accumulate operations on packed data |
EP1503548A1 (en) | 2003-08-01 | 2005-02-02 | fg microtec GmbH | Distributed Quality of Service Management System |
US7483374B2 (en) | 2003-08-05 | 2009-01-27 | Scalent Systems, Inc. | Method and apparatus for achieving dynamic capacity and high availability in multi-stage data networks using adaptive flow-based routing |
US7937493B2 (en) | 2003-08-14 | 2011-05-03 | Oracle International Corporation | Connection pool use of runtime load balancing service performance advisories |
US7953860B2 (en) | 2003-08-14 | 2011-05-31 | Oracle International Corporation | Fast reorganization of connections in response to an event in a clustered computing system |
US20050223109A1 (en) | 2003-08-27 | 2005-10-06 | Ascential Software Corporation | Data integration through a services oriented architecture |
US7366109B2 (en) | 2003-10-29 | 2008-04-29 | Nortel Networks Limited | Virtual private networks within a packet network having a mesh topology |
US20050102412A1 (en) | 2003-11-10 | 2005-05-12 | Jan Hirsimaki | Transmission performance of a transport layer protocol connection |
US20050234986A1 (en) * | 2004-04-09 | 2005-10-20 | Microsoft Corporation | Systems and methods for fragment-based serialization |
US7640357B2 (en) | 2004-04-30 | 2009-12-29 | Sap Ag | Transmitting enterprise messages based on buffer sizes |
US7649854B2 (en) * | 2004-05-19 | 2010-01-19 | Bea Systems, Inc. | System and method for providing channels in application servers and transaction-based systems |
US7930422B2 (en) | 2004-07-14 | 2011-04-19 | International Business Machines Corporation | Apparatus and method for supporting memory management in an offload of network protocol processing |
WO2007014186A2 (en) | 2005-07-22 | 2007-02-01 | The Thomson Corporation | Systems, methods, and software for online courses |
EP1699257B1 (en) * | 2005-03-04 | 2007-09-12 | Alcatel Lucent | Switch for integrated telecommunication networks. |
US7804504B1 (en) | 2004-12-13 | 2010-09-28 | Massachusetts Institute Of Technology | Managing yield for a parallel processing integrated circuit |
US8984140B2 (en) | 2004-12-14 | 2015-03-17 | Hewlett-Packard Development Company, L.P. | Managing connections through an aggregation of network resources providing offloaded connections between applications over a network |
US7562138B2 (en) * | 2004-12-28 | 2009-07-14 | Sap | Shared memory based monitoring for application servers |
US20060176884A1 (en) | 2005-02-04 | 2006-08-10 | Sytex, Inc. | Sytems, Methods And Devices For Remotely Administering A Target Device |
US7409709B2 (en) | 2005-02-14 | 2008-08-05 | Etsec, Inc. | Systems and methods for automatically reconfiguring a network device |
US7941556B2 (en) * | 2005-02-23 | 2011-05-10 | At&T Intellectual Property I, Lp | Monitoring for replica placement and request distribution |
EP1860568A1 (en) | 2005-03-14 | 2007-11-28 | Matsushita Electric Industrial Co., Ltd. | Bus controller |
US8762547B2 (en) * | 2005-04-29 | 2014-06-24 | Sap Ag | Shared memory implementations for session data within a multi-tiered enterprise network |
DK2582158T3 (en) | 2005-06-05 | 2016-11-28 | Starkey Labs Inc | Communication system for wireless audio devices |
US7480823B2 (en) | 2005-06-24 | 2009-01-20 | Sun Microsystems, Inc. | In-memory replication of timing logic for use in failover within application server node clusters |
US8473934B2 (en) | 2005-07-15 | 2013-06-25 | Imec | Method for mapping applications on a multiprocessor platform/system |
GB0517303D0 (en) | 2005-08-23 | 2005-10-05 | Netronome Systems Inc | System and method for processing secure transmissions |
US8166547B2 (en) | 2005-09-06 | 2012-04-24 | Fortinet, Inc. | Method, apparatus, signals, and medium for managing a transfer of data in a data network |
US7702947B2 (en) * | 2005-11-29 | 2010-04-20 | Bea Systems, Inc. | System and method for enabling site failover in an application server environment |
US8707323B2 (en) | 2005-12-30 | 2014-04-22 | Sap Ag | Load balancing algorithm for servicing client requests |
US20070157212A1 (en) | 2006-01-04 | 2007-07-05 | Berg Douglas C | Context key routing for parallel processing in an application serving environment |
US7895329B2 (en) | 2006-01-12 | 2011-02-22 | Hewlett-Packard Development Company, L.P. | Protocol flow control |
US7685131B2 (en) | 2006-02-28 | 2010-03-23 | International Business Machines Corporation | Web services database cluster architecture |
US7765307B1 (en) | 2006-02-28 | 2010-07-27 | Symantec Operating Corporation | Bulk network transmissions using multiple connections primed to optimize transfer parameters |
US8131860B1 (en) | 2006-03-30 | 2012-03-06 | Emc Corporation | Serialization and deserialization |
EP2002335A1 (en) | 2006-03-31 | 2008-12-17 | British Telecommunications Public Limited Company | Interactive development tool and debugger for web services |
US20070245005A1 (en) | 2006-04-18 | 2007-10-18 | Banerjee Dwip N | Method and data processing system for managing a plurality of interfaces |
US8924524B2 (en) | 2009-07-27 | 2014-12-30 | Vmware, Inc. | Automated network configuration of virtual machines in a virtual lab data environment |
US8112525B2 (en) * | 2006-05-16 | 2012-02-07 | Oracle International Corporation | Engine near cache for reducing latency in a telecommunications environment |
US7371014B2 (en) * | 2006-08-21 | 2008-05-13 | Intel Corporation | Monolithic active optical cable assembly for data device applications and various connector types |
US8166460B2 (en) * | 2006-10-10 | 2012-04-24 | Convergys Cmg Utah, Inc. | System and method for analyzing HTTP sessions |
US8631041B2 (en) * | 2006-10-20 | 2014-01-14 | Adobe Systems Incorporated | Secondary lazy-accessible serialization of electronic content |
WO2008072093A2 (en) | 2006-12-13 | 2008-06-19 | Quickplay Media Inc. | Mobile media platform |
US8640086B2 (en) * | 2006-12-29 | 2014-01-28 | Sap Ag | Graphical user interface system and method for presenting objects |
US8358591B2 (en) | 2007-06-06 | 2013-01-22 | Hewlett-Packard Development Company, L.P. | Network traffic monitoring in a server network environment |
US8576807B2 (en) | 2007-06-25 | 2013-11-05 | Qualcomm Incorporated | Channel interleaving structure for a wireless communication system |
WO2009002318A1 (en) | 2007-06-26 | 2008-12-31 | Thomson Licensing | Real time protocol stream migration |
US7991904B2 (en) | 2007-07-10 | 2011-08-02 | Bytemobile, Inc. | Adaptive bitrate management for streaming media over packet networks |
US20090024764A1 (en) | 2007-07-18 | 2009-01-22 | International Business Machines Corporation | Tracking The Physical Location Of A Server In A Data Center |
US9141435B2 (en) | 2007-07-30 | 2015-09-22 | Sybase, Inc. | System and methodology providing workload management in database cluster |
US8391295B2 (en) | 2007-07-31 | 2013-03-05 | Oracle International Corporation | Temporal affinity-based routing of workloads |
JP4893581B2 (ja) | 2007-10-23 | 2012-03-07 | 日本電気株式会社 | 多重化通信システム、送信処理装置、受信処理装置、多重化通信方法、送信処理方法、および受信処理方法 |
CN100586058C (zh) | 2007-11-20 | 2010-01-27 | 中国人民解放军信息工程大学 | 基于j2ee中间件规范的容忍入侵应用服务器及容忍入侵方法 |
US7809925B2 (en) | 2007-12-07 | 2010-10-05 | International Business Machines Corporation | Processing unit incorporating vectorizable execution unit |
US20090182642A1 (en) * | 2008-01-14 | 2009-07-16 | Neelakantan Sundaresan | Methods and systems to recommend an item |
US8306951B2 (en) | 2009-09-18 | 2012-11-06 | Oracle International Corporation | Automated integrated high availability of the in-memory database cache and the backend enterprise database |
US8972978B2 (en) | 2008-05-02 | 2015-03-03 | Skytap | Multitenant hosted virtual machine infrastructure |
CN101325504A (zh) | 2008-07-11 | 2008-12-17 | 中兴通讯股份有限公司 | 一种应用服务器控制多媒体会议的方法及装置 |
JP5352848B2 (ja) | 2008-11-28 | 2013-11-27 | 株式会社日立製作所 | 仮想計算機の制御方法及び計算機装置 |
US9230002B2 (en) | 2009-01-30 | 2016-01-05 | Oracle International Corporation | High performant information sharing and replication for single-publisher and multiple-subscriber configuration |
US8612930B2 (en) | 2009-01-30 | 2013-12-17 | Oracle America, Inc. | Methods and apparatus for dynamic class reloading and versioning |
US9454444B1 (en) * | 2009-03-19 | 2016-09-27 | Veritas Technologies Llc | Using location tracking of cluster nodes to avoid single points of failure |
US8880524B2 (en) | 2009-07-17 | 2014-11-04 | Apple Inc. | Scalable real time event stream processing |
US8055933B2 (en) * | 2009-07-21 | 2011-11-08 | International Business Machines Corporation | Dynamic updating of failover policies for increased application availability |
CN101989922B (zh) | 2009-07-31 | 2014-05-28 | 国际商业机器公司 | 用于恢复会话初始协议事务的方法和系统 |
US20110047413A1 (en) * | 2009-08-20 | 2011-02-24 | Mcgill Robert E | Methods and devices for detecting service failures and maintaining computing services using a resilient intelligent client computer |
US8566509B2 (en) | 2009-08-25 | 2013-10-22 | International Business Machines Corporation | Efficiently implementing a plurality of finite state machines |
US8130776B1 (en) | 2009-08-28 | 2012-03-06 | Massachusetts Institute Of Technology | Method and apparatus providing network coding based flow control |
EP2293524A1 (en) | 2009-09-07 | 2011-03-09 | Nxp B.V. | Set-up of media stream transmission and server and client for media stream transmission |
US20110082832A1 (en) * | 2009-10-05 | 2011-04-07 | Ramkumar Vadali | Parallelized backup and restore process and system |
US8811417B2 (en) * | 2009-11-15 | 2014-08-19 | Mellanox Technologies Ltd. | Cross-channel network operation offloading for collective operations |
IT1397440B1 (it) | 2009-12-30 | 2013-01-10 | St Microelectronics Srl | Procedimento e sistemi per la distribuzione di contenuti mediali e relativo prodotto informatico |
US8874961B2 (en) | 2010-03-22 | 2014-10-28 | Infosys Limited | Method and system for automatic failover of distributed query processing using distributed shared memory |
US8543722B2 (en) | 2010-03-30 | 2013-09-24 | International Business Machines Corporation | Message passing with queues and channels |
US8260757B1 (en) | 2010-04-22 | 2012-09-04 | Wal-Mart Stores, Inc. | Data access layer |
US8756329B2 (en) | 2010-09-15 | 2014-06-17 | Oracle International Corporation | System and method for parallel multiplexing between servers in a cluster |
US9185054B2 (en) | 2010-09-15 | 2015-11-10 | Oracle International Corporation | System and method for providing zero buffer copying in a middleware machine environment |
WO2012109677A2 (en) | 2011-02-11 | 2012-08-16 | Fusion-Io, Inc. | Apparatus, system, and method for managing operations for data storage media |
US8938598B2 (en) | 2011-07-06 | 2015-01-20 | Nvidia Corporation | Facilitating simultaneous submission to a multi-producer queue by multiple threads with inner and outer pointers |
US9563480B2 (en) | 2012-08-21 | 2017-02-07 | Rackspace Us, Inc. | Multi-level cloud computing system |
-
2011
- 2011-05-17 US US13/109,871 patent/US8756329B2/en active Active
- 2011-05-17 US US13/109,849 patent/US8856460B2/en active Active
- 2011-06-23 US US13/167,636 patent/US9811541B2/en active Active
- 2011-06-24 US US13/168,506 patent/US9092460B2/en active Active
- 2011-06-28 US US13/170,490 patent/US9864759B2/en active Active
- 2011-09-13 JP JP2013529274A patent/JP2013541764A/ja active Pending
- 2011-09-13 CN CN201180039809.XA patent/CN103124967B/zh active Active
- 2011-09-13 EP EP11764385.8A patent/EP2616966B1/en active Active
- 2011-09-13 WO PCT/US2011/051459 patent/WO2012037163A1/en active Application Filing
- 2011-09-15 US US13/234,004 patent/US8856352B2/en active Active
-
2014
- 2014-05-28 US US14/288,722 patent/US9495392B2/en active Active
-
2016
- 2016-07-20 JP JP2016142298A patent/JP6195958B2/ja active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070198684A1 (en) * | 2006-02-22 | 2007-08-23 | Kazunori Mizushima | Method and system for data processing with connection pool for the same |
CN101408899A (zh) * | 2008-11-21 | 2009-04-15 | 北京中企开源信息技术有限公司 | 一种网站多数据源切换方法和装置 |
CN101661499A (zh) * | 2009-03-25 | 2010-03-03 | 福建省电力有限公司 | 电力应用支撑系统及其分布式实时数据中心 |
Cited By (22)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104331406A (zh) * | 2013-12-20 | 2015-02-04 | 乐视网信息技术(北京)股份有限公司 | 一种数据库容量控制方法及装置 |
US11343200B2 (en) | 2014-01-21 | 2022-05-24 | Oracle International Corporation | System and method for supporting multi-tenancy in an application server, cloud, or other environment |
US11683274B2 (en) | 2014-01-21 | 2023-06-20 | Oracle International Corporation | System and method for supporting multi-tenancy in an application server, cloud, or other environment |
US10742568B2 (en) | 2014-01-21 | 2020-08-11 | Oracle International Corporation | System and method for supporting multi-tenancy in an application server, cloud, or other environment |
CN105100185A (zh) * | 2014-05-06 | 2015-11-25 | 甲骨文国际公司 | 事务中间件机器环境中处理数据库状态通知的系统和方法 |
US11880679B2 (en) | 2014-09-24 | 2024-01-23 | Oracle International Corporation | System and method for supporting patching in a multitenant application server environment |
CN106716360A (zh) * | 2014-09-24 | 2017-05-24 | 甲骨文国际公司 | 支持多租户应用服务器环境中的补丁修补的系统和方法 |
CN106716360B (zh) * | 2014-09-24 | 2020-03-03 | 甲骨文国际公司 | 支持多租户应用服务器环境中的补丁修补的系统和方法 |
US10853055B2 (en) | 2014-09-24 | 2020-12-01 | Oracle International Corporation | System and method for supporting patching in a multitenant application server environment |
US11449330B2 (en) | 2014-09-24 | 2022-09-20 | Oracle International Corporation | System and method for supporting patching in a multitenant application server environment |
CN104503751B (zh) * | 2014-12-16 | 2018-07-10 | 深圳中兴网信科技有限公司 | 基于soa的数据源切换方法和基于soa的数据源切换系统 |
CN104503751A (zh) * | 2014-12-16 | 2015-04-08 | 深圳中兴网信科技有限公司 | 基于soa的数据源切换方法和基于soa的数据源切换系统 |
CN104468274A (zh) * | 2014-12-16 | 2015-03-25 | 深圳大学 | 一种集群监控管理方法及系统 |
CN104794026B (zh) * | 2015-04-29 | 2017-09-15 | 上海新炬网络信息技术有限公司 | 一种集群实例多数据源绑定的故障转移方法 |
CN104794026A (zh) * | 2015-04-29 | 2015-07-22 | 上海新炬网络信息技术有限公司 | 一种集群实例多数据源绑定的故障转移方法 |
CN105302565A (zh) * | 2015-11-10 | 2016-02-03 | 河海大学 | 一种基于Java的自带连接池管理的数据持久化组件 |
CN106095571B (zh) * | 2016-06-07 | 2019-06-04 | 中国建设银行股份有限公司 | 多rac集群系统、数据访问方法及装置 |
CN106095571A (zh) * | 2016-06-07 | 2016-11-09 | 中国建设银行股份有限公司 | 多rac集群系统、数据访问方法及装置 |
US11237814B2 (en) | 2017-08-17 | 2022-02-01 | Oracle International Corporation | System and method for supporting custom hooks during patching in an application server environment |
CN112835866A (zh) * | 2019-11-25 | 2021-05-25 | 深圳云天励飞技术有限公司 | 数据库的实现方法、装置、电子设备及存储介质 |
CN113297173A (zh) * | 2021-05-24 | 2021-08-24 | 阿里巴巴新加坡控股有限公司 | 分布式数据库集群管理方法及装置、电子设备 |
CN113297173B (zh) * | 2021-05-24 | 2023-10-31 | 阿里巴巴新加坡控股有限公司 | 分布式数据库集群管理方法及装置、电子设备 |
Also Published As
Publication number | Publication date |
---|---|
JP2013541764A (ja) | 2013-11-14 |
US8856460B2 (en) | 2014-10-07 |
US9495392B2 (en) | 2016-11-15 |
US9864759B2 (en) | 2018-01-09 |
US20120066394A1 (en) | 2012-03-15 |
US8856352B2 (en) | 2014-10-07 |
EP2616966A1 (en) | 2013-07-24 |
JP2016181304A (ja) | 2016-10-13 |
US20120066459A1 (en) | 2012-03-15 |
US20140280988A1 (en) | 2014-09-18 |
US9811541B2 (en) | 2017-11-07 |
US20120066460A1 (en) | 2012-03-15 |
US8756329B2 (en) | 2014-06-17 |
JP6195958B2 (ja) | 2017-09-13 |
CN103124967B (zh) | 2017-09-22 |
WO2012037163A1 (en) | 2012-03-22 |
US20120066363A1 (en) | 2012-03-15 |
EP2616966B1 (en) | 2019-10-30 |
US9092460B2 (en) | 2015-07-28 |
US20120066400A1 (en) | 2012-03-15 |
US20120144045A1 (en) | 2012-06-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN103124967A (zh) | 用于将应用服务器连接到集群的数据库的系统和方法 | |
US9800087B2 (en) | Multi-level data center consolidated power control | |
US10691716B2 (en) | Dynamic partitioning techniques for data streams | |
US9929971B2 (en) | Flexible-location reservations and pricing for network-accessible resource capacity | |
US11847329B2 (en) | Techniques for implementing fault domain sets | |
CN102402395B (zh) | 基于仲裁磁盘的高可用系统不间断运行方法 | |
CN106888129A (zh) | 一种可弹性伸缩的分布式服务管理系统及其方法 | |
US8468548B2 (en) | Multi-tenant, high-density container service for hosting stateful and stateless middleware components | |
US10635644B2 (en) | Partition-based data stream processing framework | |
US9026837B2 (en) | Resource aware placement of applications in clusters | |
CN105659562B (zh) | 一种用于容障的方法和数据处理系统和包括用于容障的计算机可用代码的存储设备 | |
US20150135255A1 (en) | Client-configurable security options for data streams | |
US8984108B2 (en) | Dynamic CLI mapping for clustered software entities | |
US20110258634A1 (en) | Method for Monitoring Operating Experiences of Images to Improve Workload Optimization in Cloud Computing Environments | |
CN104067257A (zh) | 自动化事件管理 | |
CN101460907A (zh) | 管理由多个计算系统执行程序 | |
CN1987804A (zh) | 并行计算系统中的冗余保护的方法和系统 | |
US9348685B2 (en) | Intermediate database management layer | |
JP5672386B2 (ja) | 計算機およびリソース検索方法 | |
CN109150599A (zh) | 一种基于云架构的运维监控系统 | |
Zheng et al. | A qos-aware middleware for fault tolerant web services | |
CN102662702B (zh) | 设备管理系统、装置、基板管理装置及方法 | |
US7558858B1 (en) | High availability infrastructure with active-active designs | |
US20240069970A1 (en) | System and method for sharing vitals among service replicas to enable processing of long running automation workflows in a container orchestration system | |
US8898289B1 (en) | Distributed event processing method and architecture |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |