CACHE ARRANGEMENT FOR IMPROVING RAID I/O OPERATIONS
The embodiments of the invention provide a method, apparatus, etc. for a cache arrangement for improving RAID I/O operations. More specifically, a method begins by partitioning a data object into a plurality of data blocks and creating one or more parity data blocks from the data object. Next, the data blocks and the parity data blocks are stored within storage nodes. Following this, the method caches data blocks within a partitioned cache, wherein the partitioned cache includes a plurality of cache partitions. The cache partitions are located within the storage nodes, wherein each cache partition is smaller than the data object. Moreover, the caching within the partitioned cache only caches data blocks in parity storage nodes, wherein the parity storage nodes comprise a parity storage field. Thus, caching within the partitioned cache avoids caching data blocks within storage nodes lacking the parity storage field.
1. Field of the Invention
The embodiments of the invention provide a method, apparatus, etc. for a cache arrangement for improving RAID I/O operations.
2. Description of the Related Art
It is often necessary in a distributed storage system to read or write data redundantly that has been striped on more than one storage server (or target). Such a system configuration is referred to as a “network-RAID” (redundant array of independent disks) because the function of a RAID controller is performed by the network protocol of the distributed storage system by coordinating I/O (input/output) operations that are processed at multiple places concurrently in order to ensure correct system behavior, both atomically and serially. Distributed storage systems using a network-RAID protocol can process, or coordinate, a network-RAID-protocol I/O request (I/O request) locally at a client node or the request can be forwarded to a storage server or a coordination server for processing. For example, one client node may locally write data to a particular data location, while another client node may choose to forward a read or a write request for the same data location to a shared, or coordination, server.
SUMMARYThe embodiments of the invention provide a method, apparatus, etc. for a cache arrangement for improving RAID I/O operations. More specifically, a method for cache management within a distributed data storage system begins by partitioning a data object into a plurality of data blocks and creating one or more parity data blocks from the data object. Next, the data blocks and the parity data blocks are stored within storage nodes.
Following this, the method caches data blocks within a partitioned cache, wherein the partitioned cache includes a plurality of cache partitions. The cache partitions are located within the storage nodes, wherein each cache partition is smaller than the data object. Moreover, the caching within the partitioned cache only caches data blocks in parity storage nodes, wherein the parity storage nodes comprise a parity storage field. Thus, caching within the partitioned cache avoids caching data blocks within storage nodes lacking the parity storage field. When the storage nodes comprise more than one parity storage node, the data blocks are cached in any of the parity storage nodes.
The method further includes updating the data object. Specifically, a write request is annotated with information regarding changed data blocks within the data object; and, the write request is only sent to the parity storage nodes. The sending of the write request only to the parity storage nodes comprises simultaneously performing an invalidation operation and a write operation. Subsequently, the data blocks and parity data block are read from the storage nodes.
An apparatus for cache management within a distributed data storage system is also provided. More specifically, the apparatus comprises a partitioner to partition a data object into a plurality of data blocks. An analysis engine is operatively connected to the partitioner, wherein the analysis engine creates one or more parity data blocks from the data object. Moreover, a controller is operatively connected to the analysis engine, wherein the controller stores the data blocks and the parity data blocks within storage nodes.
The controller also caches data blocks within a partitioned cache, wherein the partitioned cache includes a plurality of cache partitions. The cache partitions are located within the storage nodes, wherein each cache partition is smaller than the data object. When caching within the partitioned cache, the controller only caches data blocks in parity storage nodes, wherein the parity storage nodes have a parity storage field. Thus, when caching, the controller avoids caching data blocks within storage nodes lacking the parity storage field. When the storage nodes have more than one parity storage node, the controller caches the data blocks in any of the parity storage nodes.
Additionally, the controller annotates a write request with information regarding changed data blocks within the data object and sends the write request to the parity storage nodes. The controller simultaneously performs an invalidation operation and a write operation. The apparatus further includes a reader operatively connected to the controller, wherein the reader reads the data blocks and the parity data blocks from the storage nodes.
Accordingly, the embodiments of the invention provide a technique to build a lightweight cache coherence protocol in distributed storage systems by exploiting the update patterns inherent with erasure coded data. Such a technique can unify the partitioned caches into a single large read cache and can use the cached data to improve RAID I/O operations from clients.
The embodiments of the invention will be better understood from the following detailed description with reference to the drawings, in which:
The embodiments of the invention and the various features and advantageous details thereof are explained more fully with reference to the non-limiting embodiments that are illustrated in the accompanying drawings and detailed in the following description. It should be noted that the features illustrated in the drawings are not necessarily drawn to scale. Descriptions of well-known components and processing techniques are omitted so as to not unnecessarily obscure the embodiments of the invention. The examples used herein are intended merely to facilitate an understanding of ways in which the embodiments of the invention may be practiced and to further enable those of skill in the art to practice the embodiments of the invention. Accordingly, the examples should not be construed as limiting the scope of the embodiments of the invention.
The embodiments of the invention provide a technique to build a lightweight cache coherence protocol in distributed storage systems by exploiting the update patterns inherent with erasure coded data. Such a technique can unify the partitioned caches into a single large read cache and can use the cached data to improve RAID I/O operations from clients.
Erasure coded data benefits the most from caching while executing write and reconstruct read operations.
To make effective use, dispersed cache requires some cache coherence scheme, which comprises of two parts. First, a scalable cache directory needs to map pages to nodes. Second, an invalidation (or coherence) protocol is needed to ensure correctness. With erasure codes, read/write performance of data in degraded/critical mode is significantly slower than under fault-free mode. If at least the working set is cached somewhere until the rebuild operation completes, then read/write performance can be improved. Specifically, given a cache arrangement scheme, the execution of a RAID read or write operation at a node can be optimized by leveraging pages that are in the caches of the different nodes.
Considering data laid out in some erasure code layout (e.g., RAID5), for each data stripe, a subset of the bricks take on different roles. Each brick stores a stripe of data for which it is the target node (TN). For each stripe, there will be at least t pages to store parity for a t-fault tolerant code. Each parity page is stored on a different parity node (PN). Client nodes (CN) are also provided. From the perspective of any dirty data page, the multiple nodes in the system are categorized as described below. CN is the client node that initiates the flush of this dirty page; and, TN is the target node to which the dirty data page should be written. {PN} is the parity node that hosts the parity page that depends on the dirty data page. There can be multiple parities depending on the layout, which is indicated by the curved brackets. {DN} is the dependent node that hosts the dependent data (dD) contributing to the calculation of the same parity as the dirty page.
The XOR calculations for new parity can be performed at any one or combination of these nodes. Locally, each of the above nodes can have one of two plans: parity compute (PC) or parity increment (PI). Additionally, two issues need to be addressed. The first issue is how each kind of nodes derive their own best I/O plan. The second issue is how different nodes interact with each other to get an agreement on the final I/O plan.
Data pages can be cached only at parity nodes that depend on it. When an update to the data page occurs (at CN) the invalidation can be piggybacked on the that operation to the new parity page (to PN). PN is guaranteed to get an update operation due to how redundancy is maintained i.e., erasure coding. In other words, if data pages are cached at the parity node(s), the new data is always in the parity nodes. This can be checked during read to that data by any CN. The unchanged data, which is not in the parity nodes, are not invalidated.
Beyond just invalidation, by employing certain client write I/O plans, this cache at the parity node(s) can be kept in sync without any extra messaging.
As illustrated in
If both TN and one or more PNs cache a data block, the effective cache size is reduced. This leads to greater cache pressure on (global pool) cache pages. To avoid this, three rules for caching data are provided. First, TN does not read cached data pages except during system transience (writing, buffering). This makes TN's cache exclusive. Second, when the erasure code allows for multiple PN's, then any one can be chosen (e.g., randomly). Third, the first rule is not applicable to parity pages, which can cached during transience.
With this caching scheme in place, embodiments herein can use one round of messages to gather all candidate I/O plan costs from all t PN's and compare with the local plans available to CN and pick the best plan. In degraded/critical mode, reconstructed pages are held at the parity node longer (until rebuild completes or cache pressure builds sufficiently) for possible reuse by another client. As discussed above, if at least the working set is cached somewhere until the rebuild operation completes, then read/write performance can be improved. Specifically, given a cache arrangement scheme, the execution of a RAID read or write operation at a node can be optimized by leveraging pages that are in the caches of the different nodes.
Thus, while cache invalidation is piggybacked on write operations, priming caches at the parity nodes takes some extra work. Moreover, read operations will need two phases, including a first phase to exchange plans. Write operations may require 3 phases, including a first phase to exchange plans (but here is an opportunity to piggyback). Further, by location shifting the cache, the impact it will have on local I/O optimizations (like prefetching etc.) is unknown.
The embodiments herein can be applied to distributed (clustered) storage systems. For such systems, the embodiments of the invention have the ability to provide read cache unification and to improve RAID I/O operations.
Furthermore, the embodiments of the invention provide a distributed cache management scheme for a storage system that uses erasure coded distributed RAID and has partitioned cache (where the total sum can be fairly substantial). This speeds up RAID reads and writes by leveraging cached data, where possible. Moreover, this unifies the cache, which maximizes cache effectiveness. There is no duplication of cached data. The cache management scheme is lightweight; no (additional) messaging for cache coherence or a data directory is needed. The management scheme is also opportunistic; any steps can be skipped under a heavy load without affecting correctness.
Embodiments of the invention provide the following cache rules. First, each write request from a client is annotated with information about changed blocks within a stripe. Thus, cache invalidation is piggybacked onto regular operations. Second, data blocks can be cached only at parity node(s). Multiple candidates exist for higher distance codes; and, no separate cache directory is needed. Third, data blocks are not cached at the target node, except by the operating system as staging during read/write operations. The “home” location of data is shifted from a target node to a parity node. Fourth, clients “demote” victim data page to parity node(s). In case of a higher distance code, a lexicographical parity node is chosen. Such a parity node primes caches in storage nodes opportunistically from clients. Fifth, a client or storage node can locally decide to evict (clean) pages. This provides for loosely coupled caching.
Consequences of the cache rules provide that data pages from multiple clients get “percolated” into caches in storage nodes, which is advantageous for shared workloads without clients even cooperating. This is irrelevant for totally random workloads, which are no worse than before. Moreover, caches at storage nodes are aligned in a “RAID-friendly” way. All data used to compute a parity block localized. Further, due to the nature of erasure code updates, cache coherence is free. Parity node(s) have to be written to for write completion. Annotation helps identify which blocks have changed.
Reads and writes include an extra messaging phase to query the cache state at parity node(s). Client costs various read/update plans possible around metrics, such as disk IOs and memory bandwidth. The client chooses the best plan and drives I/O.
Read plan choices include finding the cheapest reconstruction plan in three steps: inverting the matrix; masking cached pages; and, cost planning. Possible locations include the client node and parity node(s).
Beyond distributed RAID, the embodiments herein are applicable to a class of problems that requires coordination of a distributed cache resource and updates to a set of data blocks that require updates to some common (dependent) block(s). Such systems could include distributed databases and cluster file systems.
Thus, the embodiments of the invention provide a distributed cache arrangement for a storage system that speeds up RAID operations where workload is conducive. The working set is larger than any single client cache but it fits in the collective cache. A shared data set exists between the clients but the data set is time shifted. Moreover, the cache arrangement adjusts automatically to workloads from clients. If there is a shared workload, then there is a benefit; otherwise, the cache arrangement exploits collective cache space.
Referring to
The controller 830 also caches the data blocks within a partitioned cache, wherein the partitioned cache includes cache partitions. The cache partitions are located within the storage nodes, wherein each cache partition is smaller than the data object (e.g., volume, LUN, file system). More specifically, each cache partition is located within a storage node. When caching within the partitioned cache, the controller 830 only caches the data blocks in parity storage nodes, wherein the parity storage nodes include a parity storage field (a field within a storage node where parity data block(s) can be stored). Thus, the controller 830 avoids caching data blocks within storage nodes lacking the parity storage field. For example, as illustrated in
When caching within the partitioned cache, and when the storage nodes comprise more than one parity storage node, the controller 830 caches the data blocks in any of the parity storage nodes. Moreover, the controller 830 annotates a write request with information regarding changed data blocks within the data object and sends the write request to the parity storage nodes. The controller 830 simultaneously performs an invalidation operation and a write operation. Additionally, a reader 840 is operatively connected to the controller 830, wherein the reader 840 reads the data blocks and the parity data block from the storage nodes.
Referring to
In item 940, the data blocks are also cached within a partitioned cache, wherein the partitioned cache includes cache partitions. The cache partitions are located within the storage nodes, wherein each cache partition is smaller than the data object. As described above, the storage nodes could have a write and read cache or a read cache only. Moreover, the caching within the partitioned cache only caches the data blocks in parity storage nodes, wherein the parity storage nodes include a parity storage field (item 942). Thus, caching the data blocks within storage nodes lacking the parity storage field is avoided (item 944). Accordingly, as described above, a separate cache directory is not required because the cached data blocks are only in the parity storage nodes.
When caching the data blocks within the partitioned cache, and when the storage nodes have more than one parity storage node, the data blocks are cached in any of the parity storage nodes (item 946). As described above,
The method 900 also includes, in item 950, updating the data object. This includes annotating a write request with information regarding changed data blocks within the data object (item 952) and sending the write request only to the parity storage nodes (item 954). The sending of the write request only to the parity storage nodes comprises simultaneously performing an invalidation operation and a write operation (item 956). Thus, as described above, cache invalidation is piggybacked onto regular operations. Due to the nature of erasure code updating, cache coherence is free because parity node(s) have to be written to for a write completion. Annotation helps identify which blocks have changed. Subsequently, in item 960, the data blocks and parity data block are read from the storage nodes. The method 900 can check the cache at the parity storage nodes before reading the data block from the target storage nodes.
Accordingly, the embodiments of the invention provide a technique to build a lightweight cache coherence protocol in distributed storage systems by exploiting the update patterns inherent with erasure coded data. Such a technique can unify the partitioned caches into a single large read cache and can use the cached data to improve RAID I/O operations from clients.
The foregoing description of the specific embodiments will so fully reveal the general nature of the invention that others can, by applying current knowledge, readily modify and/or adapt for various applications such specific embodiments without departing from the generic concept, and, therefore, such adaptations and modifications should and are intended to be comprehended within the meaning and range of equivalents of the disclosed embodiments. It is to be understood that the phraseology or terminology employed herein is for the purpose of description and not of limitation. Therefore, while the embodiments of the invention have been described in terms of preferred embodiments, those skilled in the art will recognize that the embodiments of the invention can be practiced with modification within the spirit and scope of the appended claims.
Claims
1-7. (canceled)
7. A method for cache management within a distributed data storage system, said method comprising:
- partitioning a data object into a plurality of data blocks;
- creating at least one parity data block from said data object;
- storing said data blocks and said parity data block within storage nodes;
- caching said data blocks within a partitioned cache, wherein said partitioned cache comprises a plurality of cache partitions, wherein said cache partitions are located within said storage nodes,
- wherein said caching within said partitioned cache only caches said data blocks in parity storage nodes, wherein said parity storage nodes comprise a parity storage field;
- updating said data object, said updating comprising annotating a write request with information regarding changed data blocks within said data object, and sending said write request only to said parity storage nodes; and
- reading said data blocks and said parity data block from said storage nodes;
- wherein said caching within said partitioned cache comprises avoiding caching said data blocks within storage nodes lacking said parity storage field,
- wherein said sending of said write request only to said parity storage nodes comprises simultaneously performing an invalidation operation and a write operation, and
- wherein said caching of said data blocks within said partitioned cache comprises, when said storage nodes comprise more than one of said parity storage nodes, caching said data blocks in any of said parity storage nodes.
8-20. (canceled)
Type: Application
Filed: Apr 30, 2007
Publication Date: Oct 30, 2008
Inventors: Dingshan He (Bellevue, WA), Deepak R. Kenchammana-Hosekote (San Jose, CA)
Application Number: 11/741,826
International Classification: G06F 12/02 (20060101); G06F 15/16 (20060101);