Multi-writer revision synchronization in a dispersed storage network

US9880902B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9880902-B2
Application numberUS-201715460958-A
CountryUS
Kind codeB2
Filing dateMar 16, 2017
Priority dateOct 9, 2007
Publication dateJan 30, 2018
Grant dateJan 30, 2018

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 begins by a processing module of a computing device receiving a most current revision value for a data element, where a revision value for the data element is generated based on a current time of a storing device. The method continues with the processing module generating a new revision value for a currently revised version of the data element based on a current time of the computing device and comparing the current time of the new revision value with the current time of the most current revision value. When the current time of the new revision value precedes the current time of the most current revision value, the method continues with the processing module adjusting the new revision value to produce an adjusted revision value and facilitating storage of the currently revised version of the data element having the adjusted revision value.

First claim

Opening claim text (preview).

What is claimed is: 1. A storage unit (SU) comprising: a clock; an interface configured to interface and communicate with a distributed storage network (DSN); memory that stores operational instructions; and a processing module operably coupled to the interface and to the memory, wherein the processing module, when operable within the SU based on the operational instructions, is configured to: store at least one encoded data slice (EDS) of a set of encoded data slices (EDSs) associated with a data object, wherein the data object is segmented into a plurality of data segments, wherein a data segment of the plurality of data segments is dispersed error encoded in accordance with dispersed error encoding parameters to produce the set of EDSs, wherein a threshold number of EDSs are needed to recover the data segment; generate, based on a revision level request, a most current revision value for a data element, wherein a revision value of the data element is based on a current time of the clock, wherein the data element including a data segment that is associated with the data object; transmit the most current revision value for the data element to a computing device via the DSN; and when a current time of a new revision value for a currently revised version of the data element as generated by the computing device based on another current time of another clock of the computing device precedes a current time of the most current revision value based on the clock; receive the currently revised version of the data element having an adjusted revision value from the computing device via the DSN, wherein the adjusted revision value having an effective current time that succeeds the current time of the most current revision value; and store the currently revised version of the data element having the adjusted revision value. 2. The SU of claim 1 , wherein the processing module, when operable within the SU based on the operational instructions, is further configured to: receive the currently revised version of the data element having the adjusted revision value from the computing device via the DSN including to receive at least one other EDSs of another set of EDSs that is generated by the computing device dispersed error encoding another data segment, wherein the threshold number of EDSs of the another set of EDSs are needed to recover the another data segment. 3. The SU of claim 1 , wherein the processing module, when operable within the SU based on the operational instructions, is further configured to: when the current time of the new revision value for the currently revised version of the data element as generated by the computing device based on the another current time of the another clock of the computing device succeeds the current time of the most current revision value based on the clock; receive the currently revised version of the data element having the new revision value from the computing device via the DSN; and store the currently revised version of the data element having the new revision value. 4. The SU of claim 1 , wherein the processing module, when operable within the SU based on the operational instructions, is further configured to: receive the revision level request from the computing device via the DSN; generate a response to the revision level request; and transmit the response to the revision level request to the computing device via the DSN to be used, at least in part, by the computing device to determine the current time of the most current revision value. 5. The SU of claim 1 , wherein the set of EDSs are distributedly stored in a plurality of storage units (SUs) that includes the SU. 6. The SU of claim 1 , wherein the SU is located at a first location that is remotely located from at least one other SU that is located at a second location within the DSN and that stores at least one other EDS of the set of EDSs associated with the data object. 7. The SU of claim 1 , wherein the computing device includes a portable computing device, a social networking device, a gaming device, a cell phone, a smart phone, a personal digital assistant, a digital music player, a digital video player, a laptop computer, a handheld computer, a video game controller, a fixed computing device, a personal computer, a computer server, a cable, set-top box, a satellite receiver, a television set, a printer, a fax machine, home entertainment equipment, or a video game console. 8. The SU of claim 1 , wherein the DSN includes at least one of a wireless communication system, a wire lined communication system, a non-public intranet system, a public internet system, a local area network (LAN), or a wide area network (WAN). 9. A storage unit (SU) comprising: a clock; an interface configured to interface and communicate with a distributed storage network (DSN); memory that stores operational instructions; and a processing module operably coupled to the interface and to the memory, wherein the processing module, when operable within the SU based on the operational instructions, is configured to: store at least one encoded data slice (EDS) of a set of encoded data slices (EDSs) associated with a data object, wherein the set of EDSs are distributedly stored in a plurality of storage units (SUs) that includes the SU, wherein the data object is segmented into a plurality of data segments, wherein a data segment of the plurality of data segments is dispersed error encoded in accordance with dispersed error encoding parameters to produce the set of EDSs, wherein a threshold number of EDSs are needed to recover the data segment; receive a revision level request from a computing device via the DSN; generate, based on the revision level request, a most current revision value for a data element, wherein a revision value of the data element is based on a current time of the clock, wherein the data element including a data segment that is associated with the data object; transmit the most current revision value for the data element to the computing device via, the DSN in response to the revision level request; and when a current time of a new revision value, for a currently revised version of the data element as generated by the computing device based on another current time of another clock of the computing device precedes a current time of the most current revision value based on the clock; receive the currently revised version of the data element having an adjusted revision value from the computing device via the DSN, wherein the adjusted revision value having an effective current time that succeeds the current time of the most current revision value; and store the currently revised version of the data element having the adjusted revision value; when the current time of the new revision value for the currently revised version of the data element as generated by the computing device based on the another current time of the another clock of the computing device succeeds the current time of the most current revision value based on the clock; receive the currently revised version of the data element having the new revision value from the computing device via the DSN; and store the currently revised version of the data element having the new revision value. 10. The SU of claim 9 , wherein the processing module, when operable within the SU based on the operational instructions, is further configured to: receive the currently revised version of the data element having the adjusted revision value from the computing device via the DSN including to receive at least one other EDSs of another set of EDSs that is generated by the computing device dispersed error encoding another data segment, wherein the threshold number o

Assignees

Inventors

Classifications

  • Transmit or communication errors · CPC title

  • Parity data used in redundant arrays of independent storages, e.g. in RAID systems · CPC title

  • Replication mechanisms · CPC title

  • Timestamp · CPC title

  • in transactions (updating of structured data in databases G06F16/23) · 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 US9880902B2 cover?
A method begins by a processing module of a computing device receiving a most current revision value for a data element, where a revision value for the data element is generated based on a current time of a storing device. The method continues with the processing module generating a new revision value for a currently revised version of the data element based on a current time of the computing d…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F11/1443. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jan 30 2018 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 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).