The present invention relates to distributed database systems and methods for selectively employing storage engines.
Multiple data storage formats exist for storing data in a database. Storage engines exist that are capable of storing data in a particular data format. Applications, system processes, and other programs that access the data instruct the storage engine to perform a database operation, causing the storage engine to interact with the data in the expected data format.
Conventional approaches to database storage are typically tied to a particular data format and, in some approaches, a storage engine capable of managing that data format. While the format may be changed with some effort, conventional approaches require significant time and involve complexity that makes such changes difficult, at best. For example, modifications to the data format and/or the storage engine may need to comply with forward- and backward-compatibility requirements. The inefficiency of being tied to a particular format is exacerbated by the advent of “big data” and ever-larger databases. More efficient storage and retrieval of the information stored in databases is increasingly important. While a number of storage formats have been employed in storing database data, the selection of a particular format has largely been dependent on intuition and guesswork of the user and/or the application software developer. Furthermore, adding or modifying storage functionality in a particular storage format has typically required changes to the high-level database code in user applications and system routines. Scaling a database up in size has similarly presented issues, as the database read/write operations coded in an application may be tailored to a data format that is no longer optimal.
There is therefore a need for a database that can store data in the optimal data format in a particular situation without requiring changes to the applications or processes accessing that data. Accordingly, methods and systems are provided by which a storage application programming interface (API) is employed as a level of abstraction in database read/write operations. A database application may simply instruct the storage API to “write” a portion of a database, and the database engine selects an appropriate storage engine based on automated optimization analysis, user preference, or other factors. In some embodiments, the database application may request that data be stored by a particular storage engine, or stored in a particular format. The database engine may fulfill the request, and may also cause the data to be stored in a different format determined to be optimal.
In some embodiments, storage engines may be modular and “pluggable,” allowing for modification, removal, or addition of storage engines without changing the application code. In further embodiments, the storage engine may determine to store the data in one or more data formats, including an optimal format that the storage engine determines. In this manner, operation requests received by the database may be carried out such that different portions of the database may be stored by different storage engines in different formats, enabling optimization of storage operations at various levels in a database (e.g., entire database, partitions, logical groupings, and any base unit of storage). Optimization decisions can be made at each step as the level of granularity increases from the database engine to the storage engine to the particular data format. For example, a “write” request received by the database may cause the database engine to select a particular storage engine to carry out the request; the storage engine may then determine an optimal format in which to store the data.
A storage API interacting with a database engine capable of calling pluggable storage engines in such a manner offers a number of benefits. For example, application code is simplified. Fewer modifications may be required to switch between engines, because the storage API is opaque to the user, who need not be concerned with format-specific operations underlying “write” operations or other access requests. The same query language, data model, scaling considerations, security protocols, and operational tooling may be used no matter the underlying data format.
Further, a database engine calling pluggable storage engines offers benefits to database systems employing replica sets having a primary node and one or more replica secondary nodes. A storage API allows such replica sets to be easily managed with minimal code, as the storage API allows a user to simultaneously write to a primary node in one format, and to a replica node in another format, without regard to the respective data formats. This approach allows live migration between different storage engines and/or data formats, thereby reducing the complexity and time required for conventional approaches.
In addition, the database engine underlying the storage API may be configured to automatically select a storage engine (i.e., data format), allowing for dynamic changes to the format of a particular set of data based on historic and/or expected data operations and volume, data structure and characteristics, and other factors. Any change in data format can be monitored, and a comparison can made between the performance and efficiency observed in the previous and current data format. Based on that comparison, any necessary adjustments can be made. In some embodiments, the previous and current data format may be maintained in parallel for some amount of time, to allow for a comparison and selection of an optimal format.
According to one aspect of the present invention, a database system is provided comprising at least one processor configured to execute a plurality of system components, wherein the system components comprise an operation prediction component configured to determine an expected set of operations to be performed on a portion of the database, a data format selection component configured to select, based on at least one characteristic of the expected set of operations, a data format for the portion of the database, and at least one storage engine for writing the portion of the database in the selected data format. According to one embodiment, the operation prediction component is further configured to access information about a past set of operations for a first time period, and predict, based on the past set of operations for the first time period, an expected set of operations to be performed on the portion of the database during a second time period. According to one embodiment, the operation prediction component is further configured to determine the expected set of operations to be performed on the portion of the database by identifying a data structure for data to be stored in the portion of the database. According to one embodiment, the characteristic of the expected set of operations is a relatively high ratio of read operations to write operations. According to another embodiment, the data format is a row-store format.
According to one embodiment, the data format is a column-store format. According to one embodiment, the characteristic of the expected set of operations is a determination that sequential operations are likely to be performed on a first storage location and a second storage location nearby the first storage location. According to one embodiment, the characteristic of the expected set of operations is a relatively high ratio of write operations to read operations. According to one embodiment, the data format is a log-sequence merge format. According to another embodiment, the characteristic of the expected set of operations is a requirement to update less than all of the fields in a plurality of records stored in the database, and wherein the data format is a column-store format.
According to another aspect of the present invention, a method of performing operations in a computer database is provided comprising steps of determining, by a computer system, an expected set of operations to be performed on a portion of a database, selecting, based on at least one characteristic of the expected set of operations, a data format for the portion of the database, storing the selected data format in a configuration metadata component of the computer database, and writing data to the portion of the database in the selected data format. According to one embodiment, determining the expected set of operations to be performed on the portion of the database comprises accessing information about a past set of operations for a first time period, and predicting, based on the past set of operations for the first time period, an expected set of operations to be performed on the portion of the database during a second time period. According to another embodiment, determining the expected set of operations to be performed on the portion of the database comprises identifying a data structure for data to be stored in the portion of the database.
According to one embodiment, the characteristic of the expected set of operations is a relatively high ratio of read operations to write operations. According to one embodiment, the first data format is a row-store format. According to one embodiment, the first data format is a column-store format. According to one embodiment, the characteristic of the expected set of operations is a determination that sequential operations are likely to be performed on a first storage location and a second storage location nearby the first storage location. According to one embodiment, the characteristic of the expected set of operations is a relatively high ratio of write operations to read operations. According to another embodiment, the second data format is a log-sequence merge format. According to yet another embodiment, the first characteristic of the expected set of operations is a requirement to update less than all of the fields in a plurality of records stored in the database, and wherein the first data format is a column-store format.
According to another aspect of the present invention, a method of performing operations in a computer database is provided comprising steps of presenting, in a user interface of a computer system, a plurality of data format options for a portion of a database, receiving, from the user interface, a user selection of a data format for the portion of the database, storing the data format selection as configuration metadata for the database, responsive to the data format selection indicating a first data format, activating a first storage engine to store the portion of the database in the first data format, and responsive to the data format selection indicating a second data format, activating a second storage engine to store the portion of the database in the second data format. According to one embodiment, the first data format is a row-store format. According to one embodiment, the first data format is a column-store format. According to another embodiment, the second data format is a log-sequence merge format.
According to one aspect of the present invention, a method of performing operations in a computer database, comprising steps of receiving, from a computer application, a request to perform a write operation, wherein the request does not specify a data storage format, selecting, by a computer system, a data storage format from a group consisting of at least a first data storage format and a second data storage format, responsive to a selection of the first data storage format, performing the write operation using a first data storage engine, and responsive to a selection of the second data storage format, performing the write operation using a second data storage engine. According to another aspect, a database system for storing data in an optimal format is provided comprising an application programming interface configured to receive, from a computer system, a request to perform a write operation, wherein the request does not specify a data storage format, at least one storage component configured to store a plurality of data records, a first storage engine configured to store the plurality of data records in a first format, a second storage engine configured to store the plurality of data records in a second format, and a storage engine selector for selectively executing one of the first storage engine or the second storage engine to perform the write operation. According to one embodiment, system further comprises a database monitor configured to track performance information about the database system, and a memory configured to store analytics data comprising performance information tracked by the database monitor. According to another embodiment, the system further comprises a configuration database adapted to stored configuration metadata about the database, the configuration metadata including at least one of an association between a storage engine and one of the at least one storage components.
According to another aspect of the present invention, a database system for storing data in an optimal format is provided comprising an application programming interface configured to receive, from a computer system, a request to perform a write operation, wherein the request does not specify a data storage format, a replica set comprising a primary node having a first storage component and a secondary node having a second storage component, the first storage component and the second storage component configured to store a plurality of records, a first storage engine configured to store the plurality of data records in a first format in the first storage component, and a second storage engine configured to store the plurality of data records in a second format in the second storage component. According to one embodiment, the system further comprises a storage engine selector for selectively executing one of the first storage engine or the second storage engine to perform the write operation.
Various aspects of at least one embodiment are discussed herein with reference to the accompanying figures, which are not intended to be drawn to scale. The figures are included to provide illustration and a further understanding of the various aspects and embodiments, and are incorporated in and constitute a part of this specification, but are not intended as a definition of the limits of the invention. Where technical features in the figures, detailed description or any claim are followed by reference signs, the reference signs have been included for the sole purpose of increasing the intelligibility of the figures, detailed description, and/or claims. Accordingly, neither the reference signs nor their absence are intended to have any limiting effect on the scope of any claim elements. In the figures, each identical or nearly identical component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled in every figure.
In the figures:
A system and method is provided for a database storage API capable of selectively mapping to different pluggable storage engines and storage formats. In a preferred embodiment, the database storage API is employed in a non-relational database system, in which documents or other structures not limited by a schema are stored. In one example, the selection of a particular storage engine and/or data format may be made by a user via a user interface. The user may be presented with one or more recommendations of optimal storage engines for a particular data structure, collection, or database according to one or more factors. In another example, the database engine may select a particular storage engine and/or data format, or the storage engine itself or other system components may select a particular data format based on one or more factors. For example, a storage engine and/or data format may be selected for its expected optimal performance as compared to other storage engine options.
The factors used to recommend or select an optimal storage engine or data format may relate to the type and breakdown of historical operations performed on the database (e.g., volume of write requests, volume or read requests, timing of writes and/or read, sparsity of data, etc.), and/or the characteristics of a set of operations predicted to be performed on the database. Such predictions can be made based on the layout of the data, the nature of the data, the data type (e.g., primary database data or database index data), historical operations for a given time period, database compression characteristics, or other aspects of the data and the operations to be performed on it. In some embodiments, a change in storage engines for a portion of the database is assessed to determine if the database performance with respect to that portion is more optimal before or after the change, so that appropriate measures may be recommended or taken.
Examples of the methods, devices, and systems discussed herein are not limited in application to the details of construction and the arrangement of components set forth in the following description or illustrated in the accompanying drawings. The methods and systems are capable of implementation in other embodiments and of being practiced or of being carried out in various ways. Examples of specific implementations are provided herein for illustrative purposes only and are not intended to be limiting. In particular, acts, components, elements and features discussed in connection with any one or more examples are not intended to be excluded from a similar role in any other examples.
Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. Any references to examples, embodiments, components, elements or acts of the systems and methods herein referred to in the singular may also embrace embodiments including a plurality, and any references in plural to any embodiment, component, element or act herein may also embrace embodiments including only a singularity. References in the singular or plural form are not intended to limit the presently disclosed systems or methods, their components, acts, or elements. The use herein of “including,” “comprising,” “having,” “containing,” “involving,” and variations thereof is meant to encompass the items listed thereafter and equivalents thereof as well as additional items. References to “or” may be construed as inclusive so that any terms described using “or” may indicate any of a single, more than one, and all of the described terms.
An example of a database subsystem 100 is shown in
Database subsystem 100 includes an application programming interface (API) 108 that receives database requests, including requests to perform read and write operations. When a write operation is requested, the storage API 108 in response selectively triggers a first storage engine 104 or a second storage engine 106 configured to store data in a first data format or second data format, respectively, in node 110. As discussed in more detail below, a database monitor 111 may track a number of analytics about the database. In some embodiments, the database monitor 111 is configured to track the operations performed on the data over time, and stores that information as analytics data 113. In some examples, analytic data may be stored in a separate database. In other examples, the analytics data is stored as a name collection (i.e., a logical grouping of data). These analytics may be provided to the storage API 108, which relies on the analytics to selectively actuate an appropriate storage engine.
In one example, the database monitor 111 tracks the relative number of read and write operations performed on a collection within the database. In another example, the database monitor 111 is configured to track any operations (e.g., reads, writes, etc.) performed on any base unit of data in the database.
In some embodiments, the storage API 108 uses the tracked data (e.g., analytics data) collected by the database monitor 111 and/or the analytics data 113 to select an optimal storage engine and/or data format for a database, a collection, or a document having the observed read/write ratio. In one example, the storage API 108 is mapped to the selected storage engine. For example, an identifier of the selected storage engine may be stored in a location in memory or on disk; when a write operation request is received by the storage API 108, the identifier is used to identify and activate the storage engine. Alternatively, elements of the database can specify a mapping or association with a storage engine that can be manually edited, edited through an administrative interface, or automatically changed responsive to system monitoring. In other embodiments, the database monitor 111 itself is configured to determine an optimal storage engine based on the analytics data 113 and other aspects of the data, for example, stored in the database, database collection, or in a document. This determination may be passed to the storage API 108, or otherwise used to map the storage API 108 to a determined storage engine.
In an embodiment incorporating a replica set, a primary node executes a write operation on data, then passes the operation through an associated API (e.g., the database API 260) to a storage engine API 208. The storage API 208 in turn passes the write operation to a particular storage engine (e.g., storage engine 204), which would be responsible for any transformation or mapping of the data as required by the storage engine. The storage engine, upon receiving the request, stores the data in a storage format associated with the storage engine. In some embodiments, the storage engine may also perform any additional transformations or mappings of the data.
In one example, the storage API 208 is a set of protocols, functions, and data used by the database API 260 to perform operations on the database. In other words, the API as discussed herein provides both the programming interface to which commands are passed, as well as the underlying data and functionality for carrying out those commands. For example, the storage API 208 may provide functions for performing operations on the database, including write operations, read operations, or commit operations. Any necessary data or variables are passed to such functions, the details of which are carried out by the functionality of the storage API 208. The storage API 208 may be configured to perform operations on the nodes (e.g., primary node or secondary nodes) of a replica set, as discussed in more detail below with respect to
In some embodiments, the storage API 208 is in direct communication with the database API 260. In other embodiments, including those in which the managed database subsystem 200 is located on a server connected by a network to other database components, the storage API 208 may be in communication with a network interface configured to receive requests from the database API 260 and pass them to the storage API 208.
The first storage engine 204 and second storage engine 206 are configured to store database data in the data store 220 in one or more data formats. The embodiments discussed in this application discuss a non-relational database scenario. In such scenarios, a “document” is a collection of attribute-value associations relating to a particular entity, and in some examples forms a base unit of data storage for the managed database system. Attributes are similar to rows in a relational database, but do not require the same level of organization, and are therefore less subject to architectural constraints. A collection is a group of documents that can be used for a loose, logical organization of documents. It should be appreciated, however, that the concepts discussed herein are applicable to relational databases and other database formats, and this disclosure should not be construed as being limited to non-relational databases in the disclosed embodiments.
In one example, the database data may include logical organizations of subsets of database data. In one embodiment, the data is a collection of documents or other structures in a non-relational database. The data store 220 may also store index data, which may include copies of certain columns of data that are logically ordered to be searched efficiently. Each entry in the index may consist of a key-value pair that represents a document or field (i.e., the value), and provides an address or pointer to a low-level disk block address where the document or field is stored (the key). The data store 220 may also store an operation log (“oplog”), which is a chronological list of write/update operations performed on the data store during a particular time period. The oplog can be used to roll back or re-create those operations should it become necessary to do so due to a database crash or other error.
Primary data, index data, or oplog data may be stored in any of a number of database formats, including row store, column store, log-structured merge (LSM) tree, or otherwise. In row store format, all of the columns of a particular document are stored together in memory. For example, in a database of employee information, all of the information about a particular employee (e.g., name, address, SSN, salary, title) may be stored in a contiguous block of memory. Data in a row-store format may be stored to disk and represented as a B-tree, B+tree, or variation thereof. B-trees and their variants are described in “The Ubiquitous B-Tree” by Douglas Comer (Computing Surveys, Vol. 11, No. 2, June 1979), which is hereby incorporated by reference in its entirety.
In column-store format, all instances of a particular field (or column) are stored together. In the employee database example, the salary of each employee may be stored in a contiguous block of memory. Column-store format is described in “C-Store: A Column Oriented DBMS” by Mike Stonebraker et al., (Proceedings of the 31st VLDB Conference, 2005), which is hereby incorporated by reference in its entirety.
Reading a particular document or field that is stored in row-store or column-store format generally involves using the index to locate and read the requested data from disk. But when a document or field is updated in row-store or column-store format, the entire row or column must be loaded from disk, the appropriate field(s) updated, and the entire row or column written back to disk. This read-and-write requirement may be costly in terms of input/output, particularly when the data being acted upon is subject to a relatively high number of writes. In LSM tree format, data to be overwritten (i.e., updated) is typically not read first; rather, updates to the data are simply written to disk, with a pointer to the new version of the data created. LSM tree format is described in “The Log-Structured Merge-Tree (LSM-Tree)” by Patrick O'Neil et al. (1996), which is hereby incorporated by reference in its entirety.
Returning again to
One advantage of using the storage API 108 as an abstraction layer between the database API and the storage engines is that the identity and selection of a particular storage engine can be transparent to the database API and/or a user interacting with the database API. For example, the database API may pass a “write” function call to the storage API 108 instructing the storage API to write a particular set of data to stable storage. The storage API 108 then determines, according to its own analysis and/or user input, which storage engine should perform the write operation in which data format. Different storage engines may be appropriate for different types of data stored in different collections that may undergo a variety of different operations. Thus, the choice and implementation of calls to an appropriate storage engine are made by the storage API 108, freeing the database API calls to simply request a “write” of certain data. This abstraction level allows for the implementation of the system on large filesystems that may be stored across machines in a database cluster, such as the Hadoop Filesystem offered by the Apache Software Foundation.
Another advantage of using the storage API 108 is the ability to add, remove, or modify storage engines without modifying the requests being passed to the API 108. The storage API 108 is configured to identify the available storage engines and select the appropriate one based on a one or more factors discussed below. The database API requesting write operations need not know the particulars of the storage engine selection or operation, meaning that storage engines may be embodied in pluggable modules that may be swapped out or modified. Thus, users are able to leverage the same query language, data model, scaling, security and operational tooling across different applications, each powered by different pluggable storage engines.
The embodiment shown and discussed with respect to
The primary node 320 and secondary nodes 330, 340, 350 may be configured to store data in any number of database formats or data structures as are known in the art. In a preferred embodiment, the primary node 320 is configured to store documents or other structures associated with non-relational databases. The embodiments discussed herein relate to documents of a document-based database, such as those offered by MongoDB, Inc. (of New York, N.Y. and Palo Alto, Calif.), but other data structures and arrangements are within the scope of the disclosure as well.
In one embodiment, both read and write operations may be permitted at any node (including primary node 320 or secondary nodes 330, 340, 350) in response to requests from clients. The scalability of read operations can be achieved by adding nodes and database instances. In some embodiments, the primary node 320 and/or the secondary nodes 330, 340, 350 are configured to respond to read operation requests by either performing the read operation at that node or by delegating the read request operation to another node (e.g., a particular secondary node 330). Such delegation may be performed based on load-balancing and traffic direction techniques known in the art.
In some embodiments, the database only allows write operations to be performed at the primary node 320, with the secondary nodes 330, 340, 350 disallowing write operations. In such embodiments, the primary node 320 receives and processes write requests against the database, and replicates the operation/transaction asynchronously throughout the system to the secondary nodes 330, 340, 350. In one example, the primary node 320 receives and performs client write operations and generates an oplog. Each logged operation is replicated to, and carried out by, each of the secondary nodes 330, 340, 350, thereby bringing those secondary nodes into synchronization with the primary node 320. In some embodiments, the secondary nodes 330, 340, 350 may query the primary node 320 to receive the operation log and identify operations that need to be replicated. In other embodiments, the operation log may be transmitted from the primary node 320 to the secondary nodes 330, 340, 350 periodically or in response to the occurrence of a predefined condition, such as accruing a threshold number of operations in the operation log that have not yet been sent to the secondary nodes 330, 340, 350.
In some embodiments, the primary node 320 and the secondary nodes 330, 340, 350 may operate together to form a replica set 310 that achieves eventual consistency, meaning that replication of database changes to the secondary nodes 330, 340, 350 may occur asynchronously. When write operations cease, all replica nodes of a database will eventually “converge,” or become consistent. This may be a desirable feature where higher performance is important, such that locking records while an update is stored and propagated is not an option. In such embodiments, the secondary nodes 330, 340, 350 may handle the bulk of the read operations made on the replica set 310, whereas the primary node 330, 340, 350 handles the write operations. For read operations where a high level of accuracy is important (such as the operations involved in creating a secondary node), read operations may be performed against the primary node 320.
It will be appreciated that the difference between the primary node 320 and the one or more secondary nodes 330, 340, 350 in a given replica set may be largely the designation itself and the resulting behavior of the node; the data, functionality, and configuration associated with the nodes may be largely identical, or capable of being identical. Thus, when one or more nodes within a replica set 310 fail or otherwise become available for read or write operations, other nodes may change roles to address the failure. For example, if the primary node 320 were to fail, a secondary node 330 may assume the responsibilities of the primary node, allowing operation of the replica set to continue through the outage. This failover functionality is described in U.S. application Ser. No. 12/977,563, the disclosure of which is hereby incorporated by reference.
Each node in the replica set 310 may be implemented on one or more server systems. Additionally, one server system can host more than one node. Each server can be connected via a communication device to a network, for example the Internet, and each server can be configured to provide a heartbeat signal notifying the system that the server is up and reachable on the network. Sets of nodes and/or servers can be configured across wide area networks, local area networks, intranets, and can span various combinations of wide area, local area and/or private networks. Various communication architectures are contemplated for the sets of servers that host database instances and can include distributed computing architectures, peer networks, virtual systems, among other options.
The primary node 320 may be connected by a LAN, a WAN, or other connection to one or more of the secondary nodes 330, 340, 350, which in turn may be connected to one or more other secondary nodes in the replica set 310. Connections between secondary nodes 330, 340, 350 may allow the different secondary nodes to communicate with each other, for example, in the event that the primary node 320 fails or becomes unavailable and a secondary node must assume the role of the primary node.
An example of a database subsystem 400 incorporating a replica set 410 is shown in
In one example, database operation requests directed to the replica set 410 may be processed by the primary node 420 and either performed by the primary node 420 or directed to a secondary node 430, 440 as appropriate. In one embodiment, both read and write operations are permitted at any node (including primary node 320 or secondary nodes 430, 440) in response to requests from clients. The scalability of read operations can be achieved by adding nodes and database instances. In some embodiments, the primary node 420 and/or the secondary nodes 430, 440 are configured to respond to read operation requests by either performing the read operation at that node or by delegating the read request operation to another node (e.g., a particular secondary node 430). Such delegation may be performed based on load-balancing and traffic direction techniques known in the art.
In some embodiments, the database only allows write operations to be performed at the primary node 420, with the secondary nodes 430, 440 disallowing write operations. In such embodiments, the primary node 420 receives and processes write requests against the database, and replicates the operation/transaction asynchronously throughout the system to the secondary nodes 430, 440. In one example, the primary node 420 receives and performs client write operations and generates an oplog. Each logged operation is replicated to, and carried out by, each of the secondary nodes 430, 440, thereby bringing those secondary nodes into synchronization with the primary node 420 under an eventual-consistency model.
In one example, primary database data (i.e., the data being stored and queried) may be stored by one or more data storage engines in one or more data formats in the primary data memory 422, 432, 442 of nodes 420, 430, 440, respectively. Database index data may be stored by one or more data storage engines in one or more data formats in the index data memory 424, 434, 444 of nodes 420, 430, 440, respectively. Oplog data may be stored by a data storage engine in a data format in oplog data memory 426, 436, 446 of nodes 420, 430, 440, respectively.
The shard cluster is the grouping of shards that collectively represent the data within the database, with each shard responsible for storing a particular range or subset of documents in the database. A shard cluster typically comprises multiple shard servers (e.g., 502-508) hosting multiple partitions (e.g., 552-574) or shards of data, one or more configuration servers (e.g., 510-514) for metadata management, and shard router processes (e.g., 516-518). Metadata for the shard cluster can include, for example, information on the ranges of data stored in each partition, information associated with managing the shard cluster, partition counts, number of shard servers, data index information, partition size constraints, data distribution thresholds, among other options.
Each shard of data (e.g., 552-574) can be configured to reside on one or more servers executing database operations for storing, retrieving, managing, and/or updating data. In some embodiments, a shard of data corresponds to a chunk of data. In other embodiments, a shard server 502 contains multiple partitions, or “chunks,” of database data. A chunk can be configured as a contiguous range of data from a particular collection in the database. Collections are logical organizations of subsets of database data. In one example, a collection of documents is a named grouping of the data, for example, a named grouping of documents. The named grouping can be homogenous or heterogeneous. In some embodiments, collections are organizations of database data similar to relational database tables.
Configurations within a shard cluster can be defined by metadata associated with the managed database referred to as shard metadata. Shard metadata can include information on collections within a given database, the number of collections, data associated with accessing the collections, database key properties for a given collection, ranges of key values associated with a given partition, shard, and/or chunk of data within a given collections, to provide some examples.
In some embodiments, partitioning or sharding of the database in data chunks occurs based on database collections rather than the database as a whole. For example, when implementing a database management system for a service like the well-known TWITTER service, it is appreciated that the collection of “tweets” or messages within the database of the TWITTER service would be several orders or magnitude larger than the next largest collection. The size and throughput associated with the collection of tweets would be ideal for sharding, whereas smaller collections can be configured to reside on a single server. In some implementations, the data within the database is organized into documents. Some examples of document organization formats include the known JSON (JavaScript Object Notation) and BSON (binary encoded serialization of JSON) formatting for documents. BSON is a binary format in which zero or more key/value pairs are stored as a single entity. The BSON entity can be referred to as a document. In some examples, BSON adds some additional information to documents, like length prefixes, that make it the document easier and faster to traverse. BSON is also designed to be fast to encode and decode. For example, integers are stored as 32 (or 64) bit integers, so they don't need to be parsed to and from text. This uses more space than JSON for small integers, but may be much faster to parse. The choice between JSON and BSON may therefore be made according to traversal needs, storage efficiency, or other considerations.
Returning to
The router processes 516-518 are configured to provide a transparent interface to handle database requests. The shard router processes 516-518 receive such client requests and route the database requests to the appropriate shard(s), e.g., 552-574 on shard servers 502-508. According to some embodiments, a router process, e.g., 516, can be configured to operate as a routing and coordination process that makes the various components of the cluster look like a single system, for example, to client 520. In response to receiving a client request, the router process 516 routes the request to the appropriate shard or shards. The shard(s) return any results to the router process. The router process 516 can merge any results and communicate the merged result back to the client 520. Thus, the client 520 may submit requests through router processes 516-518 without regard to whether the request is being served by a sharded database, or the specifics of the implementation of such a database.
In some examples, the router process 516 is also configured to establish current state information for the data distributed throughout the database by requesting metadata information on the database from the configuration server(s) 510-514. The request for metadata information can be executed on startup of a routing process. Further requests can be initiated by the routing process and/or can be initiated by a configuration server. In one example, a change at the configuration server can trigger a distribution of updates to any routing processes. In some embodiments, any changes that occur on the configuration server(s) can be propagated to each router process 516-518, as needed. In one example, router processes 516-518 can be configured to poll the configuration servers(s) 510-514 to update their state information periodically. In others examples, router processes can be configured to poll the configuration servers(s) 510-514 to update their state information on a schedule, periodically, intermittently, and can be further configured to receive updates pushed from the configuration server(s) 510-514 and/or any combination of thereof. According to one embodiment, the router processes capture metadata information on the shard cluster stored at the configuration servers. In some examples, the metadata information includes information on the data stored in the database, how the data is partitioned, version information associated with the partitions, database key values associated with partitions, read/write statistics, partition size, the current storage engine(s) associated with the partitions, etc. According to some embodiments, the router process 516 can be configured without persistent state information. For example, at initiation, the router process 516 cannot fully route data requests until its state is updated with the metadata describing the distribution of data throughout the shards.
According to some embodiments, router processes can run on any server within the managed database and/or on any number of server(s) as desired. For example, the router processes can be executed on stand-alone systems, and in other examples the router processes can be run on the shard servers themselves. In yet another example, the router processes can be run on application servers associated with the managed database. Under typical installations, there are no limits on the number of router processes that can be invoked. The addition of routing processes can permit the managed database to route greater number of requests to the appropriate shards of data. In some embodiments, additional routing processes can enable additional client connections to the partitioned database. In other embodiments, additional routing processes can facilitate management of the distribution of data within the database.
According to one embodiment, configuration server(s) 510-514 are configured to store and manage the database's metadata. In some examples, the metadata includes basic information on each shard in the shard cluster (including, for example, network communication information), server information, number of chunks of data, chunk version, number of shards of data, shard version, and other management information for routing processes, database management processes, chunk splitting processes, etc. According to some embodiments, chunk information, such as the range or subset of information for which a shard is responsible, can be the primary data stored by the configuration server(s) 510-514. In some examples, chunks are defined by a triple (collection, minKey, and maxKey) and the metadata stored on the configuration servers establishes the relevant values for a given chunk of data.
In some examples, each of the installed configuration server(s) has a complete copy of all the chunk metadata information for the managed database.
In addition to the consistency processes executed on the configuration servers, the shard cluster can be configured with various replication models to insure consistent replication of any changes to the database's metadata stored on the configuration servers. In some embodiments, the replication model for the configuration servers can be different from the replication model used within the rest of the shard cluster, for example, on the shard servers 502-508. In one embodiment, the configuration servers can be configured to perform operations under various all-or-nothing approaches while the data stored in database shards can be configured to operate under an eventual consistency model.
To partition a collection, a shard key pattern can be specified. The shard key pattern, in some embodiments, can be similar to the key pattern used to define an index. The shard key pattern establishes one or more fields to define the shard key upon which the managed database can distribute data. According to some embodiments, establishing an appropriate shard key facilitates the efficient management of data within the shard cluster. In some embodiments, the shard key pattern can be input through a management process. The shard key pattern can be predefined and/or dynamically generated. Once established, the shard key pattern can be used to control the partitioning of data. The resulting chunks of data are typically constructed of contiguous ranges of data.
A process 600 of operating a storage API on a database server (e.g., the shard server 500 depicted in
At step 610, process 600 begins.
At step 620, an expected set of operations to be performed on a portion of a database is determined. In one embodiment, the portion of the database stores one type of information, such as primary data, index data, or an oplog, for that database. In some embodiments, the portion of the database may not represent the entirety of that type of data. For example, where the portion of the database is some subset of the primary data, other portions of the database may also store primary data. Furthermore, the portion of the database may represent a single document, a collection of documents, or the entire database.
In some embodiments, the expected set of operations is determined based on the type of data stored in the portion of the database. Different data types often have different characteristics that may help in identifying or predicting an expected set of operations. For example, a portion of the database storing an oplog may be expected to undergo more write operations than read operations, since each operation performed on the primary data of the database will be written to the oplog, but the oplog will only be read relatively occasionally (e.g., in the event of a database failure or data inconsistency). By contrast, primary data in the database may be more likely to have a higher number of read operations, since database queries often represent a significant portion of the operations performed on the database.
In some embodiments, the amortized cost of a typical operation may be considered. For example, primary data is considered to have a relatively high locality of reference, meaning that, when performing an operation on a piece of stored data, the data in nearby memory locations is more likely to be relevant/required in related operations than a randomly selected memory location. When a document is stored in row-store format, for example, the data is stored contiguously; reading multiple blocks of data in one read operation is likely to yield several useful pieces of data in responding to a query. Thus, the cost (in time) of that read operation may be amortized over the number of relevant pieces of data read during that operation. For example, if a read operation takes x amount of time, but is able to read in 10 pieces of information needed in responding to the current query, then the amortized cost of that read operation may be considered x/10. In some embodiments, this amortized cost may be used in determining the expected set of operations.
Relatedly, in some embodiments, the expected set of operations is determined based on the nature of the data stored in the portion of the database. As discussed above, primary data may be expected to have a relatively higher proportion of read operations than oplog data. It will also be appreciated that the nature of some types of primary data, for example, may be used in identifying or predicting an expected set of operations. For example, a portion of a database that stores product information for an ecommerce store that rarely changes its product offerings may be expected to have a relatively high number of read operations as opposed to write operations, since the product information may often be accessed (i.e., read) by visitors to the website but may rarely be updated (i.e., written) by the store administrator. On the other hand, a portion of a database that stores inventory information for a high-volume ecommerce store may be expected to have a relatively high number of both read and write operations, as visitor purchases necessitate verifying (i.e., reading) and updating (i.e., writing) the inventory information to the database. As another example, a node may be set up for the purpose of performing data mining, suggesting that the node will undergo mostly read operations once it is set up.
In some embodiments, the expected set of operations is determined based on a historical analysis of the portion of the database and the other data (and metadata) available for that portion of the database. For example, the oplog may be consulted to determine how many read operations are performed on a portion of the database storing primary data. In some embodiments, a tally may be kept of the number and type of operations performed on the portion of the database during a particular time period. These operation tallies may be used to determine, for a particular time period, the relative proportions of read and write operations performed on the portion of the database. Those relative proportions may then be considered in identifying or predicting an expected set of operations to be performed on the portion of the database. For example, where a database index has historically undergone many more read operations than write operations, it may be concluded that the expected set of operations for that portion of the database storing the database index will continue to have a proportionally higher number of read operations. In some embodiments, more recent historical data is weighted more heavily than older data, so that a recent change in the way the portion of the database is being used (e.g., the primary data has started to undergo a higher proportion of reads than writes) will be appropriately taken into account in identifying an expected set of operations in the future.
In some embodiments, an analogous historical period is identified, and analytics from that period referred to, in determining the expected set of operations. In some embodiments, the time of day, day of week, day of month, or dates of the year are taken into account in identifying an expected set of operations. In one example, it may be determined that the beginning of the month is a busy time for website-based enrollments in a program, and therefore a large number of write operations may be expected. Similarly, in another example, it may be determined that a database supporting an e-commerce store performs an extraordinary number of read operations in the days following the U.S. Thanksgiving holiday, as shoppers browse for holiday purchases. These insights into past time periods may be used to predict an expected set of operations in a current corresponding time period.
In some embodiments, the expected set of operations to be determined may include more than the read and write operations. For example, it may be determined, based on a user profile, historic practice, or configuration parameters that data will be written and read in a compressed format in order to save storage space. In such embodiments, considerations relating to those operations may also be considered.
The factors considered in making the determinations above may be considered in conjunction with one another. In one embodiment, the layout of the portion of the database, such as a collection of documents, may be considered along with the historical ways in which the data in the collection is accessed. For example, the documents in a collection may have a large number of fields, only some of which are populated or accessed. (This situation may be considered analogous to a “wide” table having many columns, only few of which are populated.) In this example, where only a relative few fields are being accessed, a determination may be made that it should be expected that reading a small number of fields from many documents is more likely to occur than reading entire documents.
At step 630, a characteristic is determined of the expected set of operations to be performed on the portion of the database. The characteristic may be a count, threshold, minimum or maximum amount, ratio, percentage, or other measurement based on, derived from, or calculated from the expected set of operations. In some embodiments, the characteristic is the relative number of expected read operations as compared to write operations, which may be expressed as a read/write ratio. In some embodiments, this read/write ratio may be weighted according to the predicted speed of performing various operations on the portion of the database, given the arrangement of the database. For example, read operations on a relatively small collection, most or all of which can be stored in memory, may be performed relatively quickly. Operations performed on a larger collection may likely require more reads from disk, which are typically quite a bit slower than memory reads. The relatively “expensive” read operations in the latter case may be a characteristic considered in determining what data format should be used. For example, “expensive” read operations may be assigned a weighted value of greater than 1.0 read operations, whereas more “inexpensive” read operations (such as those from memory) may be assigned a weighted value of 1.0 read operations.
At step 640, responsive to the expected set of operations having a first characteristic, a determination is made to store the portion of the database in a first data format, and at step 650, responsive to the expected set of operations having a second characteristic, a determination is made to store the portion of the database in a second data format. Thus, depending on the characteristics of the set of operations expected for the portion of the database, the portion of the database may be configured to store the data in a selected one of a number of formats.
In one embodiment, the determination to store data in a given format is made with respect to the weighted or unweighted read/write ratio discussed above. For example, where the read/write ratio is relatively high (i.e., a proportionally higher number of read operations may be expected for the portion of the database), a data format most suited for a high volume of read operations is identified. In this example, a row-store format or column-store format may be selected. In some embodiments, the selection is made with respect to other characteristics of the data, as discussed above. For example, where multiple fields within a document are likely to be read (e.g., retrieving employee profiles from a database storing individual employee information in a document), a row-store format may be suitable, since in a row-store format the document fields are stored in contiguous memory locations. Where a single field is likely to be read from multiple documents (e.g., reading salary information for an entire company), a column-store format may be suitable, since in a column-store format all values for a particular field are stored in contiguous memory locations. As another example, where the read/write ratio is relatively low (i.e., a proportionally higher number of write operations may be expected for the portion of the database), a data format most suited for a high volume of write operations is selected. In this example, a LSM-tree format is selected.
In some embodiments, the determination to store data in a given format may be made with reference to other expected operations beyond read and write operations. For example, if it was determined in step 620 that the portion of the database is likely to be compressed in order to save storage space, the determination may be made to store the data in a format conducive to compression. For example, it is known that a collection of like types of data may be more efficiently compressed than a collection of disparate types of data, given the techniques that can be applied to homogeneous data. In such a situation, it may therefore be suitable to store the data in a column-store format, keeping like values (i.e., fields) contiguous and enjoying the benefits of compression of homogeneous data.
In optional step 660, the portion of the database is stored in the selected data format. In some embodiments, the entire portion of the database is stored in the selected data format as soon as practicable. In other words, the entire portion of the database may be stored in the selected data format at the next available opportunity. In other embodiments, the portion of the database is stored in the selected data format as write operations occur. In such embodiments, the migration to the selected format occurs gradually.
In optional step 670, at some point in time after the portion of the database is stored in the selected data format, the benefit or effect of the selection of the data format is assessed by comparing the performance of the system both before and after the selection according to various metrics. For example, the average time to perform a write operation and/or a read operation may be compared from before and after the format was selected and put into use. If the average time has gotten smaller (i.e., the database is more quickly performing operations), then the selected format may be considered an improvement over the previous format. On the other hand, if performance has not improved or has degraded, the system may determine whether the previous format should be reverted to. In some embodiments, the administrators or users of the system may be alerted to the possibility that the selected format is not an improvement, and options may be provided to select the previous format, continue to use the current format, or perform additional analysis.
Process 600 ends at step 680.
It will be appreciated that process 600 may be performed with respect to individual nodes within a replica set, selecting a suitable data format for each portion of the database stored on each node. Thus, with reference to
A process 700 of operating a database server (e.g., the shard server 500 depicted in
At step 710, process 700 begins.
At step 720, one or more data format selection options for a portion of a database may be presented to a user. The user may be an administrator of the database system, or may be any user with credentials that allow for selection of a data format for the portion of the database. In a preferred embodiment, the user interacts with the system via a user interface allowing for the selection of data formats to be used in storing a portion of the database. A screen may be displayed to the user providing the option to identify a portion of the database and choose a desired data format in which to store that portion of the database. In some embodiments, a storage engine selector may assist with the decision by providing analytics and recommendations enabling an informed decision regarding the storage format. For example, the user may be presented with an interface showing the historical read/write operation ratio for particular period of time, which may be configurable. Other analytics and metadata about the database (or the portion of the database to be stored) may also be presented, including the size and layout of the data.
At optional step 730, one or more recommendations may be presented to the user regarding data format options for the portion of the database. The recommendation may be formed based on the considerations discussed above with respect to steps 730 and 740 of process 700. For example, the type of data, amortized cost of a typical operation, the nature of the data, a historical analysis of the portion of the database and the other data (and metadata) available for that portion of the database, compression, and other considerations may be taken into account. In some embodiments, a plurality of recommendations is provided in a prioritized order determined by the system.
In some embodiments, before or concurrent with the user being provided with one or more recommendations, the user may be presented with the option to identify priorities for the database. For example, the user may be asked to place a relative importance on the speed of read operations, the speed of write operations, and the like. In some embodiments, configuration decisions made by the user may also affect the recommendations. For example, the user may be queried whether compression will be used on the portion of the database. If so, a data format suitable for compression may be recommended.
In some embodiments, the user may be provided with the option to identify multiple data formats, from which one is selected based on thresholds that the user also provides. For example, the user may be prompted to enter a threshold read/write ratio (e.g., 80%) at which a portion of the database that meets that threshold at a given time will be stored in a chosen format (e.g., row-store format). The user may be provided the option to be prompted to switch to such a data format when the threshold is reached, or to have the switch be made automatically. In some embodiments, the threshold must be met or exceeded for a certain amount of time before the switch is enacted, to avoid too-frequent format changes in the event of temporary activity.
In step 740, the user's selection of one or more data formats is received through a user interface.
In step 750, the portion of the database is stored in the selected data format. In some embodiments, the entire portion of the database is stored in the selected data format as soon as practicable. In other words, the entire portion of the database may be stored in the selected data format at the next available opportunity. In other embodiments, the portion of the database may be stored in the selected data format at a time selected by the user. For example, when selecting the data format (or the threshold for switching to the data format), the user may be prompted whether the change should go into place right away, or should be deferred for some amount of time or until some event occurs. The user may be given the option to defer the change for a certain number of minutes or hours, or may be given the option to have the change applied at a time of low database activity (for example, during the middle of the night).
In still other embodiments, the portion of the database is stored in the selected data format as write operations occur. In such embodiments, the migration to the selected format occurs gradually.
Process 700 ends at step 760.
The various processes described herein can be configured to be executed on the systems shown by way of example in
Additionally, other computer systems can be configured to perform the operations and/or functions described herein. For example, various embodiments according to the present invention may be implemented on one or more computer systems. These computer systems may be, specially configured, computers such as those based on Intel Atom, Core, or PENTIUM-type processor, IBM PowerPC, AMD Athlon or Opteron, Sun UltraSPARC, or any other type of processor. Additionally, any system may be located on a single computer or may be distributed among a plurality of computers attached by a communications network.
A special-purpose computer system can be specially configured as disclosed herein. According to one embodiment of the invention the special-purpose computer system is configured to perform any of the described operations and/or algorithms. The operations and/or algorithms described herein can also be encoded as software executing on hardware that defines a processing component, that can define portions of a special purpose computer, reside on an individual special-purpose computer, and/or reside on multiple special-purpose computers.
Computer system 800 may also include one or more input/output (I/O) devices 802-804, for example, a keyboard, mouse, trackball, microphone, touch screen, a printing device, display screen, speaker, etc. Storage 812, typically includes a computer readable and writeable nonvolatile recording medium in which computer executable instructions are stored that define a program to be executed by the processor or information stored on or in the medium to be processed by the program.
The medium can, for example, be a disk 902 or flash memory as shown in
Referring again to
The computer system may include specially-programmed, special-purpose hardware, for example, an application-specific integrated circuit (ASIC). Aspects of the invention can be implemented in software, hardware or firmware, or any combination thereof. Although computer system 800 is shown by way of example, as one type of computer system upon which various aspects of the invention can be practiced, it should be appreciated that aspects of the invention are not limited to being implemented on the computer system as shown in
It should be appreciated that the invention is not limited to executing on any particular system or group of systems. Also, it should be appreciated that the invention is not limited to any particular distributed architecture, network, or communication protocol.
Various embodiments of the invention can be programmed using an object-oriented programming language, such as Java, C++, Ada, or C# (C-Sharp). Other programming languages may also be used. Alternatively, functional, scripting, and/or logical programming languages can be used. Various aspects of the invention can be implemented in a non-programmed environment (e.g., documents created in HTML, XML or other format that, when viewed in a window of a browser program, render aspects of a graphical-user interface (GUI) or perform other functions). The system libraries of the programming languages are incorporated herein by reference. Various aspects of the invention can be implemented as programmed or non-programmed elements, or any combination thereof.
Various aspects of this invention can be implemented by one or more systems similar to system 1000 shown in
There can be other computer systems that perform functions such as hosting replicas of database data, with each server hosting database partitions implemented as a replica set, among other functions. These systems can be distributed among a communication system such as the Internet. One such distributed network, as discussed below with respect to
System 1000 may include one or more specially configured special-purpose computer systems 1004, 1006, and 1008 distributed among a network 1002 such as, for example, the Internet. Such systems may cooperate to perform functions related to hosting a partitioned database, managing database metadata, monitoring distribution of database partitions, monitoring size of partitions, splitting partitions as necessary, migrating partitions as necessary, identifying sequentially keyed collections, optimizing migration, splitting, and rebalancing for collections with sequential keying architectures.
Having thus described several aspects and embodiments of this invention, it is to be appreciated that various alterations, modifications and improvements will readily occur to those skilled in the art. Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description is by way of example only.
Use of ordinal terms such as “first,” “second,” “third,” “a,” “b,” “c,” etc., in the claims to modify or otherwise identify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term) to distinguish the claim elements.
This application is a Continuation of U.S. application Ser. No. 14/992,225, filed Jan. 11, 2016, entitled “DISTRIBUTED DATABASE SYSTEMS AND METHODS WITH PLUGGABLE STORAGE ENGINES”, which is a Non-Provisional of Provisional (35 USC 119(e)) of U.S. Application Ser. No. 62/232,979, filed Sep. 25, 2015, entitled “DISTRIBUTED DATABASE SYSTEMS AND METHODS WITH PLUGGABLE STORAGE ENGINES”, which applications are herein incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
4918593 | Huber | Apr 1990 | A |
5379419 | Heffernan et al. | Jan 1995 | A |
5416917 | Adair et al. | May 1995 | A |
5471629 | Risch | Nov 1995 | A |
5551027 | Choy et al. | Aug 1996 | A |
5598559 | Chaudhuri | Jan 1997 | A |
5710915 | McElhiney | Jan 1998 | A |
5884299 | Ramesh et al. | Mar 1999 | A |
5999179 | Kekic et al. | Dec 1999 | A |
6065017 | Barker | May 2000 | A |
6088524 | Levy et al. | Jul 2000 | A |
6112201 | Wical | Aug 2000 | A |
6115705 | Larson | Sep 2000 | A |
6212529 | Boothby et al. | Apr 2001 | B1 |
6240406 | Tannen | May 2001 | B1 |
6240514 | Inoue et al. | May 2001 | B1 |
6249866 | Brundett et al. | Jun 2001 | B1 |
6324540 | Khanna et al. | Nov 2001 | B1 |
6324654 | Wahl et al. | Nov 2001 | B1 |
6339770 | Leung et al. | Jan 2002 | B1 |
6351742 | Agarwal et al. | Feb 2002 | B1 |
6363389 | Lyle et al. | Mar 2002 | B1 |
6385201 | Iwata | May 2002 | B1 |
6385604 | Bakalash et al. | May 2002 | B1 |
6427230 | Goiffon et al. | Jul 2002 | B1 |
6438538 | Goldring | Aug 2002 | B1 |
6496843 | Getchius et al. | Dec 2002 | B1 |
6505187 | Shatdal | Jan 2003 | B1 |
6611850 | Shen | Aug 2003 | B1 |
6687846 | Adrangi et al. | Feb 2004 | B1 |
6691101 | MacNicol et al. | Feb 2004 | B2 |
6748393 | Kapoor | Jun 2004 | B1 |
6801905 | Andrei | Oct 2004 | B2 |
6823474 | Kampe et al. | Nov 2004 | B2 |
6920460 | Srinivasan et al. | Jul 2005 | B1 |
6959369 | Ashton et al. | Oct 2005 | B1 |
6973452 | Metzger | Dec 2005 | B2 |
7020649 | Cochrane et al. | Mar 2006 | B2 |
7032089 | Ranade et al. | Apr 2006 | B1 |
7082473 | Breitbart et al. | Jul 2006 | B2 |
7177866 | Holenstein et al. | Feb 2007 | B2 |
7181460 | Coss et al. | Feb 2007 | B2 |
7191299 | Kekre et al. | Mar 2007 | B1 |
7246345 | Sharma et al. | Jul 2007 | B1 |
7447807 | Merry et al. | Nov 2008 | B1 |
7467103 | Murray et al. | Dec 2008 | B1 |
7469253 | Celis et al. | Dec 2008 | B2 |
7472117 | Dettinger et al. | Dec 2008 | B2 |
7486661 | Van den Boeck et al. | Feb 2009 | B2 |
7529834 | Birrell et al. | May 2009 | B1 |
7548928 | Dean et al. | Jun 2009 | B1 |
7552356 | Waterhouse et al. | Jun 2009 | B1 |
7558481 | Jenkins et al. | Jul 2009 | B2 |
7567991 | Armangau et al. | Jul 2009 | B2 |
7617369 | Bezbaruah et al. | Nov 2009 | B1 |
7634459 | Eshet et al. | Dec 2009 | B1 |
7647329 | Fischman et al. | Jan 2010 | B1 |
7657570 | Wang et al. | Feb 2010 | B2 |
7657578 | Karr et al. | Feb 2010 | B1 |
7668801 | Koudas et al. | Feb 2010 | B1 |
7761465 | Nonaka et al. | Jul 2010 | B1 |
7957284 | Lu et al. | Jun 2011 | B2 |
7962458 | Holenstein et al. | Jun 2011 | B2 |
8005804 | Greer | Aug 2011 | B2 |
8005868 | Saborit et al. | Aug 2011 | B2 |
8037059 | Bestgen et al. | Oct 2011 | B2 |
8078825 | Oreland et al. | Dec 2011 | B2 |
8082265 | Carlson et al. | Dec 2011 | B2 |
8086597 | Balmin et al. | Dec 2011 | B2 |
8099572 | Arora et al. | Jan 2012 | B1 |
8103906 | Alibakhsh et al. | Jan 2012 | B1 |
8108443 | Thusoo | Jan 2012 | B2 |
8126848 | Wagner | Feb 2012 | B2 |
8170984 | Bakalash et al. | May 2012 | B2 |
8185505 | Blitzer et al. | May 2012 | B1 |
8260840 | Sirota et al. | Sep 2012 | B1 |
8296419 | Khanna et al. | Oct 2012 | B1 |
8305999 | Palanki et al. | Nov 2012 | B2 |
8321558 | Sirota et al. | Nov 2012 | B1 |
8352450 | Mraz et al. | Jan 2013 | B1 |
8352463 | Nayak | Jan 2013 | B2 |
8363961 | Avidan et al. | Jan 2013 | B1 |
8370857 | Kamii et al. | Feb 2013 | B2 |
8386463 | Bestgen et al. | Feb 2013 | B2 |
8392482 | McAlister et al. | Mar 2013 | B1 |
8539197 | Marshall et al. | Sep 2013 | B1 |
8572031 | Merriman et al. | Oct 2013 | B2 |
8589382 | Betawadkar-Norwood | Nov 2013 | B2 |
8589574 | Cormie et al. | Nov 2013 | B1 |
8615507 | Varadarajulu et al. | Dec 2013 | B2 |
8712044 | MacMillan et al. | Apr 2014 | B2 |
8712993 | Ordonez | Apr 2014 | B1 |
8751533 | Dhavale et al. | Jun 2014 | B1 |
8762031 | Wada | Jun 2014 | B2 |
8775070 | Bhatia | Jul 2014 | B1 |
8843441 | Rath et al. | Sep 2014 | B1 |
8869256 | Sample | Oct 2014 | B2 |
8996463 | Merriman et al. | Mar 2015 | B2 |
9015431 | Resch et al. | Apr 2015 | B2 |
9069827 | Rath et al. | Jun 2015 | B1 |
9116862 | Rath et al. | Aug 2015 | B1 |
9141814 | Murray | Sep 2015 | B1 |
9183254 | Cole et al. | Nov 2015 | B1 |
9262462 | Merriman et al. | Feb 2016 | B2 |
9268639 | Leggette et al. | Feb 2016 | B2 |
9274902 | Morley et al. | Mar 2016 | B1 |
9313604 | Holcombe | Apr 2016 | B1 |
9317576 | Merriman et al. | Apr 2016 | B2 |
9350633 | Cudak et al. | May 2016 | B2 |
9350681 | Kitagawa et al. | May 2016 | B1 |
9442995 | Pareek | Sep 2016 | B2 |
9460008 | Leshinsky et al. | Oct 2016 | B1 |
9495427 | Abadi et al. | Nov 2016 | B2 |
9569481 | Chandra et al. | Feb 2017 | B1 |
9628404 | Goffinet | Apr 2017 | B1 |
9660666 | Ciarlini et al. | May 2017 | B1 |
9715433 | Mu et al. | Jul 2017 | B2 |
9740762 | Horowitz et al. | Aug 2017 | B2 |
9792322 | Merriman et al. | Oct 2017 | B2 |
9800685 | Neerincx et al. | Oct 2017 | B2 |
9805108 | Merriman et al. | Oct 2017 | B2 |
9881034 | Horowitz et al. | Jan 2018 | B2 |
9959308 | Carman et al. | May 2018 | B1 |
10031631 | Kanna | Jul 2018 | B2 |
10031931 | Horowitz et al. | Jul 2018 | B2 |
10031956 | Merriman et al. | Jul 2018 | B2 |
10262050 | Bostic et al. | Apr 2019 | B2 |
10303570 | Nakajima | May 2019 | B2 |
10346430 | Horowitz et al. | Jul 2019 | B2 |
10346434 | Morkel et al. | Jul 2019 | B1 |
10366100 | Horowitz et al. | Jul 2019 | B2 |
10372926 | Leshinsky et al. | Aug 2019 | B1 |
10394822 | Stearn | Aug 2019 | B2 |
10423626 | Stearn et al. | Sep 2019 | B2 |
10430433 | Stearn et al. | Oct 2019 | B2 |
10467245 | Sirer | Nov 2019 | B2 |
10474645 | Freedman et al. | Nov 2019 | B2 |
10489357 | Horowitz et al. | Nov 2019 | B2 |
10496669 | Merriman et al. | Dec 2019 | B2 |
10614098 | Horowitz et al. | Apr 2020 | B2 |
10621050 | Horowitz et al. | Apr 2020 | B2 |
10621200 | Merriman et al. | Apr 2020 | B2 |
10671496 | Horowitz et al. | Jun 2020 | B2 |
10673623 | Horowitz et al. | Jun 2020 | B2 |
10698775 | Horowitz et al. | Jun 2020 | B2 |
10713275 | Merriman et al. | Jul 2020 | B2 |
10713280 | Horowitz et al. | Jul 2020 | B2 |
10740353 | Horowitz et al. | Aug 2020 | B2 |
10740355 | Horowitz et al. | Aug 2020 | B2 |
10776220 | Horowitz et al. | Sep 2020 | B2 |
10846305 | Merriman et al. | Nov 2020 | B2 |
10846411 | Horowitz et al. | Nov 2020 | B2 |
10866868 | Horowitz | Dec 2020 | B2 |
10872095 | Horowitz et al. | Dec 2020 | B2 |
11012806 | Tan | May 2021 | B2 |
20010021929 | Lin et al. | Sep 2001 | A1 |
20020029207 | Bakalash et al. | Mar 2002 | A1 |
20020065675 | Grainger et al. | May 2002 | A1 |
20020065676 | Grainger et al. | May 2002 | A1 |
20020065677 | Grainger et al. | May 2002 | A1 |
20020143901 | Lupo et al. | Oct 2002 | A1 |
20020147842 | Breitbart et al. | Oct 2002 | A1 |
20020184239 | Mosher, Jr. et al. | Dec 2002 | A1 |
20020198872 | MacNicol et al. | Dec 2002 | A1 |
20030046307 | Rivette et al. | Mar 2003 | A1 |
20030212668 | Hinshaw et al. | Apr 2003 | A1 |
20030084073 | Hotti et al. | May 2003 | A1 |
20030088659 | Susarla et al. | May 2003 | A1 |
20030182427 | Halpern | Sep 2003 | A1 |
20030187864 | McGoveran | Oct 2003 | A1 |
20040078569 | Hotti | Apr 2004 | A1 |
20040133591 | Holenstein et al. | Jul 2004 | A1 |
20040168084 | Owen et al. | Aug 2004 | A1 |
20040186817 | Thames et al. | Sep 2004 | A1 |
20040186826 | Choi et al. | Sep 2004 | A1 |
20040205048 | Pizzo et al. | Oct 2004 | A1 |
20040220937 | Bickford et al. | Nov 2004 | A1 |
20040236743 | Blaicher et al. | Nov 2004 | A1 |
20040254919 | Giuseppini | Dec 2004 | A1 |
20050027796 | San Andres et al. | Feb 2005 | A1 |
20050033756 | Kottomtharayil | Feb 2005 | A1 |
20050038833 | Colrain et al. | Feb 2005 | A1 |
20050192921 | Chaudhuri et al. | Sep 2005 | A1 |
20050234841 | Miao et al. | Oct 2005 | A1 |
20050283457 | Sonkin | Dec 2005 | A1 |
20060004746 | Angus | Jan 2006 | A1 |
20060020586 | Prompt et al. | Jan 2006 | A1 |
20060085541 | Cuomo et al. | Apr 2006 | A1 |
20060090095 | Massa et al. | Apr 2006 | A1 |
20060168154 | Zhang et al. | Jul 2006 | A1 |
20060209782 | Miller et al. | Sep 2006 | A1 |
20060218123 | Chowdhuri et al. | Sep 2006 | A1 |
20060224603 | Correll, Jr. | Oct 2006 | A1 |
20060235905 | Kapur | Oct 2006 | A1 |
20060259160 | Hood | Nov 2006 | A1 |
20060287998 | Folting et al. | Dec 2006 | A1 |
20060288232 | Ho et al. | Dec 2006 | A1 |
20060294129 | Stanfill et al. | Dec 2006 | A1 |
20070050436 | Chen et al. | Mar 2007 | A1 |
20070061487 | Moore | Mar 2007 | A1 |
20070094237 | Mitchell et al. | Apr 2007 | A1 |
20070124317 | Dettinger | May 2007 | A1 |
20070203944 | Batra et al. | Aug 2007 | A1 |
20070226640 | Holbrook et al. | Sep 2007 | A1 |
20070233746 | Garbow et al. | Oct 2007 | A1 |
20070240129 | Kretzschmar et al. | Oct 2007 | A1 |
20080002741 | Maheshwari et al. | Jan 2008 | A1 |
20080005475 | Lubbers et al. | Jan 2008 | A1 |
20080016021 | Gulbeden et al. | Jan 2008 | A1 |
20080071755 | Barsness et al. | Mar 2008 | A1 |
20080098041 | Chidambaran et al. | Apr 2008 | A1 |
20080140971 | Dankel et al. | Jun 2008 | A1 |
20080162590 | Kundu et al. | Jul 2008 | A1 |
20080288646 | Hasha et al. | Nov 2008 | A1 |
20090030986 | Bates | Jan 2009 | A1 |
20090055350 | Branish et al. | Feb 2009 | A1 |
20090077010 | Muras et al. | Mar 2009 | A1 |
20090094318 | Gladwin et al. | Apr 2009 | A1 |
20090222474 | Alpern et al. | Sep 2009 | A1 |
20090240744 | Thomson et al. | Sep 2009 | A1 |
20090254572 | Redlich | Oct 2009 | A1 |
20090271412 | Lacapra et al. | Oct 2009 | A1 |
20100011026 | Saha et al. | Jan 2010 | A1 |
20100030793 | Cooper et al. | Feb 2010 | A1 |
20100030800 | Brodfuehrer et al. | Feb 2010 | A1 |
20100049717 | Ryan et al. | Feb 2010 | A1 |
20100057764 | Williamson | Mar 2010 | A1 |
20100058010 | Augenstein et al. | Mar 2010 | A1 |
20100094851 | Bent et al. | Apr 2010 | A1 |
20100106934 | Calder et al. | Apr 2010 | A1 |
20100161492 | Harvey et al. | Jun 2010 | A1 |
20100198791 | Wu et al. | Aug 2010 | A1 |
20100205028 | Johnson et al. | Aug 2010 | A1 |
20100223078 | Willis et al. | Sep 2010 | A1 |
20100235606 | Oreland et al. | Sep 2010 | A1 |
20100250497 | Redlich | Sep 2010 | A1 |
20100250930 | Csaszar et al. | Sep 2010 | A1 |
20100257142 | Murphy et al. | Oct 2010 | A1 |
20100333111 | Kothamasu | Dec 2010 | A1 |
20100333116 | Prahlad et al. | Dec 2010 | A1 |
20110022642 | deMilo et al. | Jan 2011 | A1 |
20110032571 | Kitada | Feb 2011 | A1 |
20110125704 | Mordinova et al. | May 2011 | A1 |
20110125766 | Carozza | May 2011 | A1 |
20110125894 | Anderson et al. | May 2011 | A1 |
20110138148 | Friedman et al. | Jun 2011 | A1 |
20110202792 | Atzmony | Aug 2011 | A1 |
20110225122 | Denuit et al. | Sep 2011 | A1 |
20110225123 | D'Souza et al. | Sep 2011 | A1 |
20110231447 | Starkey | Sep 2011 | A1 |
20110246717 | Kobayashi et al. | Oct 2011 | A1 |
20110258225 | Taylor | Oct 2011 | A1 |
20110295686 | Martin-Cocher | Dec 2011 | A1 |
20110307338 | Carlson | Dec 2011 | A1 |
20120054155 | Darcy | Mar 2012 | A1 |
20120076058 | Padmanabh et al. | Mar 2012 | A1 |
20120078848 | Jennas et al. | Mar 2012 | A1 |
20120078896 | Nixon et al. | Mar 2012 | A1 |
20120079224 | Clayton et al. | Mar 2012 | A1 |
20120084414 | Brock et al. | Apr 2012 | A1 |
20120084789 | Iorio | Apr 2012 | A1 |
20120109892 | Novik et al. | May 2012 | A1 |
20120109935 | Meijer | May 2012 | A1 |
20120130973 | Tamm et al. | May 2012 | A1 |
20120130988 | Nica et al. | May 2012 | A1 |
20120131278 | Chang et al. | May 2012 | A1 |
20120136835 | Kosuru et al. | May 2012 | A1 |
20120138671 | Gaede et al. | Jun 2012 | A1 |
20120158655 | Dove et al. | Jun 2012 | A1 |
20120158949 | Lee | Jun 2012 | A1 |
20120159097 | Jennas, II et al. | Jun 2012 | A1 |
20120166390 | Merriman et al. | Jun 2012 | A1 |
20120166517 | Lee et al. | Jun 2012 | A1 |
20120179833 | Kenrick et al. | Jul 2012 | A1 |
20120198200 | Li et al. | Aug 2012 | A1 |
20120215740 | Vaillant | Aug 2012 | A1 |
20120215763 | Hughes et al. | Aug 2012 | A1 |
20120221540 | Rose et al. | Aug 2012 | A1 |
20120254175 | Horowitz et al. | Oct 2012 | A1 |
20120274664 | Fagnou | Nov 2012 | A1 |
20120320914 | Thyni et al. | Dec 2012 | A1 |
20130019296 | Brandenburg | Jan 2013 | A1 |
20130151477 | Tsaur et al. | Jun 2013 | A1 |
20130151558 | Chercoles S Nchez | Jun 2013 | A1 |
20130179450 | Chitiveli | Jul 2013 | A1 |
20130290249 | Merriman et al. | Oct 2013 | A1 |
20130290471 | Venkatesh | Oct 2013 | A1 |
20130332484 | Gajic | Dec 2013 | A1 |
20130339379 | Ferrari et al. | Dec 2013 | A1 |
20130346366 | Ananthanarayanan et al. | Dec 2013 | A1 |
20140013334 | Bisdikian et al. | Jan 2014 | A1 |
20140032525 | Merriman et al. | Jan 2014 | A1 |
20140032579 | Merriman et al. | Jan 2014 | A1 |
20140032628 | Cudak et al. | Jan 2014 | A1 |
20140074790 | Berman et al. | Mar 2014 | A1 |
20140101100 | Hu et al. | Apr 2014 | A1 |
20140164831 | Merriman et al. | Jun 2014 | A1 |
20140180723 | Cote et al. | Jun 2014 | A1 |
20140201267 | Yang | Jul 2014 | A1 |
20140258343 | Nikula | Sep 2014 | A1 |
20140279929 | Gupta et al. | Sep 2014 | A1 |
20140280380 | Jagtap et al. | Sep 2014 | A1 |
20150012797 | Leggette et al. | Jan 2015 | A1 |
20150016300 | Devireddy et al. | Jan 2015 | A1 |
20150074041 | Bhattacharjee et al. | Mar 2015 | A1 |
20150081766 | Curtis et al. | Mar 2015 | A1 |
20150242531 | Rodniansky | Aug 2015 | A1 |
20150278295 | Merriman et al. | Oct 2015 | A1 |
20150301901 | Rath et al. | Oct 2015 | A1 |
20150331755 | Morgan | Nov 2015 | A1 |
20150341212 | Hsiao et al. | Nov 2015 | A1 |
20150378786 | Suparna et al. | Dec 2015 | A1 |
20150378825 | Resch | Dec 2015 | A1 |
20160005423 | Neppalli et al. | Jan 2016 | A1 |
20160048345 | Vijayrao et al. | Feb 2016 | A1 |
20160110284 | Athalye et al. | Apr 2016 | A1 |
20160110414 | Park et al. | Apr 2016 | A1 |
20160162354 | Singhai et al. | Jun 2016 | A1 |
20160162374 | Mutha et al. | Jun 2016 | A1 |
20160188377 | Thimmappa et al. | Jun 2016 | A1 |
20160198044 | Gruchala et al. | Jul 2016 | A1 |
20160203202 | Merriman et al. | Jul 2016 | A1 |
20160246861 | Merriman et al. | Aug 2016 | A1 |
20160253109 | Litke | Sep 2016 | A1 |
20160306709 | Shaull | Oct 2016 | A1 |
20160323378 | Coskun et al. | Nov 2016 | A1 |
20160364440 | Lee et al. | Dec 2016 | A1 |
20170032007 | Merriman | Feb 2017 | A1 |
20170032010 | Merriman | Feb 2017 | A1 |
20170091327 | Bostic et al. | Mar 2017 | A1 |
20170109398 | Stearn | Apr 2017 | A1 |
20170109399 | Stearn et al. | Apr 2017 | A1 |
20170109421 | Stearn et al. | Apr 2017 | A1 |
20170169059 | Horowitz et al. | Jun 2017 | A1 |
20170262516 | Horowitz et al. | Sep 2017 | A1 |
20170262517 | Horowitz et al. | Sep 2017 | A1 |
20170262519 | Horowitz et al. | Sep 2017 | A1 |
20170262638 | Horowitz et al. | Sep 2017 | A1 |
20170264432 | Horowitz et al. | Sep 2017 | A1 |
20170270176 | Horowitz et al. | Sep 2017 | A1 |
20170286510 | Horowitz et al. | Oct 2017 | A1 |
20170286516 | Horowitz et al. | Oct 2017 | A1 |
20170286517 | Horowitz et al. | Oct 2017 | A1 |
20170286518 | Horowitz et al. | Oct 2017 | A1 |
20170322954 | Horowitz et al. | Nov 2017 | A1 |
20170322996 | Horowitz et al. | Nov 2017 | A1 |
20170344290 | Horowitz et al. | Nov 2017 | A1 |
20170344441 | Horowitz et al. | Nov 2017 | A1 |
20170344618 | Horowitz et al. | Nov 2017 | A1 |
20170371750 | Horowitz et al. | Dec 2017 | A1 |
20170371968 | Horowitz et al. | Dec 2017 | A1 |
20180004801 | Burchall et al. | Jan 2018 | A1 |
20180004804 | Merriman et al. | Jan 2018 | A1 |
20180095852 | Keremane et al. | Apr 2018 | A1 |
20180096045 | Merriman et al. | Apr 2018 | A1 |
20180165338 | Kumar et al. | Jun 2018 | A1 |
20180173745 | Balasubramanian et al. | Jun 2018 | A1 |
20180300209 | Rahut | Oct 2018 | A1 |
20180300381 | Horowitz et al. | Oct 2018 | A1 |
20180300385 | Merriman et al. | Oct 2018 | A1 |
20180314750 | Merriman et al. | Nov 2018 | A1 |
20180343131 | George et al. | Nov 2018 | A1 |
20180365114 | Horowitz | Dec 2018 | A1 |
20190102410 | Horowitz et al. | Apr 2019 | A1 |
20200097486 | Horowitz et al. | Mar 2020 | A1 |
20200160297 | Munk | May 2020 | A1 |
20200285549 | Horowitz et al. | Sep 2020 | A1 |
20200295925 | Horowitz et al. | Sep 2020 | A1 |
20200327021 | Horowitz et al. | Oct 2020 | A1 |
20200341867 | Horowitz et al. | Oct 2020 | A1 |
Entry |
---|
U.S. Appl. No. 16/525,447, filed Jul. 29, 2019, Horowitz et al. |
U.S. Appl. No. 16/456,685, filed Jun. 28, 2019, Horowitz et al. |
Chang et al., Bigtable: a distributed storage system for structured data. OSDI'06: Seventh Symposium on Operating System Design and Implementation. Nov. 2006. |
Cooper et al., PNUTS: Yahoo!'s hosted data serving platform. VLDB Endowment. Aug. 2008. |
Decandia et al., Dynamo: Amazon's highly available key-value store. SOSP 2007. Oct. 2004. |
Van Renesse et al., Chain replication for supporting high throughput and availability. OSDI. 2004: 91-104. |
Wilkins et al., Migrate DB2 applications to a partitioned database. developerWorks, IBM. Apr. 24, 2008, 33 pages. |
[No. Author Listed], Automated Administration Tasks (SQL Server Agent). https://docs.microsoft.com/en-us/sql/ssms/agent/automated-adminsitration-tasks-sql-server-agent. 2 pages, [downloaded Mar. 4, 2017]. |
Nelson et al., Automate MongoDB with MMS. PowerPoint Presentation. Published Jul. 24, 2014. 27 slides, http://www.slideshare.net/mongodb/mms-automation-mongo-db-world. |
Poder, Oracle living books. 2009. <http://tech.e2sn.com/oracle/sql/oracle-execution-plan-operation-reference >. |
Stirman, Run MongoDB with Confidence using MMS. PowerPoint Presentation. Published Oct. 6, 2014. 34 slides, http://www.slideshare.net/mongodb/mongo-db-boston-run-mongodb-with-mms-20141001. |
Walsh et al., Xproc: An XML Pipeline Language. May 11, 2011. <https://www.w3.org/TR/xproc/>. |
Wikipedia, Dataflow programming. Oct. 2011. <http://en.wikipedia.org/wiki/Dataflow_programming>. |
Wikipedia, Pipeline (Unix). Sep. 2011. <http://en.wikipedia.org/wiki/Pipeline (Unix)>. |
Ongaro et al., In Search of an Understandable Consensus Algorithm. Proceedings of USENIX ATC '14: 2014 USENIX Annual Technical Conference. Philadelphia, PA. Jun. 19-20, 2014; pp. 305-320. |
U.S. Appl. No. 16/890,948, filed Jun. 2, 2020, Merriman et al. |
U.S. Appl. No. 16/887,092, filed May 29, 2020, Horowitz et al. |
U.S. Appl. No. 17/083,238, filed Oct. 28, 2020, Horowitz et al. |
U.S. Appl. No. 16/883,653, filed May 26, 2020, Horowitz et al. |
U.S. Appl. No. 16/912,963, filed Jun. 26, 2020, Horowitz et al. |
U.S. Appl. No. 16/846,916, filed Apr. 13, 2020, Horowitz et al. |
U.S. Appl. No. 17/018,475, filed Sep. 11, 2020, Horowitz et al. |
Number | Date | Country | |
---|---|---|---|
20190303382 A1 | Oct 2019 | US |
Number | Date | Country | |
---|---|---|---|
62232979 | Sep 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14992225 | Jan 2016 | US |
Child | 16294227 | US |