System and method for providing scatter/gather data processing in a middleware environment
First Claim
1. A system for providing scatter/gather data processing, comprising:
- a plurality of microprocessors including a first microprocessor and a second microprocessor;
a cluster of a plurality of application server instances executing on the plurality of microprocessors,wherein a first application server instance of the plurality of application server instances executes on the first microprocessor, and a second application server instance of the plurality of application server instances executes on the second microprocessor;
wherein the first application server instance and the second application server instance communicate through a switch fabric network;
wherein each application server instance includes a software muxer;
a plurality of parallel logical channels between the first application server instance and the second application server instance,wherein each parallel logical channel is created based on a replication channel template configured on a cluster management bean, andwherein the number of the plurality of parallel logical channels is specified by an attribute in a server management bean;
wherein the first microprocessor executes the software muxer on the first application server instance toobtain a plurality of pointers, wherein each pointer points to one or more of a plurality of pieces of data, wherein the plurality of pieces of data are stored in different locations in a memory allocated to the first application server instance,configure a plurality of threads to execute the plurality of parallel logical channels,collect the plurality of pieces of data from the different locations in the memory using the plurality of pointers, andtransfer, in a single bulk write and using a single context switch of the first microprocessor, the plurality of pieces of data collected using the plurality of pointers concurrently over the plurality of parallel logical channels from the first application server instance to the second application server instance.
1 Assignment
0 Petitions
Accused Products
Abstract
Systems and methods are provided for providing scatter/gather data processing. In accordance with an embodiment, a such a system can include a cluster of one or more high performance computing systems, each including one or more processors and a high performance memory. The cluster communicates over an InfiniBand network. The system can also include a middleware environment, executing on the cluster, that includes one or more application server instances. The system can further include a plurality of muxers. Each application server instance includes at least one muxer, and each muxer is operable to collect data from a plurality of locations in the high performance memory, and transfer the data in bulk.
105 Citations
21 Claims
-
1. A system for providing scatter/gather data processing, comprising:
-
a plurality of microprocessors including a first microprocessor and a second microprocessor; a cluster of a plurality of application server instances executing on the plurality of microprocessors, wherein a first application server instance of the plurality of application server instances executes on the first microprocessor, and a second application server instance of the plurality of application server instances executes on the second microprocessor; wherein the first application server instance and the second application server instance communicate through a switch fabric network; wherein each application server instance includes a software muxer; a plurality of parallel logical channels between the first application server instance and the second application server instance, wherein each parallel logical channel is created based on a replication channel template configured on a cluster management bean, and wherein the number of the plurality of parallel logical channels is specified by an attribute in a server management bean; wherein the first microprocessor executes the software muxer on the first application server instance to obtain a plurality of pointers, wherein each pointer points to one or more of a plurality of pieces of data, wherein the plurality of pieces of data are stored in different locations in a memory allocated to the first application server instance, configure a plurality of threads to execute the plurality of parallel logical channels, collect the plurality of pieces of data from the different locations in the memory using the plurality of pointers, and transfer, in a single bulk write and using a single context switch of the first microprocessor, the plurality of pieces of data collected using the plurality of pointers concurrently over the plurality of parallel logical channels from the first application server instance to the second application server instance. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A method for providing scatter/gather data processing, comprising:
-
configuring a cluster of a plurality of application server instances executing on a plurality of microprocessors including a first microprocessor and a second microprocessor, wherein each application server instance includes a software muxer, wherein a first application server instance of the plurality of application server instances executes on the first microprocessor, and a second application server instance of the plurality of application server instances executes on the second microprocessor; wherein the first application server instance and the second application server instance communicate through a switch fabric network; configuring a plurality of parallel logical channels between the first application server instance and the second application server instance, wherein each parallel logical channel is created based on a replication channel template configured on a cluster management bean, and wherein the number of the plurality of parallel logical channels is specified by an attribute in a server management bean; executing, by the first microprocessor the software muxer on the first application server instance to perform the steps comprising obtaining a plurality of pointers, wherein each pointer points to one or more of a plurality of pieces of data, wherein the plurality of pieces of data are stored in different locations in a memory allocated to the first application server instance, configuring a plurality of threads to execute the plurality of parallel logical channels, collecting the plurality of pieces of data from the different locations in the memory using the plurality of pointers, transferring, in a single bulk write and using a single context switch of the first microprocessor, the plurality of pieces of data collected using the plurality of pointers concurrently over the plurality of parallel logical channels from the first application server instance to the second application server instance. - View Dependent Claims (9, 10, 11, 12, 13, 14)
-
-
15. A non-transitory computer readable storage medium including instructions stored thereon which, when executed by a computer, cause the computer to perform the steps comprising:
-
configuring a cluster of a plurality of application server instances executing on a plurality of microprocessors including a first microprocessor and a second microprocessor, wherein each application server instance includes a software muxer, wherein a first application server instance of the plurality of application server instances executes on the first microprocessor, and a second application server instance of the plurality of application server instances executes on the second microprocessor; wherein the first application server instance and the second application server instance communicate through a switch fabric network; configuring a plurality of parallel logical channels between the first application server instance and the second application server instance, wherein each parallel logical channel is created based on a replication channel template configured on a cluster management bean, and wherein the number of the plurality of parallel logical channels is specified by an attribute in a server management bean; executing, by the first microprocessor the software muxer on the first application server instance to perform the steps comprising obtaining a plurality of pointers, wherein each pointer points to one or more of a plurality of pieces of data, wherein the plurality of pieces of data are stored in different locations in a memory allocated to the first application server instance, configuring a plurality of threads to execute the plurality of parallel logical channels, collecting the plurality of pieces of data from the different locations in the memory using the plurality of pointers, transferring, in a single bulk write and using a single context switch of the first microprocessor, the plurality of pieces of data collected using the plurality of pointers concurrently over the plurality of parallel logical channels from the first application server instance to the second application server instance. - View Dependent Claims (16, 17, 18, 19, 20, 21)
-
Specification