System and method for balance localization and priority of pages to flush in a sequential log

US11068396B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11068396-B2
Application numberUS-201916528836-A
CountryUS
Kind codeB2
Filing dateAug 1, 2019
Priority dateAug 1, 2019
Publication dateJul 20, 2021
Grant dateJul 20, 2021

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, computer program product, and computer system for staging writes into a log in chronological order, wherein each write may have a log record of a plurality of log records describing data of the write. The log record may be organized into a bucket of a plurality of buckets associated with a range of a plurality of ranges within a backing store, wherein each bucket of the plurality of buckets may include two keys respectively. The log record of the plurality of log records may be flushed from the bucket of the plurality of buckets to the backing store at a location and in an order determined based upon, at least in part, the two keys included with the bucket.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer-implemented method comprising: staging writes into a log in chronological order, wherein each write has a log record of a plurality of log records describing data of the write; organizing each of the log records of the plurality of log records into a bucket of a plurality of buckets associated with a range of a plurality of ranges within a backing store, wherein each bucket of the plurality of buckets includes a first key and a second key respectively; creating a tree, wherein the tree is based upon, at least in part, the second key, wherein the second key includes a lowest log sequence number (LSN) of one or more log records of the plurality of log records, wherein the tree includes one or more LSNs of the one or more log records; and flushing one or more log records of the plurality of log records from one or more buckets of the plurality of buckets to the backing store at a location and in an order determined based upon, at least in part, the first key, the second key, and one or more lowest LSNs from the tree. 2. The computer-implemented method of claim 1 wherein the log record includes a destination logical block address (LBA) of the backing store associated with the range within the backing store. 3. The computer-implemented method of claim 1 wherein the log record includes a log sequence number (LSN). 4. The computer-implemented method of claim 1 wherein a first key of the two keys includes a starting LBA of the range within the backing store. 5. The computer-implemented method of claim 4 wherein the first key of the two keys is used to one of reference the bucket and create a new bucket if the bucket does not exist. 6. A computer program product residing on a non-transitory computer readable storage medium having a plurality of instructions stored thereon which, when executed across one or more processors, causes at least a portion of the one or more processors to perform operations comprising: staging writes into a log in chronological order, wherein each write has a log record of a plurality of log records describing data of the write; organizing each of the log records of the plurality of log records into a bucket of a plurality of buckets associated with a range of a plurality of ranges within a backing store, wherein each bucket of the plurality of buckets includes a first key and a second key respectively; creating a tree, wherein the tree is based upon, at least in part, the second key, wherein the second key includes a lowest log sequence number (LSN) of one or more log records of the plurality of log records, wherein the tree includes one or more LSNs of the one or more log records; and flushing one or more log records of the plurality of log records from one or more buckets of the plurality of buckets to the backing store at a location and in an order determined based upon, at least in part, the first key, the second key, and one or more lowest LSNs from the tree. 7. The computer program product of claim 6 wherein the log record includes a destination logical block address (LBA) of the backing store associated with the range within the backing store. 8. The computer program product of claim 6 wherein the log record includes a log sequence number (LSN). 9. The computer program product of claim 6 wherein a first key of the two keys includes a starting LBA of the range within the backing store. 10. The computer program product of claim 9 wherein the first key of the two keys is used to one of reference the bucket and create a new bucket if the bucket does not exist. 11. A computing system including one or more processors and one or more memories configured to perform operations comprising: staging writes into a log in chronological order, wherein each write has a log record of a plurality of log records describing data of the write; organizing each of the log records of the plurality of log records into a bucket of a plurality of buckets associated with a range of a plurality of ranges within a backing store, wherein each bucket of the plurality of buckets includes a first key and a second key respectively; creating a tree, wherein the tree is based upon, at least in part, the second key, wherein the second key includes a lowest log sequence number (LSN) of one or more log records of the plurality of log records, wherein the tree includes one or more LSNs of the one or more log records; and flushing one or more log records of the plurality of log records from one or more buckets of the plurality of buckets to the backing store at a location and in an order determined based upon, at least in part, the first key, the second key, and one or more lowest LSNs from the tree. 12. The computing system of claim 11 wherein the log record includes a destination logical block address (LBA) of the backing store associated with the range within the backing store, and wherein the log record includes a log sequence number (LSN). 13. The computing system of claim 11 wherein a first key of the two keys includes a starting LBA of the range within the backing store. 14. The computing system of claim 13 wherein the first key of the two keys is used to one of reference the bucket and create a new bucket if the bucket does not exist.

Assignees

Inventors

Classifications

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 US11068396B2 cover?
A method, computer program product, and computer system for staging writes into a log in chronological order, wherein each write may have a log record of a plurality of log records describing data of the write. The log record may be organized into a bucket of a plurality of buckets associated with a range of a plurality of ranges within a backing store, wherein each bucket of the plurality of b…
Who is the assignee on this patent?
Emc Ip Holding Co Llc
What technology area does this patent fall under?
Primary CPC classification G06F12/0804. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jul 20 2021 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 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).