×

Distributed data management system

  • US 8,504,521 B2
  • Filed: 04/11/2011
  • Issued: 08/06/2013
  • Est. Priority Date: 07/28/2005
  • Status: Active Grant
First Claim
Patent Images

1. A method for storing data objects among a plurality of database management nodes operating on a plurality of computers in communication with each other over a computer network, the method comprising:

  • maintaining a global data structure in at least one of the database management nodes, wherein the global data structure maps each logical data store of a plurality of logical data stores to a corresponding one of the database management nodes in which the logical data store is stored and, upon receipt of a key value identifying a data object, provides an identity of a database management node storing a logical data store in which the data object is stored;

    storing a first data object in a first logical data store selected from the plurality of logical data stores, wherein the first logical data store corresponds to a key value of the first data object;

    upon determining that memory consumption of a first database management node corresponding to the first logical data store exceeds a predetermined threshold, sending requests from the first database management node to one or more of the plurality of database management nodes in order to determine whether any one of the plurality of database management nodes has memory to accommodate the first logical data store;

    identifying a second database management node from the one or more of the plurality of database management nodes that responds to the requests with replies affirming having memory to accommodate the first logical data store;

    enabling migration of the first logical data store from the first database management node to the second database management node to rebalance memory consumption among the database management nodes while simultaneously allowing concurrent and non-blocking access to data objects stored in other logical data stores that are not involved in the migration; and

    blocking access to logical data stores that are being migrated until the migration successfully completes.

View all claims
  • 3 Assignments
Timeline View
Assignment View
    ×
    ×