Hosted file sync with stateless sync nodes

US10440106B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10440106-B2
Application numberUS-201514922179-A
CountryUS
Kind codeB2
Filing dateOct 25, 2015
Priority dateSep 14, 2015
Publication dateOct 8, 2019
Grant dateOct 8, 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.

Disclosed herein is a system and method to synchronize files from a hosted file system where the client endpoint devices have direct access to the files stored on a hosted file store. When the client desires to synchronize with the files stored on the hosted file store the process identifies a sync role that can process the request. The particular sync role does not need to maintain state with the client device or the file store. The state necessary for the processing of the synchronization process is maintained separate from the sync role such that any sync role in the system can pick up the requests and process the requests. Once the role has been selected the synchronization process proceeds as normal. As state is not maintained by the sync role multiple roles can process the request or two roles can handle different portions of the process.

First claim

Opening claim text (preview).

The invention claimed is: 1. A method comprising: synchronizing a set of files and/or folders between a client device and a remote file server, via a sync node, and storing a synchronization state of the synchronizing by the sync node within a runtime state store managed independent of the sync node by a host service; receiving, by the host service from the client device, a sync request for synchronizing the set of files and/or folders between the client device and the remote file store; selecting, by the service, one or more stateless sync nodes from among a plurality of stateless sync nodes of the host service, for resuming synchronizing the set of files and/or folders between the client device and the remote file server, wherein the one or more stateless sync nodes do not maintain a synchronization state between the client device and the remote file store for the set of files and/or folders; transmitting, by the host service, the synchronization state of the set of files and/or folders of the synchronizing performed by the sync node from the runtime state store to the one or more stateless sync nodes; continuing synchronizing, by the one or more stateless sync nodes, the set of files and/or folders based on the synchronization state provided by the host service from the runtime state store, where the continuing of the synchronizing results in one or more changes to the client device and/or the remote file store; and committing, by the service, the one or more changes. 2. The method of claim 1 wherein the method further comprises determining whether the sync request can be processed based on whether the client device is authorized to access the file store. 3. The method of claim 1 , further comprising identifying, by the host service, a long-running sync task included in the continuing of the synchronizing, and offloading the identified long-running sync task from the one or more stateless sync nodes to a background node of the host service is-configured for executing the long running sync task. 4. The method of claim 1 further comprising sharding a task of the sync request when a size of the task exceeds a threshold size. 5. The method of claim 4 wherein the selecting comprises selecting a plurality of stateless sync nodes of the host service and distributing processing of the shards among the plurality of selected stateless sync nodes such that each selected stateless sync node processes at least a respective shard of the sync request. 6. The method of claim 1 wherein the one or more stateless sync nodes are selected from among the plurality of stateless sync nodes of the service based on a round robin approach. 7. The method of claim 1 wherein the one or more stateless sync nodes are selected based upon a usage level for each of the stateless sync nodes among the plurality of stateless sync nodes. 8. A computing device comprising: memory that is coupled to at least one hardware computing device and that includes computer executable instructions that, based on execution by the at least one hardware computing device, configure a service to perform actions comprising: synchronizing a set of files and/or folders between a client device and a remote file server, via a sync node, and storing a synchronization state of the synchronizing by the sync node within a runtime state store managed independent of the sync node by a host service; receiving, by the host service from the client device, a sync request for synchronizing the set of files and/or folders between the client device and the remote file store; selecting, by the host service, one or more stateless sync nodes from among a plurality of stateless sync nodes of the host service, for synchronizing the set of files and/or folders between the client device and the remote file server, wherein the one or more stateless sync nodes do not maintain a synchronization state between the client device and the remote file store for the set of files and/or folders; transmitting, by the host service, the synchronization state of the set of files and/or folders of the synchronizing performed by the sync node from the runtime state store to the one or more stateless sync nodes; continuing synchronizing, by the one or more stateless sync nodes, the set of files and/or folders based on the synchronization state provided by the host service from the runtime state store, where the continuing of the synchronizing results in one or more changes to the client device and/or the remote file store; and committing, by the service, the one or more changes. 9. The computing device of claim 8 wherein the actions further comprise determining whether the sync request can be processed based on whether the client device is authorized to access the file store. 10. The computing device of claim 8 wherein the actions further comprises identifying, by the host service, a long-running sync task included in the continuing of the synchronizing, and offloading the identified long-running sync task from the one or more stateless sync nodes to a background node of the host service is configured for executing the long running sync task. 11. The computing device of claim 8 wherein a plurality of stateless sync nodes of the service are each configured to process at least a shard of the sync request. 12. The computing device of claim 8 wherein the one or more stateless sync nodes are selected from among the plurality of stateless sync nodes of the service based upon a usage level for each of the plurality of stateless sync nodes. 13. The computing device of claim 8 , wherein the actions further comprise sharding a task of the sync request into shards when a size of the task exceeds a threshold size, and distributing processing of the shards among a plurality of selected stateless sync nodes such that each selected stateless sync node processes at least a respective shard of the sync request. 14. A non-transitory computer-readable medium storing program instructions which when executed by a processor cause a computer to perform a method comprising: synchronizing a set of files and/or folders between a client device and a remote file server, via a sync node, and storing a synchronization state of the synchronizing by the sync node within a runtime state store managed independent of the sync node by a host service; receiving, by the host service from the client device, a sync request for synchronizing the set of files and/or folders between the client device and the remote file store; selecting, by the host service, one or more stateless sync nodes from among a plurality of stateless sync nodes of the host service, for synchronizing the set of files and/or folders between the client device and the remote file server, wherein the one or more stateless sync nodes do not maintain a synchronization state between the client device and the remote file store for the set of files and/or folders; transmitting, by the host service, the synchronization state of the set of files and/or folders of the synchronizing performed by the sync node from the runtime state store to the one or more stateless sync nodes; continuing synchronizing, by the one or more stateless sync nodes, the set of files and/or folders based on the synchronization state provided by the host service from the runtime state store, where the continuing of the synchronizing results in one or more changes to the client device and/or the remote file store; and committing, by the service, the one or more changes. 15. The non-transitory computer-readable medium of claim 14 where the method further comprises determining whether the sync reques

Assignees

Inventors

Classifications

  • Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes · CPC title

  • Versioning file systems, temporal file systems, e.g. file system supporting different historic versions of files · CPC title

  • Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor · CPC title

  • Updates performed during online database operations; commit processing · CPC title

  • between a Database Management System and a front-end application · 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 US10440106B2 cover?
Disclosed herein is a system and method to synchronize files from a hosted file system where the client endpoint devices have direct access to the files stored on a hosted file store. When the client desires to synchronize with the files stored on the hosted file store the process identifies a sync role that can process the request. The particular sync role does not need to maintain state with …
Who is the assignee on this patent?
Microsoft Technology Licensing Llc
What technology area does this patent fall under?
Primary CPC classification H04L67/1095. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Oct 08 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 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).