This disclosure relates to computing systems and related devices and methods, and, more particularly, to a method and apparatus for enabling access to snapshot storage volumes using nocopy undefined thin devices.
The following Summary and the Abstract set forth at the end of this document are provided herein to introduce some concepts discussed in the Detailed Description below. The Summary and Abstract sections are not comprehensive and are not intended to delineate the scope of protectable subject matter, which is set forth by the claims presented below.
All examples and features mentioned below can be combined in any technically possible way.
A thin device (TDev) is tagged to identify the TDev as being used to access snapshot data on the storage system. If a snapshot is to be shipped to a cloud repository, the tagged TDev is linked to the snapshot, and mounted to a cloud tethering subsystem. When the tagged TDev is linked to the cloud tethering subsystem, the snapshot subsystem reads the thin device tag and, if the thin device is tagged, selectively does not execute a define process on the tagged thin device. By not executing the define process, linking the TDev requires generation of no metadata, such that the tracks of the thin device do not contain metadata pointers to locations of the snapshot data on the storage system. When data read operations are issued by the cloud tethering subsystem on the tagged thin device, the snapshot subsystem executes a one-time identification of the location of the requested data, without creating metadata for the thin device. A write to source will cause the old data to be saved to a new location within the source storage resource pool, but because the TDev is undefined, a private copy is not required even if the snapshot is created in a different storage resource pool.
Aspects of the inventive concepts will be described as being implemented in a storage system 100 connected to a host computer 102. Such implementations should not be viewed as limiting. Those of ordinary skill in the art will recognize that there are a wide variety of implementations of the inventive concepts in view of the teachings of the present disclosure.
Some aspects, features and implementations described herein may include machines such as computers, electronic components, optical components, and processes such as computer-implemented procedures and steps. It will be apparent to those of ordinary skill in the art that the computer-implemented procedures and steps may be stored as computer-executable instructions on a non-transitory tangible computer-readable medium. Furthermore, it will be understood by those of ordinary skill in the art that the computer-executable instructions may be executed on a variety of tangible processor devices, i.e., physical hardware. For ease of exposition, not every step, device or component that may be part of a computer or data storage system is described herein. Those of ordinary skill in the art will recognize such steps, devices and components in view of the teachings of the present disclosure and the knowledge generally available to those of ordinary skill in the art. The corresponding machines and processes are therefore enabled and within the scope of the disclosure.
The terminology used in this disclosure is intended to be interpreted broadly within the limits of subject matter eligibility. The terms “logical” and “virtual” are used to refer to features that are abstractions of other features, e.g. and without limitation, abstractions of tangible features. The term “physical” is used to refer to tangible features, including but not limited to electronic hardware. For example, multiple virtual computing devices could operate simultaneously on one physical computing device. The term “logic” is used to refer to special purpose physical circuit elements, firmware, and/or software implemented by computer instructions that are stored on a non-transitory tangible computer-readable medium and implemented by multi-purpose tangible processors, and any combinations thereof.
The storage system 100 includes a plurality of compute nodes 1161-1164, possibly including but not limited to storage servers and specially designed compute engines or storage directors for providing data storage services. In some embodiments, pairs of the compute nodes, e.g. (1161-1162) and (1163-1164), are organized as storage engines 1181 and 1182, respectively, for purposes of facilitating failover between compute nodes 116 within storage system 100. In some embodiments, the paired compute nodes 116 of each storage engine 118 are directly interconnected by communication links 120. As used herein, the term “storage engine” will refer to a storage engine, such as storage engines 1181 and 1182, which has a pair of (two independent) compute nodes, e.g. (1161-1162) or (1163-1164). A given storage engine 118 is implemented using a single physical enclosure and provides a logical separation between itself and other storage engines 118 of the storage system 100. A given storage system 100 may include one storage engine 118 or multiple storage engines 118.
Each compute node, 1161, 1162, 1163, 1164, includes processors 122 and a local volatile memory 124. The processors 122 may include a plurality of multi-core processors of one or more types, e.g. including multiple CPUs, GPUs, and combinations thereof. The local volatile memory 124 may include, for example and without limitation, any type of RAM. Each compute node 116 may also include one or more front end adapters 126 for communicating with the host computer 102. Each compute node 1161-1164 may also include one or more back-end adapters 128 for communicating with respective associated back-end drive arrays 1301-1304, thereby enabling access to managed drives 132. A given storage system 100 may include one back-end drive array 130 or multiple back-end drive arrays 130.
In some embodiments, managed drives 132 are storage resources dedicated to providing data storage to storage system 100 or are shared between a set of storage systems 100. Managed drives 132 may be implemented using numerous types of memory technologies for example and without limitation any of the SSDs and HDDs mentioned above. In some embodiments the managed drives 132 are implemented using NVM (Non-Volatile Memory) media technologies, such as NAND-based flash, or higher-performing SCM (Storage Class Memory) media technologies such as 3D XPoint and ReRAM (Resistive RAM). Managed drives 132 may be directly connected to the compute nodes 1161-1164, using a PCIe (Peripheral Component Interconnect Express) bus or may be connected to the compute nodes 1161-1164, for example, by an IB (InfiniBand) bus or fabric.
In some embodiments, each compute node 116 also includes one or more channel adapters 134 for communicating with other compute nodes 116 directly or via an interconnecting fabric 136. An example interconnecting fabric 136 may be implemented using InfiniBand. Each compute node 116 may allocate a portion or partition of its respective local volatile memory 124 to a virtual shared “global” memory 138 that can be accessed by other compute nodes 116, e.g. via DMA (Direct Memory Access) or RDMA (Remote Direct Memory Access). Shared global memory 138 will also be referred to herein as the cache of the storage system 100.
The storage system 100 maintains data for the host applications 104 running on the host computer 102. For example, host application 104 may write data of host application 104 to the storage system 100 and read data of host application 104 from the storage system 100 in order to perform various functions. Examples of host applications 104 may include but are not limited to file servers, email servers, block servers, and databases.
Logical storage devices are created and presented to the host application 104 for storage of the host application 104 data. For example, as shown in
The host device 142 is a local (to host computer 102) representation of the production device 140. Multiple host devices 142, associated with different host computers 102, may be local representations of the same production device 140. The host device 142 and the production device 140 are abstraction layers between the managed drives 132 and the host application 104. From the perspective of the host application 104, the host device 142 is a single data storage device having a set of contiguous fixed-size LBAs (Logical Block Addresses) on which data used by the host application 104 resides and can be stored. However, the data used by the host application 104 and the storage resources available for use by the host application 104 may actually be maintained by the compute nodes 1161-1164 at non-contiguous addresses (tracks) on various different managed drives 132 on storage system 100.
In some embodiments, the storage system 100 maintains metadata that indicates, among various things, mappings between the production device 140 and the locations of extents of host application data in the virtual shared global memory 138 and the managed drives 132. In response to an IO (Input/Output command) 146 from the host application 104 to the host device 142, the hypervisor/OS 112 determines whether the IO 146 can be serviced by accessing the host volatile memory 106. If that is not possible then the IO 146 is sent to one of the compute nodes 116 to be serviced by the storage system 100.
There may be multiple paths between the host computer 102 and the storage system 100, e.g. one path per front end adapter 126. The paths may be selected based on a wide variety of techniques and algorithms including, for context and without limitation, performance and load balancing. In the case where IO 146 is a read command, the storage system 100 uses metadata to locate the commanded data, e.g. in the virtual shared global memory 138 or on managed drives 132. If the commanded data is not in the virtual shared global memory 138, then the data is temporarily copied into the virtual shared global memory 138 from the managed drives 132 and sent to the host application 104 by the front end adapter 126 of one of the compute nodes 1161-1164. In the case where the IO 146 is a write command, in some embodiments the storage system 100 copies a block being written into the virtual shared global memory 138, marks the data as dirty, and creates new metadata that maps the address of the data on the production device 140 to a location to which the block is written on the managed drives 132. The virtual shared global memory 138 may enable the production device 140 to be reachable via all of the compute nodes 1161-1164 and paths, although the storage system 100 can be configured to limit use of certain paths to certain production devices 140 (zoning).
Not all volumes of data on the storage system are accessible to host computer 104. When a volume of data is to be made available to the host computer, a logical storage volume, also referred to herein as a TDev (Thin Device), is linked to the volume of data, and presented to the host computer 104 as a host device 142. For example, to protect the production device 140 against loss of data, a snapshot (point in time) copy of the production device 140 may be created and maintained by the storage system 100. If the host computer 104 needs to obtain access to the snapshot copy, for example for data recovery, the snapshot copy may be linked to a logical storage volume (Tdev) and presented to the host computer 104 as a host device 142. The host computer 102 can then execute read/write IOs on the Tdev to access the data of the snapshot copy.
As shown in
Snapshot subsystem 156, in some embodiments, is configured to create “snapshots” of a volume of data such as production volume 140. A “snapshot,” as that term is used herein, is a copy of a volume of data as that volume existed at a particular point in time. A snapshot of a production device 140, accordingly, is a copy of the data stored on the production device 140 as the data existed at the point in time when the snapshot was created. A snapshot can be either target-less (not linked to a TDev) or may be linked to a target TDev when created. When a snapshot of a production volume is created, the snapshot may include all of the data of the production volume, or only the changes to the production volume that have occurred since the previous snapshot was taken.
In some embodiments, a user will set policies on a group of LUNs referred to as a storage group. These policies define the frequency of the snapshot, the retention period of the snapshots, and a cloud provider where the snapshots are to be stored. The frequency tells the snapshot subsystem 156 in the storage array 130 to create a snapshot against all the LUNs in a storage group at a regular cadence, as defined by the user. The sets of snapshots taken against a storage group are referred to as snapsets. The retention period defines the age of the snapshot when it should be deleted. The cloud provider tells the storage array the identity of the object repository where the snapshots need to be shipped.
The cloud tethering subsystem 154 is responsible for managing transmission of snapshots from the storage system 100 to an external cloud repository 162 (See
In connection with transmitting a snapshot to a cloud repository, a TDev is linked to the snapshot, and presented to the cloud tethering subsystem as a host device 142. The cloud tethering subsystem 154 then issues read operations on the snapshot, and sends the data to the cloud repository. To access storage resources of the storage system 100, the cloud tethering subsystem 154 issues read and write 10 operations 146, which are received by front end adapter 126 of the storage system, and processed by the front end adapter 126.
The cloud tethering subsystem 154 is the primary data mover that is responsible for moving 10 traffic between the back-end drive array 130 in the storage system 100 and the remote cloud repository 162. Unfortunately, shipment of the snapshot copies 164 from the storage system 100 to the cloud repository 162 by the cloud tethering subsystem 154 can be metadata intensive.
For example, conventionally, when a snapshot was to be moved to a cloud repository, a TDev would be linked to the snapshot. As part of this process, the snapshot subsystem would execute a “define” process, which would scan the entire target device, and cause the pointers of each track on the TDev to identify the location of the appropriate backend data of the snapshot. This provides access to the snapshot using the TDev, but consumes CPU resources and requires track level metadata to be generated for the TDev, as the TDev attached to the snapshot is “defined”. Since the metadata tables have a finite capacity, generating additional metadata is undesirable. As used herein, the term “define” is used to refer to a process that changes the pointers of tracks of a target linked volume to identify the location of the backend data of the source volume.
Further, if the TDev is provisioned from a different SRP (Storage Resource Pool) than the source, the TDev will also need its own private allocations when there are new writes to the source volume, and the older data needs to be saved. For example, if the source is implemented using drives 132 in a first SRP, and the snapshot is implemented using drives 132 in a second SRP, a write to the source will require an allocation of storage on one of the drives 132 in the first SRP to save the old data. If the snapshot is created in a different storage resource pool, a private copy of the old data would also be required in the snapshot storage resource pool. Accordingly, a write on source would results in two allocations—one for the snapshot and one for the TDev. These behaviors cause additional use of system metadata and backend storage space.
According to some embodiments, when the donor TDev is linked to the snapshot it remains undefined, such that the snapshot subsystem 156 does not execute a define process on the donor TDev, and accordingly the tracks of the donor TDev do not point to the backend tracks of the snapshot 164 before the cloud tethering subsystem 154 issues read operations on the donor TDev. In some embodiments, the cloud tethering subsystem uses a set of TDev that are tagged. The tag identifies the TDev as being used by the cloud tethering subsystem to move snapshots to a cloud repository. When a TDev is linked to a snapshot, the snapshot subsystem 156 reads the tag, and if the TDev is tagged, the snapshot subsystem does not run a define process on the TDev. This prevents metadata from being created in connection with movement of snapshots to the cloud repository. Because the tracks of the donor TDev are not defined, if a write on source occurs which causes the old data to be moved to a new track in the source storage resource pool, no private copy is required. Rather, if a read occurs, the snapshot subsystem will determine the current location of the old data at that point in time, hence eliminating the need for a private copy of the old data in the storage resource pool in which the snapshot resides.
The cloud tethering subsystem 154 executes read operations on the donor TDev 168 (
In some embodiments, the cloud tethering subsystem 154 implements a block LUN based snapshot shipping application, that ships sets of snapshots taken on a timeline to a heterogenous cloud repository 162 in object format. In some embodiments, the cloud tethering subsystem 154 is implemented as a Linux-based in-build container that is responsible for shipping the snapshots 164 to the cloud repository 162. The cloud snapshot shipping process generates cloud read traffic end to end within the storage system 100 where the cloud tethering subsystem 154 container is hosted, when the snapshot 164 is shipped to the cloud repository 162.
As shown in
In some embodiments, a designated set of TDevs (Thin Devices) are created for use by the cloud tethering subsystem 154 in connection with shipping data volumes to the cloud repository 162. These thin devices are tagged, for example, using a “CLOUD_DONOR_ACCESS_THIN_DEV” tag (Block 310).
In some embodiments, when a donor TDev is linked to a snapshot, the snapshot subsystem reads the tag of the donor TDev to determine whether a define process should be executed on the donor TDev. If the donor TDev is tagged, the snapshot subsystem does not execute the define process on the donor TDev, such that the tracks of the donor TDev remain undefined. Not executing the define process enables zero metadata to be generated in connection with linking the donor TDev to the snapshot, and also reduces the use of processor and other storage system resources.
When the cloud tethering subsystem 154 wants to ship the snapshot 164 to the cloud repository 162, it needs to access the snapshot 164. In some embodiments, the cloud tethering subsystem 154 sends a prepare call to the snapshot subsystem 156. As part of the prepare call, the cloud-tagged snapshot 164 is linked in nocopy mode to a donor TDev (block 315). In no-copy mode, the data of the snapshot is not actually copied to the donor TDev. The donor TDev world-wide number (WWN) is also shared with the cloud tethering subsystem 154, and the donor TDev is masked and mapped to the container of the cloud tethering subsystem 154. With the WWN of the donor TDev, the cloud tethering subsystem 154 can issue read operations on the donor TDev to cause the data of the snapshot to be shipped to the cloud repository 162 (see
When the donor TDev is linked to the snapshot, in some embodiments a determination is made by the snapshot subsystem as to whether the donor TDev is tagged (block 320). If the donor TDev is not tagged (a determination of NO at block 320), the snapshot subsystem executes a define process on the donor TDev to cause the tracks of the donor TDev to point to back-end allocations on storage array where the storage system data is being stored (block 325). If the donor TDev is tagged (a determination of YES at block 320), the snapshot subsystem does not execute the define process on the donor TDev, such that the presence of the tag prevents the snapshot subsystem from defining the tracks of the donor TDev (block 330). The process then continues to
As shown in
The snapshot subsystem 156 sends the data track number of one of the managed drives 132 where the data resides to the data services subsystem 158 (
In some embodiments, although the snapshot subsystem 156 does a one-time on-demand determination of the requested donor TDev track, this does not result in creation of metadata for the donor TDev. Rather, the location of the data is used directly by the data services subsystem 158, which uses the location information to move the requested data to the selected cache slot. At that point, the location of the requested data is discarded, and not stored in the donor TDev track. Accordingly, providing the location of the requested data by the snapshot subsystem does not result in creation of metadata associated with the donor TDev.
By leaving the tracks of the donor TDev undefined, this is not required, because the snapshot subsystem will simply determine the current location of the old data, on demand, and return the new location of the old data when requested. Accordingly, leaving the donor TDev as undefined, reduces the overall storage resources required to implement the snapshot within the storage system.
The methods described herein may be implemented as software configured to be executed in control logic such as contained in a CPU (Central Processing Unit) or GPU (Graphics Processing Unit) of an electronic device such as a computer. In particular, the functions described herein may be implemented as sets of program instructions stored on a non-transitory tangible computer readable storage medium. The program instructions may be implemented utilizing programming techniques known to those of ordinary skill in the art. Program instructions may be stored in a computer readable memory within the computer or loaded onto the computer and executed on computer's microprocessor. However, it will be apparent to a skilled artisan that all logic described herein can be embodied using discrete components, integrated circuitry, programmable logic used in conjunction with a programmable logic device such as a FPGA (Field Programmable Gate Array) or microprocessor, or any other device including any combination thereof. Programmable logic can be fixed temporarily or permanently in a tangible computer readable medium such as random-access memory, a computer memory, a disk drive, or other storage medium. All such embodiments are intended to fall within the scope of the present invention.
Throughout the entirety of the present disclosure, use of the articles “a” or “an” to modify a noun may be understood to be used for convenience and to include one, or more than one of the modified noun, unless otherwise specifically stated.
Elements, components, modules, and/or parts thereof that are described and/or otherwise portrayed through the figures to communicate with, be associated with, and/or be based on, something else, may be understood to so communicate, be associated with, and or be based on in a direct and/or indirect manner, unless otherwise stipulated herein.
Various changes and modifications of the embodiments shown in the drawings and described in the specification may be made within the spirit and scope of the present invention. Accordingly, it is intended that all matter contained in the above description and shown in the accompanying drawings be interpreted in an illustrative and not in a limiting sense. The invention is limited only as defined in the following claims and the equivalents thereto.
Number | Name | Date | Kind |
---|---|---|---|
7865596 | Grosner | Jan 2011 | B2 |
7873619 | Faibish | Jan 2011 | B1 |
7958199 | Ferrari | Jun 2011 | B2 |
8239584 | Rabe | Aug 2012 | B1 |
8332381 | Coudron | Dec 2012 | B1 |
8850145 | Haase | Sep 2014 | B1 |
8898402 | Strange | Nov 2014 | B1 |
8972340 | Haase | Mar 2015 | B1 |
9009437 | Bjornsson | Apr 2015 | B1 |
9047169 | Haase | Jun 2015 | B1 |
9063892 | Taylor | Jun 2015 | B1 |
9075755 | Haase | Jul 2015 | B1 |
9218138 | Haase | Dec 2015 | B1 |
9246996 | Brooker | Jan 2016 | B1 |
9384206 | Bono | Jul 2016 | B1 |
9460102 | Bono | Oct 2016 | B1 |
9503517 | Brooker | Nov 2016 | B1 |
9557925 | Natanzon | Jan 2017 | B1 |
9569569 | Colon | Feb 2017 | B1 |
9804993 | Brooker | Oct 2017 | B1 |
9823840 | Brooker | Nov 2017 | B1 |
9846544 | Bassov | Dec 2017 | B1 |
9893953 | Castelli | Feb 2018 | B1 |
9946569 | Beedu | Apr 2018 | B1 |
9965216 | Jaganathan | May 2018 | B1 |
10048885 | Bono | Aug 2018 | B1 |
10140039 | Baruch | Nov 2018 | B1 |
10154112 | Anthony | Dec 2018 | B1 |
10162597 | Bigman | Dec 2018 | B1 |
10216757 | Armangau | Feb 2019 | B1 |
10242011 | Basov | Mar 2019 | B1 |
10242012 | Basov | Mar 2019 | B1 |
10250679 | Natanzon | Apr 2019 | B1 |
10254970 | Martin | Apr 2019 | B1 |
10261717 | Martin | Apr 2019 | B1 |
10261944 | Armangau | Apr 2019 | B1 |
10387369 | Davenport | Aug 2019 | B1 |
10462012 | Rao | Oct 2019 | B1 |
10481794 | Castelli | Nov 2019 | B1 |
10482065 | Armangau | Nov 2019 | B1 |
10496601 | Natanzon | Dec 2019 | B1 |
10776317 | Veeraswamy | Sep 2020 | B1 |
10809932 | Armangau | Oct 2020 | B1 |
10831207 | Leung | Nov 2020 | B1 |
10911540 | Gunasekaran | Feb 2021 | B1 |
10929423 | Patwardhan | Feb 2021 | B1 |
20100042776 | Seo | Feb 2010 | A1 |
20100322255 | Hao | Dec 2010 | A1 |
20120124285 | Soran | May 2012 | A1 |
20130036128 | Ben-Tsion | Feb 2013 | A1 |
20130080728 | Cashman | Mar 2013 | A1 |
20130275447 | Ben-Tsion | Oct 2013 | A1 |
20140156877 | Tylik | Jun 2014 | A1 |
20140236898 | Hankins | Aug 2014 | A1 |
20150242294 | Lapierre | Aug 2015 | A1 |
20150248418 | Bhardwaj | Sep 2015 | A1 |
20150324713 | Haas | Nov 2015 | A1 |
20150358421 | Gupta | Dec 2015 | A1 |
20160117226 | Hetrick | Apr 2016 | A1 |
20160134599 | Ross | May 2016 | A1 |
20160349992 | Basak | Dec 2016 | A1 |
20170161286 | Eda | Jun 2017 | A1 |
20170324813 | Jain | Nov 2017 | A1 |
20170329552 | Baldwin | Nov 2017 | A1 |
20170351615 | Agombar | Dec 2017 | A1 |
20180004676 | Imazaki | Jan 2018 | A1 |
20180081548 | Barzik | Mar 2018 | A1 |
20180124157 | Gao | May 2018 | A1 |
20180129443 | Karve | May 2018 | A1 |
20180129520 | Zhang | May 2018 | A1 |
20180152278 | Chen | May 2018 | A1 |
20180288137 | Veeramani | Oct 2018 | A1 |
20190026466 | Krasser | Jan 2019 | A1 |
20190155512 | Tenner | May 2019 | A1 |
20190271157 | Baggs | Sep 2019 | A1 |
20190317682 | Li | Oct 2019 | A1 |
20190334884 | Ross | Oct 2019 | A1 |
20190340292 | Chandrashekhara | Nov 2019 | A1 |
20200121258 | Zhu | Apr 2020 | A1 |
20210036714 | Martin | Feb 2021 | A1 |
20210081432 | Grunwald | Mar 2021 | A1 |
20210133098 | Wilson | May 2021 | A1 |
20210133114 | Moyer | May 2021 | A1 |
20210133115 | Wilson | May 2021 | A1 |
20210141694 | Cope | May 2021 | A1 |
20210208799 | Wilcock | Jul 2021 | A1 |
20210240657 | Kumar | Aug 2021 | A1 |
20210263508 | Wang | Aug 2021 | A1 |
20210294701 | Satoyama | Sep 2021 | A1 |
20210374095 | Wilson | Dec 2021 | A1 |
20220067549 | Vokaliga | Mar 2022 | A1 |
Number | Date | Country | |
---|---|---|---|
20220066653 A1 | Mar 2022 | US |