Shared (distributed) logs enable multiple clients to access and modify data in a scalable yet consistent manner. However, programmers need to access data in an abstraction familiar to them. Commonly, shared log implementations provide a map abstraction which gives programmers a key-value like interface to access data. Programmers, however, often need to make queries against multiple indexes. Shared logging does not lend itself to indexing its data that efficiently supports individualized indexed searching.
With respect to the discussion to follow and in particular to the drawings, it is stressed that the particulars shown represent examples for purposes of illustrative discussion, and are presented in the cause of providing a description of principles and conceptual aspects of the present disclosure. In this regard, no attempt is made to show implementation details beyond what is needed for a fundamental understanding of the present disclosure. The discussion to follow, in conjunction with the drawings, makes apparent to those of skill in the art how embodiments in accordance with the present disclosure may be practiced. Similar or same reference numbers may be used to identify or otherwise refer to similar or same elements in the various drawings and supporting descriptions. In the accompanying drawings:
The present disclosure is directed to distributed transactional systems in which the transactions can be stored in a shared log. The shared log system can provide users with a map abstraction that gives users a key-value like interface to access data, referred to herein as a main map. The system allows users to further define additional secondary indices on the main map to support their data access needs. Users can choose to represent and project their secondary indexes however they would like. The secondary indices can be stored locally in each client's respective (main) memory. Moreover, each user can define secondary indices that are specific to their data access needs, thus avoiding the system from having to create, maintain, and otherwise support multiple indices. Since all secondary indexes are in the memory of the client machine, secondary index lookup becomes an efficient local requests. By shifting the index tables into each user's system, performance of the shared log system can be significantly improved in terms of memory (each client maintains indices its own memory) and processing load (each client machine directly accesses their own indices).
In the following description, for purposes of explanation, numerous examples and specific details are set forth in order to provide a thorough understanding of embodiments of the present disclosure. Particular embodiments as expressed in the claims may include some or all of the features in these examples, alone or in combination with other features described below, and may further include modifications and equivalents of the features and concepts described herein.
The “data state” of an object 112 at a given point in time refers to the value or values of the object at that time, namely the state of the data that comprises the object 112. For example, if the object 112 is a numerical object, then at time t1 its data state might be the value 1.4142, and at another time t2 its data state might be the value 3.14159, and so on. Likewise, if the object 112 is a textual object its data state can be a particular sequence of text at one time, and a different sequence of text at another time.
In shared log systems, such as depicted in
In accordance with the present disclosure, the shared log system 100 can include a sequencer module 104 and a log manager module 106. To append a transaction to the shared log 102, the sequencer module 104 can provide the client 12 with the next free offset in the shared log 102. The client 12 can complete the append operation by directly issuing write request (e.g., put operation) to the log manager module 106. The log manager module 106 provides buffering of data associated with transactions to be committed to the shared log 102. These aspects of the present disclosure are discussed in more detail below.
In some embodiments, objects 112 can comprise structured data. Merely to illustrate this point, consider the database table 200 of a library database shown in
In some embodiments, where an object comprises multiple separate object members, it may be desirable to allow two or more transactions to concurrently access different object members within the same object without conflict. Referring to the database table 200 in
Computing system 302 can include any single or multi-processor computing device or system capable of executing computer-readable instructions. Examples of computing system 302 include, for example, workstations, laptops, client-side terminals, servers, distributed computing systems, handheld devices, or any other computing system or device. In a basic configuration, computing system 302 can include at least one processing unit 312 and a system (main) memory 314.
Processing unit 312 can comprise any type or form of processing unit capable of processing data or interpreting and executing instructions. The processing unit 312 can be a single processor configuration in some embodiments, and in other embodiments can be a multi-processor architecture comprising one or more computer processors. In some embodiments, processing unit 312 can receive instructions from program and data modules 330. These instructions can cause processing unit 312 to perform operations in accordance with the present disclosure.
System memory 314 (sometimes referred to as main memory) can be any type or form of volatile or non-volatile storage device or medium capable of storing data and/or other computer-readable instructions. Examples of system memory 314 include, for example, random access memory (RAM), read only memory (ROM), flash memory, or any other suitable memory device. In some embodiments computing system 302 can include both a volatile memory unit (such as, for example, system memory 314) and a non-volatile storage device (e.g., data storage 316, 346).
In some embodiments, computing system 302 can also include one or more components or elements in addition to processing unit 312 and system memory 314. For example, as illustrated in
Internal data storage 316 can comprise non-transitory computer-readable storage media to provide nonvolatile storage of data, data structures, computer-executable instructions, and so forth to operate computing system 302 in accordance with the present disclosure. For instance, the internal data storage 316 can store various program and data modules 330, including for example, operating system 332, one or more application programs 334, program data 336, and other program/system modules 338. In some embodiments, for example, the internal data storage 316 can store one or more of the sequencer module 104, and the log manager module 106 shown in
Communication interface 320 can include any type or form of communication device or adapter capable of facilitating communication between computing system 302 and one or more additional devices. For example, in some embodiments communication interface 320 can facilitate communication between computing system 302 and a private or public network including additional computing systems. Examples of communication interface 320 include, for example, a wired network interface (such as a network interface card), a wireless network interface (such as a wireless network interface card), a modem, and any other suitable interface.
In some embodiments, communication interface 320 can also represent a host adapter configured to facilitate communication between computing system 302 and one or more additional network or storage devices via an external bus or communications channel. Examples of host adapters include, for example, SCSI host adapters, USB host adapters, IEEE 1394 host adapters, SATA and eSATA host adapters, ATA and PATA host adapters, Fibre Channel interface adapters, Ethernet adapters, or the like.
Computing system 302 can also include at least one output device 342 (e.g., a display) coupled to system bus 324 via I/O interface 322. The output device 342 can include any type or form of device capable of visual and/or audio presentation of information received from I/O interface 322.
Computing system 302 can also include at least one input device 344 coupled to system bus 324 via I/O interface 322. Input device 344 can include any type or form of input device capable of providing input, either computer or human generated, to computing system 302. Examples of input device 344 include, for example, a keyboard, a pointing device, a speech recognition device, or any other input device.
Computing system 302 can also include external data storage 346 coupled to system bus 324. In some embodiments, external data storage 346 can provide a storage cluster (e.g., 40,
Each log entry 402 can be identified by a log index (offset) 404 that represents its ordinal position in the shared log 102. Since log entries 402 are sequentially appended, the log index 404 can represent the “time” of a log entry 402 relative to other log entries in the shared log 102. For example, a log entry 402 having a log index of n occurs earlier in time than a log entry having a log index of n+1, and later in time than a log entry having a log index of n−1. The log index 404 can be referred to variously as an offset, an address, sequence number, version number, timestamp, time reference, and so on. The remainder of the present disclosure can use these various terms interchangeably.
The sequencer module 104 can include a data objects table 604 that stores information relating to each object member of each object 112 in the shared log system 100. As used herein, the term “data object” will refer to a particular object member of a particular object; although in some embodiments where object 112 does not comprise structured data, the term “data object” can refer to the entire object 112 such as disclosed in commonly owned U.S. application Ser. No. 15/652,981.
The data objects table 604 include information for each data object that can be collectively referred to as state information, metadata, and the like for that data object. The data objects table 604, for example, can include a column of data object identifiers 604a that identify the data objects in the shared log system 100. In some embodiments, for example, a data object identifier 604a can be formed by computing a hash value using a name (e.g., a text string) of the object and a name of the object member in that object. The computed hash values can be used to as an index to the data objects table 604.
The data objects table 604 can include a column of last-modified times that stores a last-modified time 604b for each data object. The last-modified time of a data object is a time reference (e.g., using the latest time counter 602) of when the data object was last updated/modified. In some embodiments, the last-modified time can be the log index 404 of the log entry 402 that contains the transaction for the data object. Merely to illustrate this point,
In some embodiments, the data objects table 604 can include entries for the object s themselves. In some embodiments, for example, the last-modified time field 604b for the entire object can represent the time that any member of that object was last modified.
The discussion will now turn to a description of various operational flows in the shared log system 100 for processing a transaction in accordance with the present disclosure, beginning with processing in a client. A basic flow in the shared log system 100 can begin with a client writing a transaction to the shared log 102. The client can obtain from the sequencer module 104 an offset into the shared log 102. The offset (e.g., log index 404) identifies a log entry 402 in the shared log into which the transaction can be stored. In accordance with the present disclosure, the sequencer module 104 can verify the correctness of the transaction before issuing an offset. Refer now to
At operation 702, a client 12a can perform a series of operations and/or computations on one or more data objects in the shared log system 100 to produce data for a transaction (transaction result). The operations and/or computations that comprise the transaction can include a set of data objects that serve as the source of data for the transaction (call these the “source data objects”). The transaction can include a set of data objects that are to be modified with the results of the operations and/or computations (call these the “target data objects”).
The source data objects can come from the client's local copy (e.g., virtual objects 14 stored in the client's memory) of the data, rather than from the shared log 102. Maintaining a local copy of the source data objects can reduce the processing overhead that can be incurred when having to access the shared log 102 for the data. Maintaining a local copy of the source data objects can become outdated if other client, however, incurs the risk that the source data objects are outdated due to other clients making updates to those data objects.
At operation 704, when the client 12a has completed its computations and is ready to submit a transaction to the shared log 102, the client 12a can communicate with the sequencer module 104 to obtain the log index 404 of the next free log entry in the shared log 102. In accordance with the present disclosure, the sequencer module 104 can verify the correctness of that transaction as a pre-condition of issuing the log index 404. Recall from
In accordance with the present disclosure, the information load in the verify request that is provided to the sequencer module 104 can be kept to a minimum. In other words, the verify request can contain the minimum amount of information that the sequencer module 104 needs to do its job. For example, parameters for the verify request can comprise only identifiers of the target data objects and identifiers of the source data objects. In some embodiments, for example, the client 12a can compute hash values (e.g., 8-byte values) as identifiers of the target and source data objects. For instance hash values can be computed using the text string of the name of the object and of the name of the member in that object. An 8-byte hash value of a data object can be much more compact than a lengthy textual identifier of the data object.
Since verification in accordance with the present disclosure does not require the actual data associated with the source and target data objects, the verify request can omit such data. Likewise, the verify request can omit the operations and/or computations used to compute the data for the target data objects, further reducing the overhead in communicating with the sequencer module 104. These can be important considerations because all clients 12 in the system 10 go through the sequencer module 104 to verify the correctness of their respective transactions, and so the application programming interface (API) to the sequencer module 104 should be kept as “lightweight” as possible by omitting any extraneous information in the verify request API to minimize communication overhead with the sequencer module 104.
For illustrative purposes only, an example of a verify request can include the following parameters:
In accordance with some embodiments, the verify request can include only a single snapshot time (in keeping with the goal of achieving a lightweight interface to the sequencer module 104), despite that the read set can comprise several data objects. In some embodiments, the snapshot time can be the time reference of the source data object that was most recently updated. Recall that each client maintains its own virtual copy of data objects. Accordingly, each client will maintain its own time references for when those data objects were most recently updated. Using the example above, for instance, suppose the virtual objects 14 in client 12a includes the following state information for the read set:
At operation 706, the client 12a can receive a response to the verify request indicating whether the transaction can be committed (COMMIT) or should be aborted (FAIL). For example, in response to the client 12a receiving a COMMIT from the sequencer module 104, processing in the client 12a can proceed to operation 708 to commit the transaction. On the other hand, in response to the client 12a receiving a negative response (e.g., FAIL), the client 12a can proceed along processing paths I, II, III explained below.
At operation 708, the client 12a can respond to a COMMIT from the sequencer module 104. A COMMIT response indicates that the data states of the source data objects as stored in the client 12a matches the sequencer module's data states of the same source data objects. Accordingly, the computation can be deemed to be correct with respect to those source data objects. In addition to receiving a COMMIT from the sequencer module 104, the client 12a can receive the value of the latest time counter 602 from the sequencer module 104, which identifies the log index 404 of the next free log entry 402 in the shared log 102.
In response to receiving a COMMIT from the sequencer module 104, the client 12a can commit the transaction. In some embodiments, for example, the client 12a can submit a write transaction to the log manager module 106 to update the target data objects. The write transaction can include the value of the latest time counter 602, which identifies the log entry 402 in the shared log 102 to store the transaction. Client 12a can send a message to the log manager module 106 to buffer the transaction in the log manager module's transaction write buffer 502 to be written to the shared log 102. The value of the latest time counter 602 from the sequencer module 104 can also be used to update the local time references of the target data objects stored in the client 12a. Processing can return to operation 702 to process another transaction.
Returning to operation 706, the client 12a in the alternative can receive a FAIL response from the sequencer module 104. In some instances, a FAIL response can indicate that not all the source data objects used to make the computations for the transaction were at their latest data state; in other words, there was a conflict between the data state of at least one of the source data objects in the client 12a versus the data state of that source data object in the shared log 102. Consequently, the computations performed by client 12a may be incorrect. This is an example of an “actual conflict.”
In other instances, a FAIL response can indicate a failure in the sequencer module 104, whereby access to state information (e.g., last-modified time 604b,
In response to receiving a FAIL from the sequencer module 104, the client 12a in some embodiments can proceed along any one of three processing paths I, II, III. The client 12a does not know whether the FAIL is due to an actual conflict or is a non-conflict failure in the sequencer module 104 (e.g., a collision in the hash function used to generate object identifiers). Accordingly, in some instances, the client 12a can abort the transaction and return to operation 702 to process another transaction (processing path I). In other instances, the client 12a can proceed to operation 722 (processing path II) or to operation 732 (processing path III) and attempt to retry the verification. Processing paths II and III are discussed next.
At operation 722, the client 12a can respond to the FAIL indication by scanning entries in the shared log 102, and manually determining whether or not an actual conflict exists. In some embodiments, the sequencer module 104 can return a time reference Treturned to the client 12a along with the FAIL indication. Depending on the nature of the FAIL condition, Treturned can be the log index 404 of the log entry 402 in the shared log 102 of the source data object, among all the source data objects in the read set, that was most recently updated (in the case of an actual conflict). In the case of a non-conflict failure in the sequencer module 104, Treturned can be the value of the latest time counter 602 (i.e., the log index 404 of the log entry 402 at the tail of the shared log 102).
In accordance with some embodiments, the client 12a can scan the shared log 102 for each source data object for any updates made within a conflict window, to determine whether or not an actual conflict exists. In some embodiments, the “conflict window” for a data object can be defined as the window of time between Treturned (the time reference returned by the sequencer module 104) and the client's time reference for that data object, keeping in mind that each client in the system maintains its own virtual copy of data objects and corresponding time references. Using the examples above, for instance, the conflict window for the data object A.member1 is the time between time reference 12 (the client side time reference) and Treturned. The conflict window for the data object A.member3 is the time between time reference 15 and Treturned, and for the data object B.member1 the conflict window is between time reference 11 and Treturned.
Consider the scanning for data object A.member1, for example. In some embodiments, the client 12a can query the shared log 102, for each increment in time within the conflict window (from time reference 12 to Treturned) to look for any updates to A.member1. Thus, client 12a can query the shared log 102 for any updates to A.member1 made at time reference 13 (e.g., read the log entry at log index=13), then at time reference 14, and so on up to Treturned. If an update has been made to data object A.member1 at any time between 12 and Treturned, then an actual conflict of data object A.member1 exists; in other words, the copy of A.member1 held by client 12a is older than the current state of A.member1 in the shared log 102. Otherwise, there is no actual conflict with A.member1.
At operation 724, in response to detecting an actual conflict with any one of the source data objects, client 12a can proceed to operation 732. If no actual conflict is detected, processing in the client 12a can proceed to operation 726.
At operation 726, the client 12a can retry verifying the transaction and obtaining a log index when no actual conflict exists. In accordance with the present disclosure, the client 12a can include an additional parameter, referred to herein as a VERIFIED flag, in the verify request. The VERIFIED flag can serve to indicate to the sequencer module 104 that the client 12a has verified that the source data objects are not in conflict with the shared log 102 as of time reference Treturned. Accordingly, the client 12a can use the time reference Treturned as the snapshot time parameter in the verify request.
Since a source data object can be updated by another client subsequent to verifying the conflict windows (operation 722) and prior to receiving confirmation from the sequencer module 104 to commit the transaction, the sequencer module 104 may respond with another FAIL indication. Accordingly, processing in the client 12a can continue at operation 706 to repeat the process.
At operation 732, the client 12a can respond to the FAIL indication by re-computing the transaction. In accordance with some embodiments, the client 12a can use the time reference Treturned returned by the sequencer module 104 to obtain the latest data state of the source data objects used in computing the transaction. For example, using Treturned, the client 12a can replay transactions from the shared log 102 up to Treturned for each data object, thus updating the data state of the source data objects to the time reference of Treturned. The client 12a can then recompute the transaction beginning at operation 702 with the updated source data objects.
The discussion will now turn to a description of additional detail in the sequencer module 104 in accordance with some embodiments. As noted above, the sequencer module 104 can indicate FAIL as a result of an actual conflict, where the data state in the shared log 102 of a source data object is more current than the data state in the client. In some embodiments, for example, an actual conflict can exist when the log index 404 of the most recent entry 402 of a source data object in the shared log 102 is greater than the time reference for that source data object in the client.
It is further noted that the sequencer module 104 can indicate FAIL where there is no actual conflict (a non-conflict). In some embodiments, a non-conflict FAIL can arise if the data objects table 604 does not contain an entry for a source data object. In some embodiments, for example, it may not be practical to store the entire data objects table 604 in main memory. In specific instances, for example, the data objects table 604 can contain thousands to hundreds of thousands to millions of entries. Accordingly, only portions of the data objects table 604 may be stored in main memory, for example, in a cache. Being a cache memory, portions of the cache can be evicted from main memory, for example, due to memory pressure, or during the course of normal memory management in the computer system (e.g., 302,
In some embodiments, a non-conflict FAIL can arise due to a hash collision. As noted above, in some embodiments, a data object in the data objects table 604 can be indexed according to a hash value (hash code) computed from the identifier of the object and the identifier of the member in that object. Clients can transmit hash codes to identify data objects in the read set and data objects in the write set in order to minimize I/O with the sequencer module 104. In the case of a hash collision for a data object, the sequencer module 104 can respond with a FAIL because the data object cannot be identified due to the collision.
Referring to
At operation 802, the sequencer module 104 can receive a verify request from a client (see operations 704, 726,
At operation 804, the sequencer module 104 can determine if the verify request includes the VERIFIED parameter (see operation 726,
At operation 806, the sequencer module 104 can verify each source data object by scanning the shared log 102. As explained above, inclusion of the VERIFIED parameter in the verify request indicates the client has manually verified the data objects up to the snapshot time provided in the verify request in response to a FAIL indication. Accordingly, the sequencer module 104 needs only to scan that portion of the shared log 102 from the time of the snapshot time to the latest entry in the shared log 102 (e.g., pointed to by the latest time counter 602) to verify the source data objects, instead of having to scan the entire shared log 102. If none of the data objects appear in the shared log 102 subsequent to the snapshot time, the data objects can be deemed to be verified; i.e., no conflict. If one of the data objects appears in shared log 102 subsequent to the snapshot time, this can be deemed to be a conflict. The sequencer module 104 can proceed to operation 814.
At operation 808, the sequencer module 104 can determine if all the source data objects are in memory. As explained above, only portions of the data objects table 604 may be cached in main memory. As such, it is possible that portion(s) of the data objects table 604 that contain one or more of the source data objects may not be in main memory. Accordingly, in response to a determination that one or more of the source data objects are not in main memory, the sequencer module 104 can proceed to operation 810; otherwise, the sequencer module 104 can proceed to operation 812.
At operation 810, the sequencer module 104 can signal a FAIL to the client since the portion(s) of the data objects table 604 that contains one or more source data objects are not in main memory. As such, the sequencer module 104 does not have the last-modified times (604b,
At operation 812, the sequencer module 104 can verify the actual state of the source data objects against the snapshot time provided in the verify request, for example, by comparing the snapshot time to time references of the source data objects' most recent updates in the shared log 102 to determine whether the snapshot time represents the most current data state of the source data objects. In some embodiments, for instance, the sequencer modules 104 can compare the last-modified time 604b of each source data object in the data objects table 604 against the snapshot time received in the verify request.
A data object is deemed to be “verified” if its last-modified time 604b is less than or equal to the snapshot time; in other words, when the snapshot time is not earlier in time than any of the data object's most recent update. Stated differently, a data object is deemed to be verified if the snapshot time represents the most current data state of the data object.
Conversely, if the last-modified time 604b of the data object is greater than the snapshot time, then that data object can be deemed to be at a state that is more recent than indicated by the snapshot time; in other words, there is a conflict. Stated differently, a conflict can exist when the most current data state of the data object occurs later in time than the snapshot time.
In accordance with the present disclosure, the sequencer module 104 can consider the last-modified times of the object members of an object, rather than the last-modified time of the object itself. Recall that a data object refers to an object (source object) and an object member (source object members) in that object; e.g., a record 202 in database table 200 in
At operation 814, if no conflicts were detected in operation 812 (or operation 806), then the computations/operations made using the source data objects can be deemed to be “correct” and the sequencer module 104 can continue processing at operation 816. On the other hand, if at least one conflict was detected in operation 812 (or operation 806), then whatever computations were made using the source data objects can be deemed to be “incorrect” and the sequencer module 104 can process a FAIL at operation 820.
At operation 816, the sequencer module 104 has determined that the transaction is “correct” in terms of the data objects used to compute the transaction, and can allow the transaction to be committed. In accordance with some embodiments of the present disclosure, for example, the sequencer module 104 can increment the latest time counter 602 to point to the next (new) free entry in the shared log 102 in which the transaction will be stored (
The sequencer module 104 can update the data objects table 604 with respect to the target data objects. For example, the sequencer module 104 can find one or more entries in the data objects table 604 that contain that target data objects. If a target data object is not already in the data objects table 604, the sequencer module 104 can create a new entry. For each target data object in the data objects table 604, the sequencer module 104 can update its last-modified time field 604b with the value of the latest time counter 602 to indicate the log entry 402 in the shared log 102 that contains the operation(s) applied to the target data objects. The data objects table 604, therefore, provides information (e.g., via the last-modified time field 604a) of the latest updates to data objects in the shared log 102.
At operation 818, the sequencer module 104 can signal the client to COMMIT the transaction. The sequencer module 104 can also provide the latest time counter 602 (see operation 708,
At operation 820, the sequencer module 104 can signal a FAIL to the client in response to detecting a conflict, where the client can retry sending the verify request (see N branch of operation 706,
As noted above, processing in accordance with the present disclosure allows the client to verify correctness of the transaction in a single roundtrip message, without having to employ time consuming heavyweight mechanisms such as locking, write-logging, and the like. Processing by the sequencer module 104 is efficient; it needs only to maintain a counter (last-modified time) per data object, and do simple in-memory comparisons to assess correctness of the transaction without the need for the source data objects or the operations and/or computations of the transaction. This lightweight interface to the sequencer module 104 allows clients in the shared log system 100 to quickly access the sequencer module 104. The lightweight processing in the sequencer module 104 allows all clients to perform conflict resolution with greatly reduced loading on the system as compared to conventional approaches.
At operation 902, the log manager module 106 can receive a transaction from a client 12 (see operation 708,
At operation 904, the log manager module 106 can write the received transaction stored in the transaction write buffer 502 to the shared log 102. In some embodiments, for example, the log manager module 106 can allocate space for another log entry 402 in the shared log 102 to store the target data objects. The write buffer 502 can retain the target data objects for subsequent read operations on the target data objects, and thus act as a caching mechanism.
The present disclosure will now turn to a discussion of accessing the most recent update to a data object stored in a shared log 102. Conventionally, a client 12 can generate the latest state of a data object by replaying all the transactions made to that object from the time of its instantiation. The idea of “replay” is a well known and understood concept. Briefly, to replay a given object the client 12 issues individual read operations to offsets in the shared log 102 to access log entries 402 for transactions made to the object of interest. The client 12 serially applies those transactions to the object starting from the time of the object's instantiation. It can be appreciated that replaying the shared log 102 can greatly increase latency, especially when the client 12 is just interested in a single update. Some systems improve on this brute force approach by separating the log into per-object streams. However, this alternative still requires playback of a “stream,” which although smaller than the log, still can contain many updates that the client may not be interested in but has to replay in order to access the most recent update.
At operation 1002, the computer system 302 can receive a read request from a client to access the most recent data state of a (target) data object. The read request can include an identifier that identifies the target data object. In some embodiments, the identifier can be a hash value computed by the client using a name (e.g., a text string) of the object and a name of the object member in that object that constitute the target data object.
At operation 1004, the computer system 302 can use the identifier of the target data object to access an entry in the data objects table 604 corresponding to the target object. In some embodiments, for example, the hash value that identifies the target data object can be used to index into the data objects table 604.
At operation 1006, the computer system 302 can access a log entry 402 in the shared log 102. In some embodiments, for example, the last-modified time 604b of the entry in the data objects table 604 that corresponds to the target data object can be used as a log index 404 into the shared log 102 to access the log entry 402. A transaction stored in the accessed log entry 402 can include the most recent operations performed on the target data object and thus represents the most recent update made to the target data object.
At operation 1008, the computer system 302 can provide information relating to the most current data state of the target object to the client. Processing in the sequencer module 104 can continue at operation 1002 to process the next read request.
The discussion will now turn to a description of providing for multiple index tables in a shared log in accordance with the present disclosure. As explained above in connection with
In some embodiments, the client's virtual objects 14 can include a map abstraction (referred to herein as a main map 1102) that gives users a key-value like interface to access states (or instances) of the object 1112 stored in the shared log 102. It will be appreciated that the client's virtual objects 14 can include several main map structures 1102, one for each of several objects of interest to the client.
In accordance with the present disclosure, the client can define one or more secondary index tables (indices) 1104 to be included among its virtual objects 14. The secondary indices 1104 can serve as an index to the main map 1102 based on keys (index keys) other than the primary key 1122. The use of secondary indices 1104 allow the client 12a to view information in the main map 1102 in different ways.
The secondary indices 1104 can be based on any suitable indexing data structure, such as hash tables, search trees, and so on. In some embodiments, for example, the secondary indices 1104 can be hash tables. Each secondary index 1104 can include rows of data, with each row comprising an index key 1142 and a primary keys field 1144. The index key 1142 can be defined based on any one or more of the data fields of the main map 1102, depending on how the user wants to view the main map 1102. The primary keys field 1144 in a given secondary index (e.g., 1104a) can be a list of primary keys 1122 (from the main map 1102) that correspond to the index key 1142.
Consider secondary index 1104a, for instance. The secondary index 1104a indexes the main map 1102 based on data field 3 (number of books on loan, in our example). The primary keys field 1144 lists the primary keys 1122 in main map 1102 that contain the index key in data field 3. For example, the index key 0 appears in a row of the main map 1102 having primary key 4, and so the primary keys field 1144 is “1, 5.” Likewise, for index key 1 (primary keys field is 3), and for index key 5 (primary index field is 2, 5). A secondary index 1104b indexes the main map 1102 based on data field 4.
In some embodiments, the index key 1142 can be based on portions of a data field in the main map 1102. For example, an index key for a secondary index (not shown) may be based on the first three digits of data field 2 in the main map 1102 (e.g., area code). In other embodiments, the index key can be based on combinations of multiple data fields and/or portions of the data fields, computations performed on the data fields (e.g., a hash code), and so on.
Using the example shown in
Referring to
At operation 1202, the system can receive a read operation from a client that identifies a target object to read the current state of the target object.
At operation 1204, the system can determine a range of time references between the last read operation or update operation on the target object made by the client and the most current time reference in the shared log. In some embodiments, for example, the client can store a local time reference that indicates the time of the last update made to the target object by the client, or the time of the last read from the shared log. In some embodiments, the most current time reference in the shared log can be the log index (e.g., 404,
At operation 1206, the system can read the shared log for any updates to the target object made within the time range determined at operation 1204, since updates to the target object can be made by other clients subsequent to when the target object was last read or updated by the client. For each time increment (index) within the time range, the system can perform the following operations:
At operation 1208, the system can read an update, if any, to the target object from the shared log for that time increment.
At operation 1210, the system can store the updated target object to the main map (e.g., 1102), thus updating the main map. Referring to
At operation 1212, the system can update each secondary index table (e.g., 1104) defined on the main map that is associated with the updated target object. In accordance with the present disclosure, the secondary index tables can be incrementally built up each time the client reads an object into the main map; the secondary index tables can be dynamically built using a just-in-time approach. In this way, building the secondary index tables can be done with little to no additional I/O load on the shared log. Moreover, since the main map and the secondary index tables are maintained in the memory (e.g., virtual objects 14) of the client, the building process largely takes place within the client machine and thus does not incur any processing load on the shared log to support a secondary index. Each secondary index table in the client that is associated with the target object can be updated using information the updated target object by the following operations:
At operation 1214, the system can generate an index key by processing the updated target object using an index-generating function that is associated with the given secondary index table. Since the updated target object is already inserted in the main map at operation 1210, in some embodiments, the row in the main map that contains the updated target object can be an input parameter to the index-generating function. The index key (e.g., 1142,
At operation 1216, the system can use the index key generated at operation 1214 to identify an entry (e.g., row) in the given secondary index table, which can be an already existing entry or a new entry.
At operation 1218, the system can store the primary key 1122 of the updated target object into the primary keys field (e.g., 1144,
Referring to
At operation 1302, the system can receive an add index operation from a client to create a secondary index table in the memory space of that client. The add index operation can identify the object (target object) that the new secondary index table is associated with. The add index operation can further include a name for the new secondary index table, and can include or otherwise identify an index-generating function that is used to generate index keys (e.g., 1142,
At operation 1304, the system can synchronize the main map with the shared log to read all updates made the target object into the main map. In some embodiments, for example, the client can store a local time reference that indicates the time of the last update made to the target object by the client, or the time of the last read from the shared log. The client can then read all updates made on the target object from the shared log from that time reference up to the most recent time in the shared log. Each update to the target object can be added to the main map, for example, using the primary key (e.g., 1122,
At operation 1306, the system can create a secondary index table in its memory space that is associated with the target object.
At operation 1308, the system can associate the index-generating function with the newly created secondary index. In accordance with the present disclosure, the index-generating function can be defined by the client. This allows the client to specify how they want to index the main map. Referring for example to
At operation 1310, the system can load the newly created secondary index table with data contained in the main map. This process does not require any processing capacity from the shared log system since the main map and the secondary index table are in the client's memory space. All the processing for initially loading the newly created secondary index table can be performed by the client. In some embodiments, for example, each row (e.g., 1114,
At operation 1312, the system can use the index-generating function provided in the add index operation to process a row from the main map to generate an index key. As explained above, the index-generating function can process any portion of the value component (e.g., 1124,
At operation 1314, the system can index into the newly created secondary index table using the index key generated at operation 1312, and insert the primary key 1122 component of the row. Processing can return to the top of the loop at operation 1310 to process the next row in the main map. Processing concludes when all the rows in the main map have been processed.
Embodiments in accordance with the present disclosure allow each client to create their own set of secondary indices that tailored to their specific data access needs, resulting different sets of secondary indices among clients. Although not shown, each client can access their secondary indices via a suitable API that takes a name of a secondary index (e.g., the index name provided by the client in the add index operation) and looks up data contained in the identified secondary index.
These and other variations, modifications, additions, and improvements may fall within the scope of the appended claims(s). As used in the description herein and throughout the claims that follow, “a”, “an”, and “the” includes plural references unless the context clearly dictates otherwise. Also, as used in the description herein and throughout the claims that follow, the meaning of “in” includes “in” and “on” unless the context clearly dictates otherwise.
The above description illustrates various embodiments of the present disclosure along with examples of how aspects of the present disclosure may be implemented. The above examples and embodiments should not be deemed to be the only embodiments, and are presented to illustrate the flexibility and advantages of the present disclosure as defined by the following claims. Based on the above disclosure and the following claims, other arrangements, embodiments, implementations and equivalents may be employed without departing from the scope of the disclosure as defined by the claims.
This application is related to the following commonly owned co-pending U.S. applications for patent, the content of each of which is incorporated herein by reference in its entirety for all purposes: U.S. application Ser. No. 15/652,981, filed Jul. 18, 2017U.S. application Ser. No. 15/791,257, filed Oct. 23, 2017, titled “Direct Access to Object State in a Shared Log”U.S. application Ser. No. 15/791,280, filed Oct. 23, 2017, titled “Fine-Grained Conflict Resolution in a Shared Log”