System and method for implementing a scalable data storage service
First Claim
1. A system, comprising:
- a plurality of computing nodes, each comprising at least one processor and memory, that collectively implement a data storage service that provides a network-based interface through which service requests are received, wherein the data storage service comprises;
a plurality of storage nodes that collectively implement a non-relational data store;
wherein, in response to receipt of a service request to create a table on behalf of a storage service client, and wherein the service request specifies a table name and a primary key by which to partition and index items stored in the table, the data storage service is configured to;
initiate performance of an asynchronous table creation workflow at a workflow component in order to create a scalable table in the non-relational data store, wherein the scalable table is configured to store a plurality of items each of which comprises a value for the primary key, and wherein the scalable table does not have a pre-determined size limit; and
subsequent to detection of the scalable table having been created, the data storage service is configured to programmatically cause the scalable table to be sized or partitioned in response to detection of an anomaly in the system or in response to receipt of one or more service requests to store, retrieve, modify, or delete items in the scalable table.
0 Assignments
0 Petitions
Accused Products
Abstract
A system that implements a scalable data storage service may maintain tables in a non-relational data store on behalf of clients. The system may provide a Web services interface through which service requests are received, and an API usable to request that a table be created, deleted, or described; that an item be stored, retrieved, deleted, or its attributes modified; or that a table be queried (or scanned) with filtered items and/or their attributes returned. An asynchronous workflow may be invoked to create or delete a table. Items stored in tables may be partitioned and indexed using a simple or composite primary key. The system may not impose pre-defined limits on table size, and may employ a flexible schema. The service may provide a best-effort or committed throughput model. The system may automatically scale and/or re-partition tables in response to detecting workload changes, node failures, or other conditions or anomalies.
-
Citations
18 Claims
-
1. A system, comprising:
-
a plurality of computing nodes, each comprising at least one processor and memory, that collectively implement a data storage service that provides a network-based interface through which service requests are received, wherein the data storage service comprises; a plurality of storage nodes that collectively implement a non-relational data store; wherein, in response to receipt of a service request to create a table on behalf of a storage service client, and wherein the service request specifies a table name and a primary key by which to partition and index items stored in the table, the data storage service is configured to; initiate performance of an asynchronous table creation workflow at a workflow component in order to create a scalable table in the non-relational data store, wherein the scalable table is configured to store a plurality of items each of which comprises a value for the primary key, and wherein the scalable table does not have a pre-determined size limit; and subsequent to detection of the scalable table having been created, the data storage service is configured to programmatically cause the scalable table to be sized or partitioned in response to detection of an anomaly in the system or in response to receipt of one or more service requests to store, retrieve, modify, or delete items in the scalable table. - View Dependent Claims (2, 3, 4, 5, 6)
-
-
7. A method, comprising:
performing by one or more computers; receiving a request to create a table in a non-relational data store, wherein the request specifies an identifier of the table and a primary key by which to index items stored in the table; and in response to said receiving; initiating performance of an asynchronous table creation workflow to create a scalable table in the non-relational data store, wherein the scalable table is configured to store a plurality of items each of which comprises a value for the primary key, and wherein the scalable table does not have a pre-determined size limit; detecting that the scalable table is successfully created upon completion of the asynchronous table creation workflow; and subsequent to said detecting that the scalable table is successfully created, programmatically causing at least one of sizing or partitioning the scalable table in response to detection of an anomaly in the system or in response to receipt of one or more service requests to store, retrieve, modify, or delete items in the scalable table. - View Dependent Claims (8, 9, 10, 11, 12, 13)
-
14. A non-transitory, computer-readable storage medium storing program instructions that when executed on one or more computers cause the one or more computers to perform:
-
receiving a service request to create a table on behalf of a storage service client, wherein the service request specifies an identifier of the table and a primary key by which to index items stored in the table; and in response to said receiving; initiating performance of an asynchronous table creation workflow to create a scalable table in a non-relational data store, wherein the scalable table is configured to store a plurality of items each of which comprises a value for the primary key, and wherein the scalable table does not have a pre-determined size limit; detecting that the scalable table is successfully created upon completion of the asynchronous table creation workflow; and subsequent to said detecting that the scalable table is successfully created, programmatically causing at least one of sizing or partitioning the scalable table in response to detection of an anomaly in the system or in response to receipt of one or more service requests to store, retrieve, modify, or delete items in the scalable table. - View Dependent Claims (15, 16, 17, 18)
-
Specification