Redirecting host IO's at destination during replication

US9916202B1 · US · B1

Patent metadata
FieldValue
Publication numberUS-9916202-B1
Application numberUS-201514644482-A
CountryUS
Kind codeB1
Filing dateMar 11, 2015
Priority dateMar 11, 2015
Publication dateMar 13, 2018
Grant dateMar 13, 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 technique for providing access to a data object serving as a target of snapshot-shipping replication includes taking a system snap of the data object after completion of each of multiple snapshot-shipping updates. In response to a data storage system receiving an IO (input/output) request to read and/or write to the data object, a data storage system redirects the IO request to a previously generated system snap, so that the data storage system performs the operation specified in the IO request on the system snap rather than of the data object itself.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for processing IO (input/output) requests, the method comprising: performing, at a destination data storage system, multiple snapshot-shipping updates to a data object, each snapshot-shipping update applying a set of changes to the data object to bring the data object into a state that is content-consistent with that of a source object operated from a source data storage system, the snapshot-shipping updates performed at respective times to keep the data object substantially current with the source object as the source object changes over time; after performing each snapshot-shipping update to the data object and before performing another one, generating a system snap of the data object, each system snap providing a point-in-time version of the data object that reflects a state of the data object after completion of the respective snapshot-shipping update; and upon receiving an IO request directed to the data object for performing a read operation on the data object, redirecting the IO request to a previously generated system snap, so that the destination data storage system performs the read operation on the previously generated system snap, wherein the method further comprises receiving a second IO request directed to the data object for performing a second read operation on the data object; and, in response to the destination data storage system not being in a process of performing any of the snapshot-shipping updates when the second IO request is received, directing the second IO request to the data object for performing the second read operation on the data object, wherein redirecting the IO request to the previously generated system snap is performed in response to the destination data storage system being in the process of performing one of the snapshot-shipping updates when the IO request is received, wherein the data object is realized in a base file stored in a file system of the destination data storage system, wherein each system snap is a snap of the base file and is itself a file in the file system, wherein the method further comprises storing, by the destination data storage system, a data element that identifies a file to which to direct IO requests directed to the data object, wherein redirecting the IO request to the previously generated system snap includes interrogating the data element and identifying, from the data element, a system snap file as the file to which to direct the IO request, wherein directing the second IO request to the data object includes interrogating the data element and identifying, from the data element, the base file as the file to which to direct the second IO request to perform the second read operation, wherein each snapshot-shipping update has a beginning and an end, and wherein the method further comprises: detecting the beginning of a snapshot-shipping update on the base file; in response to detecting the beginning of the snapshot-shipping update on the base file, setting the data element to identify a system snap file as the file to which to direct IO requests detecting the end of a snapshot-shipping update on the base file; and in response to detecting the end of the snapshot-shipping update on the base file, setting the data element to identify the base file as the file to which to direct IO requests. 2. The method of claim 1 , further comprising, after taking each system snap of the data object, destroying any previously-taken system snap of the data object from the file system. 3. The method of claim 1 , wherein the base file provides a file-based realization of one of (i) a LUN, (ii) a file system, or (iii) a VVol. 4. A data storage system, comprising control circuitry that includes a set of processing units coupled to memory, the control circuitry constructed and arranged to: perform, at a destination data storage system, multiple snapshot-shipping updates to a data object, each snapshot-shipping update applying a set of changes to the data object to bring the data object into a state that is content-consistent with that of a source object operated from a source data storage system, the snapshot-shipping updates performed at respective times to keep the data object substantially current with the source object as the source object changes over time; after performing each snapshot-shipping update to the data object and before performing another one, generate a system snap of the data object, each system snap providing a point-in-time version of the data object that reflects a state of the data object after completion of the respective snapshot-shipping update; and upon receiving an IO (input/output) request directed to the data object for performing a read operation on the data object, redirect the IO request to a previously generated system snap, so that the destination data storage system performs the read operation on the previously generated system snap, wherein the memory is constructed and arranged to (i) store a file system including multiple files, (ii) realize the data object as a base file of a file system and snaps thereof in respective other files of the file system, and (iii) store a data element that identifies a file in the file system to which to direct IO requests in response to the data storage system receiving IO requests directed to the data object, wherein each snapshot-shipping update has a beginning and an end and wherein the control circuitry is further constructed and arranged to: detect the beginning of each snapshot-shipping update on the base file; in response to detecting the beginning of each snapshot-shipping update on the base file, set the data element to identify a system snap file as the file to which to direct IO requests directed to the data object; detect the end of each snapshot-shipping update on the base file; in response to detecting the end of each snapshot-shipping update on the base file, set the data element to identify the base file as the file to which to direct IO requests directed to the data object; and in response to the data storage system receiving each of multiple IO requests directed to the data object, (a) interrogate the data element, (b) identify, from the data element, the file to which to direct the respective IO request, and (c) perform the operation specified by the respective IO request on the file identified in the data element. 5. The data storage system of claim 4 , wherein the base file provides a file-based realization of one of (i) a LUN, (ii) a file system, or (iii) a VVol. 6. A computer-program product including a set of non-transitory, computer-readable media including instructions which, when executed by a set of processing units of a destination data storage system, cause the set of processing units to perform a method for generating snaps, the method comprising: performing, at a destination data storage system, multiple snapshot-shipping updates to a data object, each snapshot-shipping update applying a set of changes to the data object to bring the data object into a state that is content-consistent with that of a source object operated from a source data storage system, the snapshot-shipping updates performed at respective times to keep the data object substantially current with the source object as the source object changes over time; after performing each snapshot-shipping update to the data object and before performing another one, generating a system snap of the data object, each system snap providing a point-in-time version of the data object that reflects a state of the data object after completion of the respective snapshot-shipping update; and upon receiving an IO (input/output) request directed to the data object for performing a read operation on the data object, redirecting the IO request to a previously

Assignees

Inventors

Classifications

  • Redundant storage control functionality · CPC title

  • Using snapshots, i.e. a logical point-in-time copy of the data · CPC title

  • while ensuring consistency · CPC title

  • for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS] · CPC title

  • Asynchronous techniques · 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 US9916202B1 cover?
A technique for providing access to a data object serving as a target of snapshot-shipping replication includes taking a system snap of the data object after completion of each of multiple snapshot-shipping updates. In response to a data storage system receiving an IO (input/output) request to read and/or write to the data object, a data storage system redirects the IO request to a previously g…
Who is the assignee on this patent?
Emc Corp, Emc Ip Holding Co 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 Mar 13 2018 00:00:00 GMT+0000 (Coordinated Universal Time) (B1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 2 related publications on this page (citations in our corpus or others sharing the same primary CPC).