×

Accelerating transfer protocols

  • US 9,917,894 B2
  • Filed: 08/06/2014
  • Issued: 03/13/2018
  • Est. Priority Date: 08/06/2014
  • Status: Active Grant
First Claim
Patent Images

1. A method executed by a client device comprising a processor and memory, the method comprising:

  • identifying a fingerprint for a designated data chunk by applying a hash function to the designated data chunk, the designated data chunk being determined by parsing a data stream at the client device to identify a plurality of data chunks, wherein the designated data chunk is determined via a rolling hash parsing technique operable to generate at least some identical chunks when parsing different but overlapping data streams, the data stream generated at the client device via a first network storage protocol;

    determining whether a data chunk associated with the fingerprint is stored at a networked storage system by transmitting the fingerprint to the networked storage system via a network, wherein data chunks are stored at the networked storage system according to a second network storage protocol, wherein the networked storage system parses data streams into data chunks via the rolling hash parsing technique used by the client device and the networked storage system determines fingerprints for data chunks using the hash function used by the client device;

    responsive to a determination that a data chunk associated with the fingerprint is stored at the networked storage system, transmitting to a virtual file system of the networked storage system, a block map update information for updating a block map at the networked storage system, wherein the block map update information includes a first block map entry that points to the data chunk associated with the fingerprint that is stored at the networked storage system; and

    when it is determined that a data chunk associated with the fingerprint is not stored at the networked storage system, transmitting the designated data chunk to the networked storage system for storage, along with a second block map update information including a second block map entry that points to the storage location of the transmitted designated data chunk.

View all claims
  • 23 Assignments
Timeline View
Assignment View
    ×
    ×