Flushing pages from solid-state storage device

US10860494B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10860494-B2
Application numberUS-201916514291-A
CountryUS
Kind codeB2
Filing dateJul 17, 2019
Priority dateSep 23, 2016
Publication dateDec 8, 2020
Grant dateDec 8, 2020

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.

Embodiments of the present disclosure relate to a method and device for flushing pages from a solid-state storage device. Specifically, the present disclosure discloses a method of flushing pages from a solid-state storage device comprising: determining a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and flushing pages from the solid-state storage device with an upper limit of the first number in the flushing cycle. The present disclosure also discloses a device for flushing pages from a solid-state storage device and a computer program product for implementing steps of a method of flushing pages from a solid-state storage device.

First claim

Opening claim text (preview).

What is claimed is: 1. A method of flushing pages from a solid-state storage device, comprising: determining a limit number based on a response time of the solid-state storage device to one flushing transaction, the limit number indicating a maximum number of flushing transactions that can be executed in parallel in the solid-state storage device during the flushing cycle; and during the flushing cycle, flushing the pages from the solid-state storage device with an upper limit of the limit number. 2. The method according to claim 1 , wherein the limit number is determined based on a response time to one flushing transaction of a RAID group to which the solid-state storage device belongs, the limit number indicating a maximum number of flushing transactions that can be executed in parallel in the RAID group to which the solid-state storage device belongs during the flushing cycle. 3. The method according to claim 2 , wherein the limit number is related to a depth of a RAID queue for the RAID group to which the solid-state storage device belongs. 4. The method according to claim 3 , wherein the solid-state storage device is one of a plurality of storage devices belong to respective RAID groups and having respective distinct RAID queue depths, and wherein the RAID queue depths of each RAID group indicate respective maximum numbers of flushing transactions that can be executed in parallel in the respective RAID groups during the flushing cycle. 5. The method according to claim 4 , wherein the RAID queue depths correspond to respective busy levels of the RAID groups including at least idle, normal and busy, the RAID queue depths decreasing with increasing busy level. 6. The method according to claim 5 , wherein a level of write/read IOs influences the busy levels of RAIDs, and the RAID queue depths are dynamically adjusted accordingly, the busy levels being assessed for a given flushing cycle and used to determine the respective RAID queue depths in a next flushing cycle. 7. The method according to claim 1 , wherein the limit number is a second limit number, and further comprising: determining a first limit number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first limit number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and during the flushing cycle, flushing the pages from the solid-state storage device with an upper limit of a smaller one of the first and second limit numbers. 8. The method according to claim 7 , further comprising: determining, based on a central processing unit (CPU) time, a start time and an end time of building the flushing transaction; and determining, based on a difference between the start time and the end time, the period length required for building the flushing transaction. 9. The method according to claim 7 , wherein flushing the pages comprises: in response to a page to be flushed being a clean page, invalidating metadata corresponding to the page; and in response to the page to be flushed being a dirty page, copying data of the page into a hard disk; and invalidating the metadata corresponding to the page. 10. The method according to claim 9 , wherein copying the data of the page into the hard disk comprises: determining a third limit number based on a response time of the hard disk to one flushing transaction, the third limit number indicating a maximum number of flushing transactions that can be executed in parallel in the hard disk during the flushing cycle; and during the flushing cycle, flushing the page into the hard disk with an upper limit of the third limit number. 11. The method according to claim 10 , further comprising: maintaining a first list and a second list in the solid-state storage device, the first list indicating clean pages, and the second list indicating dirty pages; and performing the flushing of the pages using the first list and the second list. 12. The method according to claim 9 , wherein the flushing of the clean page precedes the flushing of the dirty page. 13. An electronic device comprising: a processor; and a memory coupled to the processor and storing instructions executable by the processor, the instructions, when being executed by the processor, causing the device to: determine a limit number based on a response time of the solid-state storage device to one flushing transaction, the limit number indicating a maximum number of flushing transactions that can be executed in parallel in the solid-state storage device during the flushing cycle; and during the flushing cycle, flush the pages from the solid-state storage device with an upper limit of the limit number. 14. The electronic device according to claim 13 , wherein the limit number is determined based on a response time to one flushing transaction of a RAID group to which the solid-state storage device belongs, the limit number indicating a maximum number of flushing transactions that can be executed in parallel in the RAID group to which the solid-state storage device belongs during the flushing cycle. 15. The electronic device according to claim 14 , wherein the limit number is related to a depth of a RAID queue for the RAID group to which the solid-state storage device belongs. 16. The electronic device according to claim 15 , wherein the solid-state storage device is one of a plurality of storage devices belong to respective RAID groups and having respective distinct RAID queue depths, and wherein the RAID queue depths of each RAID group indicate respective maximum numbers of flushing transactions that can be executed in parallel in the respective RAID groups during the flushing cycle. 17. The electronic device according to claim 16 , wherein the RAID queue depths correspond to respective busy levels of the RAID groups including at least idle, normal and busy, the RAID queue depths decreasing with increasing busy level. 18. The electronic device according to claim 17 , wherein a level of write/read IOs influences the busy levels of RAIDs, and the RAID queue depths are dynamically adjusted accordingly, the busy levels being assessed for a given flushing cycle and used to determine the respective RAID queue depths in a next flushing cycle. 19. The electronic device according to claim 13 , wherein the limit number is a second limit number, and wherein the instructions, when being executed by the processor, further cause the device to: determine a first limit number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first limit number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and during the flushing cycle, flush the pages from the solid-state storage device with an upper limit of a smaller one of the first and second limit numbers. 20. A computer program product for flushing pages from a solid-state storage device, the computer program product comprising: a non-transitory computer readable medium encoded with computer-executable program code for flushing pages from the solid-state storage device, the code configured to enable the execution of: determining a limit number based on a response time of the solid-state storage device to one flushing transaction, the limit number indicating a maximum number of flushing transactions that can be executed in parallel in the solid-state storage device during the flushing cycle; and during the flushi

Assignees

Inventors

Classifications

  • with main memory updating (G06F12/0806 takes precedence) · CPC title

  • Solid state disk · CPC title

  • Non-volatile semiconductor memory arrays · CPC title

  • with two or more cache hierarchy levels (with multilevel cache hierarchies G06F12/0811) · CPC title

  • using adaptive policy · 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 US10860494B2 cover?
Embodiments of the present disclosure relate to a method and device for flushing pages from a solid-state storage device. Specifically, the present disclosure discloses a method of flushing pages from a solid-state storage device comprising: determining a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first num…
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 Dec 08 2020 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).