Using message-passing with procedural code in a database kernel
First Claim
1. A computer program product comprising a non-transitory machine-readable medium storing instructions that, when executed by at least one programmable processor that comprises at least one physical core and a plurality of logical cores, cause the at least one programmable processor to perform operations comprising:
- designating a first logical core from the plurality of logical cores for use by a first message-passing worker of a plurality of message-passing workers;
designating a second logical core from the plurality of logical cores for use by a first job worker of a plurality of job workers, the first and second logical cores sharing one or more resources of the at least one physical core;
designating an additional logical core from the plurality of logical cores for use by a second message-passing worker of the plurality of message-passing workers;
assigning a first set of database objects from a plurality of database objects in a database management system to the first message-passing worker such that the first message-passing worker has exclusive write access to the first set of database objects;
assigning a second set of database objects from the plurality of database objects in the database management system to the second message-passing worker such that the second message-passing worker has exclusive write access to the second set of database objects, the first set of database objects and the second set of database objects having at least one database object in common;
providing read-only access to the plurality of database objects via the first job worker;
executing operations by the first message-passing worker in an order in which request messages are received in a message queue of the first message-passing worker;
running a rebalancing operation to reassign the plurality of database objects to equalize a load across the plurality of message-passing workers;
receiving, by a rebalanced message-passing worker of the plurality of message-passing workers after the running of the rebalancing operation, a new request message pertaining to a reassigned database object of the plurality of database objects, the reassigned database object formerly being assigned to the rebalanced message-passing worker but currently being assigned to a new message-passing worker of the plurality of message-passing workers; and
posting, by the rebalanced message-passing worker, the new request message into a message queue of the new message-passing worker.
2 Assignments
0 Petitions
Accused Products
Abstract
Each of a plurality of database objects can be assigned to a specific message-passing worker of a plurality of message-passing workers, each executing on a first logical core that shares with at least a second logical core one or more resources of a physical processor core of a plurality of physical processor cores. The second logical core can execute a job worker of a plurality of job workers that implement procedural code. Exclusive write access can be provided to a database object of the plurality of database objects via a message-passing worker of the plurality of message-passing workers while read-only access is provided to any database object of the plurality of database objects via any of the plurality of job workers. Operations can be executed by the message-passing worker in an order in which request messages are received in a message queue of the message-passing worker.
-
Citations
13 Claims
-
1. A computer program product comprising a non-transitory machine-readable medium storing instructions that, when executed by at least one programmable processor that comprises at least one physical core and a plurality of logical cores, cause the at least one programmable processor to perform operations comprising:
-
designating a first logical core from the plurality of logical cores for use by a first message-passing worker of a plurality of message-passing workers; designating a second logical core from the plurality of logical cores for use by a first job worker of a plurality of job workers, the first and second logical cores sharing one or more resources of the at least one physical core; designating an additional logical core from the plurality of logical cores for use by a second message-passing worker of the plurality of message-passing workers; assigning a first set of database objects from a plurality of database objects in a database management system to the first message-passing worker such that the first message-passing worker has exclusive write access to the first set of database objects; assigning a second set of database objects from the plurality of database objects in the database management system to the second message-passing worker such that the second message-passing worker has exclusive write access to the second set of database objects, the first set of database objects and the second set of database objects having at least one database object in common; providing read-only access to the plurality of database objects via the first job worker; executing operations by the first message-passing worker in an order in which request messages are received in a message queue of the first message-passing worker; running a rebalancing operation to reassign the plurality of database objects to equalize a load across the plurality of message-passing workers; receiving, by a rebalanced message-passing worker of the plurality of message-passing workers after the running of the rebalancing operation, a new request message pertaining to a reassigned database object of the plurality of database objects, the reassigned database object formerly being assigned to the rebalanced message-passing worker but currently being assigned to a new message-passing worker of the plurality of message-passing workers; and posting, by the rebalanced message-passing worker, the new request message into a message queue of the new message-passing worker. - View Dependent Claims (2, 3, 4)
-
-
5. A system comprising:
-
at least one programmable processor comprising at least one physical core and a plurality of logical cores; and a non-transitory machine-readable medium storing instructions that, when executed by the at least one programmable processor, cause the at least one programmable processor to perform operations comprising; designating a first logical core from the plurality of logical cores for use by a first message-passing worker of a plurality of message-passing workers; designating a second logical core from the plurality of logical cores for use by a first job worker of a plurality of job workers, the first and second logical cores sharing one or more resources of the at least one physical core; designating an additional logical core from the plurality of logical cores for use by a second message-passing worker of the plurality of message-passing workers; assigning a first set of database objects from a plurality of database objects in a database management system to the first message-passing worker such that the first message-passing worker has exclusive write access to the first set of database objects; assigning a second set of database objects from the plurality of database objects in the database management system to the second message-passing worker such that the second message-passing worker has exclusive write access to the second set of database objects, the first set of database objects and the second set of database objects having at least one database object in common; providing read-only access to the plurality of database objects via the first job worker; executing operations by the first message-passing worker in an order in which request messages are received in a message queue of the first message-passing worker; running a rebalancing operation to reassign the plurality of database objects to equalize a load across the plurality of message-passing workers; receiving, by a rebalanced message-passing worker of the plurality of message-passing workers after the running of the rebalancing operation, a new request message pertaining to a reassigned database object of the plurality of database objects, the reassigned database object formerly being assigned to the rebalanced message-passing worker but currently being assigned to a new message-passing worker of the plurality of message-passing workers; and posting, by the rebalanced message-passing worker, the new request message into a message queue of the new message-passing worker. - View Dependent Claims (6, 7, 8)
-
-
9. A computer-implemented method comprising:
-
designating a first logical core from a plurality of logical cores of a data processor for use by a first message-passing worker of a plurality of message-passing workers; designating a first logical core from the plurality of logical cores for use by a first message-passing worker of a plurality of message-passing workers; designating a second logical core from the plurality of logical cores for use by a first job worker of a plurality of job workers, the first and second logical cores sharing one or more resources of the at least one physical core; designating an additional logical core from the plurality of logical for use by a second message-passing worker of the plurality of message-passing workers; assigning a first set of database objects from a plurality of database objects in a database management system to the first message-passing worker such that the first message-passing worker has exclusive write access to the first set of database objects; assigning a second set of database objects from the plurality of database objects in the database management system to the second message-passing worker such that the second message-passing worker has exclusive write access to the second set of database objects, the first set of database objects and the second set of database objects having at least one database object in common; providing read-only access to the plurality of database objects via the first job worker; executing operations by the first message-passing worker in an order in which request messages are received in a message queue of the first message-passing worker; running a rebalancing operation to reassign the plurality of database objects to equalize a load across the plurality of message-passing workers; receiving, by a rebalanced message-passing worker of the plurality of message-passing workers after the running of the rebalancing operation, a new request message pertaining to a reassigned database object of the plurality of database objects, the reassigned database object formerly being assigned to the rebalanced message-passing worker but currently being assigned to a new message-passing worker of the plurality of message-passing workers; and posting, by the rebalanced message-passing worker, the new request message into a message queue of the new message-passing worker. - View Dependent Claims (10, 11, 12, 13)
-
Specification