Incremental erasure coding for storage systems

US10248326B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10248326-B2
Application numberUS-201715398819-A
CountryUS
Kind codeB2
Filing dateJan 5, 2017
Priority dateJun 29, 2016
Publication dateApr 2, 2019
Grant dateApr 2, 2019

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A method comprising: generating a storage chunk having a plurality of data fragments, the storage chunk stored in one or more storage devices; allocating space in a primary memory to store a plurality of coded fragments; receiving a plurality of I/O requests to write data; allocating space in the primary memory to store a next unfilled data fragment; processing a plurality of I/O requests to write data; and copying the coded fragments from the primary memory to the one or more storage devices. For each I/O request, writing the data to the next unfilled data fragment in the one or more storage devices, writing the data to the next unfilled data fragment in the primary memory, and if the data fragment in the primary memory is full, updating the coded fragments in the primary memory using the filled data fragment in the primary memory.

First claim

Opening claim text (preview).

What is claimed is: 1. A method comprising: generating a storage chunk having a plurality of data fragments, the storage chunk stored in one or more storage devices; allocating space in a primary memory to store a plurality of coded fragments; receiving a plurality of I/O requests to write data; allocating space in the primary memory to store a next unfilled data fragment; processing a plurality of I/O requests to write data, including for each I/O request: writing the data to the next unfilled data fragment in the one or more storage devices; writing the data to the next unfilled data fragment in the primary memory; and if the data fragment in the primary memory is full, updating the coded fragments in the primary memory using the filled data fragment in the primary memory, removing the filled data fragment from the primary memory and allocating space in the primary memory to store a next unfilled data fragment; and copying the coded fragments from the primary memory to the one or more storage devices. 2. The method of claim 1 wherein updating the coded fragments in primary memory using the full data fragment in primary memory comprises calculating C i =C i +X i,j *D full for each coding fragment C i , where X is a matrix of coding coefficients and D full is the full data fragment. 3. The method of claim 1 wherein the plurality of data fragments include k data fragments, the plurality of coded fragments include m coded fragments, the method further comprising in an event of a loss of m data fragments within the chunk, accessing a number of k unique data fragments or coded fragments and using information from the k unique data fragments or the coded fragments to decode the m data fragments within the chunk. 4. The method of claim 1 wherein the primary memory includes dynamic random-access memory (DRAM). 5. The method of claim 1 wherein the storage devices comprise disk drives. 6. A system comprising: one or more processors; a volatile memory; and a non-volatile memory storing computer program code that when executed on the processor causes execution across the one or more processors of a process operable to perform the operations of: generating a storage chunk having a plurality of data fragments, the storage chunk stored in one or more storage devices; allocating space in a primary memory to store a plurality of coded fragments; receiving a plurality of I/O requests to write data; allocating space in the primary memory to store a next unfilled data fragment; processing a plurality of I/O requests to write data, including for each I/O request: writing the data to the next unfilled data fragment in the one or more storage devices; writing the data to the next unfilled data fragment in the primary memory; and if the data fragment in the primary memory is full, updating the coded fragments in the primary memory using the filled data fragment in the primary memory, removing the filled data fragment from the primary memory and allocating space in the primary memory to store a next unfilled data fragment; and copying the coded fragments from the primary memory to the one or more storage devices. 7. The system of claim 6 wherein updating the coded fragments in primary memory using the full data fragment in primary memory comprises calculating C i =C i +X i,j *D full for each coding fragment C i , where X is a matrix of coding coefficients and D full is the full data fragment. 8. The system of claim 6 wherein the plurality of data fragments include k data fragments, the plurality of coded fragments include m coded fragments, the operations further comprising in an event of a loss of m data fragments within the chunk, accessing a number of k unique data fragments or coded fragments and using information from the k unique data fragments or the coded fragments to decode the m data fragments within the chunk. 9. The system of claim 6 wherein the primary memory includes dynamic random-access memory (DRAM). 10. The system of claim 6 wherein the storage devices comprise disk drives. 11. A computer program product tangibly embodied in a non-transitory computer-readable medium, the computer-readable medium storing program instructions that are executable to: generate a storage chunk having a plurality of data fragments, the storage chunk stored in one or more storage devices; allocate space in a primary memory to store a plurality of coded fragments; receive a plurality of I/O requests to write data; allocate space in the primary memory to store a next unfilled data fragment; process a plurality of I/O requests to write data, including for each I/O request: write the data to the next unfilled data fragment in the one or more storage devices; write the data to the next unfilled data fragment in the primary memory; and if the data fragment in the primary memory is full, update the coded fragments in the primary memory using the filled data fragment in the primary memory, removing the filled data fragment from the primary memory and allocating space in the primary memory to store a next unfilled data fragment; and copy the coded fragments from the primary memory to the one or more storage devices. 12. The computer program product of claim 11 wherein updating the coded fragments in primary memory using the full data fragment in primary memory comprises calculating C i =C i +X i,j *D full for each coding fragment C i , where X is a matrix of coding coefficients and D full is the full data fragment. 13. The computer program product of claim 11 wherein the plurality of data fragments include k data fragments, the plurality of coded fragments include m coded fragments, the program instructions further configured to, in the event of a loss of m data fragments within the chunk, access a number of k unique data fragments or coded fragments and use information from the k unique data fragments or the coded fragments to decode the m data fragments within the chunk. 14. The computer program product of claim 11 wherein the primary memory includes dynamic random-access memory (DRAM). 15. The computer program product of claim 11 wherein the storage devices comprise disk drives.

Assignees

Inventors

Classifications

  • Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS] · CPC title

  • G06F3/061Primary

    Improving I/O performance · CPC title

  • Hybrid storage combining heterogeneous device types, e.g. hierarchical storage, hybrid arrays · CPC title

  • Command handling arrangements, e.g. command buffers, queues, command scheduling · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US10248326B2 cover?
A method comprising: generating a storage chunk having a plurality of data fragments, the storage chunk stored in one or more storage devices; allocating space in a primary memory to store a plurality of coded fragments; receiving a plurality of I/O requests to write data; allocating space in the primary memory to store a next unfilled data fragment; processing a plurality of I/O requests to wr…
Who is the assignee on this patent?
Emc Ip Holding Co Llc
What technology area does this patent fall under?
Primary CPC classification G06F3/061. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Apr 02 2019 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 9 related publications on this page (citations in our corpus or others sharing the same primary CPC).