EP3454231A1 - Remotely mounted file system with stubs - Google Patents
Remotely mounted file system with stubs Download PDFInfo
- Publication number
- EP3454231A1 EP3454231A1 EP18192697.3A EP18192697A EP3454231A1 EP 3454231 A1 EP3454231 A1 EP 3454231A1 EP 18192697 A EP18192697 A EP 18192697A EP 3454231 A1 EP3454231 A1 EP 3454231A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- data
- node
- snapshot
- tree
- snapshot tree
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 230000004044 response Effects 0.000 claims abstract description 10
- 238000000034 method Methods 0.000 claims description 57
- 238000004590 computer program Methods 0.000 claims description 4
- 239000000543 intermediate Substances 0.000 description 244
- 238000010586 diagram Methods 0.000 description 46
- 230000008569 process Effects 0.000 description 43
- 230000014759 maintenance of location Effects 0.000 description 16
- 230000004048 modification Effects 0.000 description 9
- 238000012986 modification Methods 0.000 description 9
- 230000000737 periodic effect Effects 0.000 description 6
- 230000008859 change Effects 0.000 description 5
- 238000011084 recovery Methods 0.000 description 5
- 238000010367 cloning Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000007774 longterm Effects 0.000 description 3
- 239000007787 solid Substances 0.000 description 3
- 230000003442 weekly effect Effects 0.000 description 2
- 240000003293 Magnolia grandiflora Species 0.000 description 1
- 241000700605 Viruses Species 0.000 description 1
- 230000003362 replicative effect Effects 0.000 description 1
- 239000004557 technical material Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/11—File system administration, e.g. details of archiving or snapshots
- G06F16/128—Details of file system snapshots on the file-level, e.g. snapshot creation, administration, deletion
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/18—File system types
- G06F16/1873—Versioning file systems, temporal file systems, e.g. file system supporting different historic versions of files
Definitions
- a snapshot is the state of a storage entity (e.g., storage volume) at a particular point in time.
- a full snapshot of a storage entity may be composed of large amounts of data (e.g., terabytes, petabytes, etc.). Performing a full snapshot of a storage entity at frequent intervals (e.g., hourly, daily) requires large amounts of storage to store the snapshots. To reduce the amount of storage required, an incremental snapshot of the storage entity may be performed between full snapshots. An incremental snapshot includes the changes that have occurred to the storage entity since the previous (full or incremental) snapshot. However, mounting a volume that includes a full snapshot and several incremental snapshots may require large amounts of storage.
- the invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor.
- these implementations, or any other form that the invention may take, may be referred to as techniques.
- the order of the steps of disclosed processes may be altered within the scope of the invention.
- a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task.
- the term 'processor' refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
- Tree data structures may be used in organizing and storing large amounts of data. For example, a tree data structure is searched to retrieve a value stored in the tree data structure using a data key associated with the value. Often it is desirable to periodically archive the tree data structure to archive changes and provide fault tolerance. If the storage where the tree data structure is to be archived natively understands and supports tree data structures, it can be directly copied to the archive storage in a native format. However, many storage solutions do not natively support tree data structures. The storage solutions that natively support tree data structures are often costly and inefficient for use as an archive.
- the tree data structure is serialized into a data file comprising a flat set of data.
- the serialized data file may be encoded in a manner that allows the serialized data file to be utilized to reconstruct a desired portion of the tree data structure to obtain a data of interest from the serialized data file without the need to reconstruct the entire tree data structure.
- Serializing is a process by which a data file is generated to store data in a manner that mimics the structure of a tree data structure.
- the serialized data file may be encoded in a manner that allows the serialized data file to be utilized to reconstruct a desired portion of the tree data structure to obtain a data of interest from the serialized data file without the need to reconstruct the entire tree data structure.
- the serialized data file is a flat set of data comprised of a plurality of data blocks.
- a data block of the data file may correspond to a node of a tree data structure.
- the order of the data blocks of the serialized data file corresponds to an order of the tree data structure.
- a tree data structure may have a root node, a plurality of intermediate nodes, and a plurality of leaf nodes.
- the serialized data file first may store the root node, then the plurality of intermediate nodes, and then the plurality of leaf nodes.
- a first data block of the serialized data file may correspond to a root node of the tree data structure
- a second data block of the serialized data file may correspond to a first intermediate node of the tree data structure
- a third data block of the serialized data file may correspond to a second intermediate node of the tree data structure
- a fourth data block of the serialized data file may correspond to a first leaf node of the tree data structure
- ...and an nth data block of the serialized data file may correspond to the nth leaf node of the tree data structure.
- a node of the tree data structure may include a pointer to another node of the tree data structure.
- a data block of the serialized data file may be configured to store one or more file offsets to one or more data blocks corresponding to one or more corresponding nodes of the tree data structure.
- the first data block of the data file corresponding to the root node of the tree data structure may store a file offset to the second data block of the data file corresponding to an intermediate node of the tree data structure.
- a data block corresponding to a leaf node of the tree data structure may store archived file system data.
- a data block corresponding to a node of the tree data structure includes a file offset to a data block of a different serialized data file.
- Snapshot archive management is disclosed.
- File system data may be stored in a tree data structure comprised of one or more snapshot trees.
- a snapshot tree (e.g., Cohesity Snaptree) is based on a tree data structure and may include a root node, one or more intermediate nodes, and one or more leaf nodes associated with each intermediate node.
- the root node is the starting point of a snapshot tree and may include pointers to one or more other nodes.
- the root node includes an identifier that indicates a view with which the root node is associated.
- An intermediate node is a node to which another node points (e.g., root node, other intermediate node) and includes one or more pointers to other nodes.
- a snapshot tree may include one or more levels of intermediate nodes.
- a leaf node is a node at the bottom of a snapshot tree.
- a leaf node may be configured to store key-value pairs of file system data.
- a leaf node includes a pointer to another snapshot tree.
- Each node of the tree data structure includes an identifier of a snapshot tree that identifies a tree data structure with which the node is associated (e.g., TreeID).
- a snapshot of the file system data may be performed according to one or more backup policies.
- the backup policy may indicate when and how a snapshot of the system is to be performed.
- the snapshot of the system captures a view of the file system at a particular point in time.
- the view may be a current view or a snapshot view.
- a current view may represent a state of the file system that is up-to-date and capable of receiving one or more modifications to the snapshot tree that correspond to modifications to the file system data.
- a snapshot view may represent a state of the file system at a particular moment in time in the past and is not updated.
- the view of a snapshot may change from a current view to a snapshot view when a subsequent snapshot is performed.
- another root node is added to the tree data structure.
- a tree data structure may be utilized to organize and store data associated with a snapshot (e.g., stored in a snapshot tree).
- the tree data structure can be used to capture different versions of file system data at different moments in time.
- the tree data structure allows a chain of snapshot trees (i.e., different snapshot tree versions) to be linked together by allowing a node of a later version of a snapshot tree to reference a node of a previous version of a snapshot tree.
- a new root node may be created and the new root node includes the set of pointers included in the previous root node, that is, the new root node includes one or more pointers to an intermediate node or leaf node associated with a previous snapshot tree.
- the new root node includes a view identifier (e.g., TreeID) that is different than the view identifier (e.g., TreeID) of the previous root node.
- the view identifier associated with a node identifies a snapshot tree and view with which the node is associated.
- the previous root node is deleted after a snapshot is performed.
- the snapshot tree is traversed from the root node of the current view to the leaf node.
- the view identifier associated with each intermediate node is compared with the view identifier associated with the root node of the current view.
- the snapshot tree is traversed to the next node.
- the view identifier of the root node does not match the view identifier of the intermediate node, a shadow copy of the node with the non-matching view identifier is made.
- the shadow copy includes the same set of pointers as the copied node, but includes a view identifier to match the view identifier of the root node and a different node ID.
- the view identifier associated with the leaf node to be modified is compared with the view identifier associated with the root node of the current view, and a new leaf node is created.
- the new leaf node includes the modified value and a view identifier that matches the view identifier of the root node.
- a snapshot policy may indicate that a full snapshot or an incremental snapshot is to be performed and stored at a storage system.
- the full snapshot may provide a complete view of the snapshot tree at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot tree at the particular moment in time.
- An incremental snapshot may provide a partial view of the snapshot tree at a particular moment time.
- the incremental snapshot may store the difference between a snapshot and a previous snapshot and one or more pointers to one or more nodes associated with one or more previous snapshots.
- a snapshot may be archived to a remote storage system. Archiving a snapshot frees up storage that was used to store the snapshot.
- An archive may be used for data that is infrequently accessed (i.e., cold data).
- An archive may be used for data for which a loading penalty due to the need to retrieve the data from an archive will not hurt the performance of a system.
- An archive policy may indicate that the file system data is to be archived to a remote storage system, such as a cloud storage system or a cluster storage system.
- the archive policy may indicate that a full snapshot archive of the file system data and/or an incremental snapshot archive of the file system data is to be performed.
- a full snapshot archive is an archive of a full snapshot.
- An incremental snapshot archive is an archive of an incremental snapshot. It includes the nodes that represent the difference between a snapshot and a previous snapshot and one or more references to one or more nodes associated with one or more previous snapshots.
- a snapshot archive may include file system data and serialized snapshot tree data.
- File system data includes one or more data chunks that make up data of a file system.
- a version of file system data is comprised of one or more blocks that are segmented into one or more chunks of data, a chunk identifier is computed for each chunk of data, and the chunk identifiers are stored as file system metadata.
- the leaf nodes of a snapshot tree may store the file system metadata.
- a corresponding serialized snapshot tree data is archived to the cloud storage system or the cluster storage system.
- a serialized snapshot tree data stores the structure of the snapshot tree associated with the file system data as a flat set of data that is comprised of one or more blocks.
- Each block of the flat set of data corresponds to a node of the snapshot tree.
- the blocks that correspond to an intermediate node or a root node may include a file offset to another block of the serialized snapshot tree data or a file offset to another block of a different serialized snapshot tree data.
- a block that corresponds to a leaf node may include a file offset to a portion of the archived file system data.
- a request for data at a particular time may be received from a user.
- the snapshots associated with the data at the particular time may not be stored locally and the archived version of the snapshot may be retrieved to determine the data at the particular time.
- a view of the file system data at the particular time may be determined by retrieving the serialized snapshot tree data associated with the particular time and deserializing the serialized snapshot tree data associated with the particular time. Deserializing is a process by which at least a portion of a tree data structure is reproduced from a data file.
- one or more additional associated serialized snapshot tree data sets may be retrieved to determine the data at the particular time.
- the generated view reproduces a portion of or the entire tree data structure at the particular time.
- the requested data may be determined based on the view, retrieved from remote storage, and provided to the user.
- restoring the entire snapshot tree data structure and associated archived file contents at the particular time may be too expensive (e.g., requires large amounts of time and system resources) to because the entire serialized archive associated with the particular time may be very large (e.g., TBs) compared to a small amount of initial amount of data desired to be accessed using the restored snapshot tree.
- the serialized snapshot tree data associated with the snapshot tree associated with the particular may be identified and used to at least partially restore the snapshot tree. Metadata of a root node of the identified serialized snapshot tree data may be used to create a partially restored snapshot tree.
- the partially restored snapshot tree may include a representation of the root node that references one or more stub nodes.
- the partially restored snapshot tree may be traversed using a key associated with a user's request and one or more encountered stub nodes may be restored using the serialized snapshot tree data that corresponds to the encountered stub nodes.
- the user's request may be completed after the snapshot tree is restored to include a restored leaf node associated with the user's request. This reduces the amount to time and storage needed to restore the user's request.
- the non-requested portions of file system data are restored as a background operation of the storage system.
- Primary storage system 102 is a computing system that stores file system data.
- Primary storage system 102 may be comprised of one or more servers, one or more computing devices, one or more storage devices, and/or a combination thereof.
- Primary storage system 102 may be configured to backup file system data to secondary storage system 104 according to one or more backup policies.
- a backup policy indicates that file system data is to be backed up on a periodic basis (e.g., hourly, daily, weekly, monthly, etc.).
- a backup policy indicates that file system data is to be backed up when a threshold size of data has changed.
- a backup policy indicates that file system data is to be backed up upon a command from a user associated with primary storage system 102.
- Secondary storage system 104 is a storage system configured to backup file system data received from primary storage system 102. Secondary storage system 104 may protect a large volume of applications while supporting tight business requirements (recovery time objective (RTO) and recovery point objective (RPO)). Secondary storage system 104 may unify end-to-end protection infrastructure - including target storage, providing backup, replicating data, disaster recover, and/or cloud tiering. Secondary storage system 104 may provide scale-out, globally deduped, highly available storage to consolidate all secondary data, including backups, files, and test/dev copies. Secondary storage system 104 simplifies backup infrastructure and eliminates the need to run separate backup software, proxies, media servers, and archival.
- RTO recovery time objective
- RPO recovery point objective
- Secondary storage system 104 may be fully integrated with a virtual machine (VM) centralized management tool, such as vCenter, and an applications programming interface (API) for data protection. Secondary storage system 104 may reduce the amount of time to perform RPOs and support instantaneous RTOs by creating a clone of a backup VM and running the VM directly from secondary storage system 104. Secondary storage system 104 may integrate natively with one or more cloud servers. This eliminates the need to use tape archives by using one or more cloud servers for long-term data archival.
- VM virtual machine
- API applications programming interface
- Secondary storage system 104 may be configured to implement policy based archival of older snapshots on-prem to cloud storage for long-term retention.
- the cloud archive allows data to be indexed for fast search and retrieval back to on-prem from the cloud.
- the cloud archive allows recovery of data to a different site in the event the primary cluster fails.
- the cloud archive may allow data encryption in-flight and at-rest in the cloud.
- Secondary storage system 104 may be configured to archive a copy of the file system data in a remote storage for disaster recovery.
- Secondary storage system 104 may be configured to move certain file system data to a remote storage location, such as cloud storage 106, to handle spikes in storage demand.
- Secondary storage system 104 may be configured to implement a policy-based waterfall model that moves cold data to a remote storage location, such as cloud storage 106. Upon receiving a read for data that is stored at the remote storage location, secondary storage system 104 is configured to retrieve the data and store the data at the secondary storage location.
- Secondary storage system 104 is configured to store the file system data in a tree data structure and to create a snapshot of the tree data structure.
- the snapshot may be associated with a view at a particular moment in time.
- a view depicts the connections between nodes and the data stored in one or more leaf nodes at the particular moment in time.
- the tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree.
- Secondary storage system 104 may archive the file system data to cloud storage system 106 or to a cluster storage system 108.
- the archive may include the file system data and a serialized snapshot tree data that is a serialized version of the tree data structure at the particular moment in time.
- the archive includes a full snapshot archive of the file system data.
- the archive includes an incremental snapshot archive of the file system data.
- a backup policy may indicate that one or more previous snapshots are to be deleted after a full snapshot is performed.
- Secondary storage system 104 may be configured to archive any of the data stored on secondary storage system 104 (e.g., tree data, other non-tree data) according to one or more archive policies.
- an archive policy indicates that the data is to be archived to a cloud storage system and/or to a cluster storage system on a periodic basis (e.g., hourly, daily, weekly, monthly, etc.).
- an archive policy indicates that data is to be archived to a cloud storage system and/or to a cluster storage system when a threshold size of data has changed.
- an archive policy indicates that data is to be archived to a cloud storage system and/or to a cluster storage system upon a command from a user associated with secondary storage system 104.
- Secondary storage system 104 may be comprised of one or more solid state drives, one or more hard disk drives, or a combination thereof. Secondary storage system 104 may include one or more processors coupled to the storage drives and configured to archive data stored in the storage drives to cloud storage system 106, a cluster 108, and/or one or more other storage mediums (e.g., tape, removable storage). In one embodiment, secondary storage system 104 is comprised of one solid state drive and three hard disk drives.
- Secondary storage system 104 may include a file system manager 105.
- File system manager 105 is configured to maintain file system data in the form of nodes arranged in a tree data structure.
- leaf nodes in the file system tree include key-value pairs that associate data keys with values in the form of particular items of file system data.
- a user requests a particular item of data by providing a data key to file system manager 105, which traverses a file system tree to find the item of data associated with that data key.
- File system manager 105 may be configured to perform a snapshot of a snapshot tree.
- File system manager 105 may be configured to perform one or more modifications, as disclosed herein, to a snapshot tree.
- Cloud storage system 106 may be a public cloud storage provider (e.g., Amazon Web Services, Microsoft Azure Blob Storage, Google Cloud Storage). Cloud storage system 106 is configured to receive and store an archive from secondary storage system 104. Cloud storage system 106 may store a full snapshot of file system data and associated serialized snapshot tree data. Cloud storage system 106 may store an incremental snapshot of file system data and associated serialized snapshot tree data. Cloud storage system 106 may provide to secondary storage 104 file system data and a serialized snapshot tree data associated with a particular time.
- Cloud storage system 106 may be a public cloud storage provider (e.g., Amazon Web Services, Microsoft Azure Blob Storage, Google Cloud Storage). Cloud storage system 106 is configured to receive and store an archive from secondary storage system 104. Cloud storage system 106 may store a full snapshot of file system data and associated serialized snapshot tree data. Cloud storage system 106 may store an incremental snapshot of file system data and associated serialized snapshot tree data. Cloud storage system 106 may provide to secondary storage 104 file system data and a serialized snapshot tree data associated with
- One or more clusters 108 may be comprised of a plurality of storage nodes.
- the storage nodes may be comprised of one or more solid state drives, one or more hard disk drives, or a combination thereof.
- a cluster is configured to receive and store an archive from secondary storage system 104.
- a cluster may store a full snapshot of file system data and associated serialized snapshot tree data.
- a cluster may store an incremental snapshot of file system data and associated serialized snapshot tree data.
- a cluster may provide to secondary storage 104 file system data and a serialized snapshot tree data associated with a particular time.
- one or more clusters 108 may be part of secondary storage 104.
- FIG. 2A is a block diagram illustrating an embodiment of a tree data structure storing file system data.
- tree data structure 200 may be created by a storage system, such as secondary storage system 104.
- tree data structure 200 is a snapshot tree that includes a root node 202, intermediate nodes 212, 214, and leaf nodes 222, 224, 226, 228, and 230.
- tree data structure 200 includes one intermediate level between root node 202 and leaf nodes 222, 224, 226, 228, and 230, there could be any number of intermediate levels in a snapshot tree.
- Tree data structure 200 may be a snapshot tree of file system data at a particular point in time t.
- Tree data structure 200 may correspond to a version of a snapshot tree.
- Root node 202 is associated with the snapshot of the file system data at the particular point in time t .
- the file system data is metadata for a distributed file system and may include information, such as file size, directory structure, file permissions, physical storage locations of the files, etc.
- a root node is the root of a snapshot tree and may include pointers to one or more other nodes. Each pointer includes a range of numerical and sorted data keys that can be found by following that particular pointer.
- An intermediate node is a node to which another node points (e.g., root node, other intermediate node) and includes one or more pointers to one or more other nodes.
- a leaf node is a node at the bottom of a snapshot tree. In some embodiments, a leaf node is a node to which another node points, but does not include a pointer to any other node. In other embodiments, a leaf node is a node to which another node points and includes a pointer to the root node of another snapshot tree.
- a leaf node may store key-value pairs of file system data.
- a data key k is a lookup value by which a particular leaf node may be accessed. For example, "1" is a data key that may be used to lookup "DATA1" of leaf node 222. Examples of values stored by a leaf node include, but are not limited to, file size, directory structure, file permissions, physical storage locations of the files, etc.
- a leaf node may store a data key k and a pointer to a location that stores the value associated with the data key.
- a root node or an intermediate node may include one or more node keys.
- the node key may be an integer value or a non-integer value.
- Each node key indicates a division between the branches of the node and indicates how to traverse the tree data structure to find a leaf node, i.e., which pointer to follow.
- root node 202 may include a node key of "3."
- a data key k of a key-value pair that is less than or equal to the node key is associated with a first branch of the node and a data key k of a key-value pair that is greater than the node key is associated with a second branch of the node.
- a hash function may determine which branch of a node with which the non-numerical data key is associated. For example, a hash function may determine that a first bucket is associated with a first branch of a node and a second bucket is associated with a second branch of the node.
- a data key k of a key-value pair is not limited to a numerical value.
- non-numerical data keys may be used for a data key-value pair (e.g., "name,” “age,” etc.) and a numerical number may be associated with the non-numerical data key.
- a data key of "name” may correspond to a numerical key of "4.”
- Data keys that alphabetically come before the word "name” or is the word "name” may be found following a left branch associated with a node.
- Data keys that alphabetically come after the word "name” may be found by following a right branch associated with the node.
- a hash function may be associated with the non-numerical data key. The hash function may determine which branch of a node with which the non-numerical data key is associated.
- root node 202 includes a pointer to intermediate node 212 and a pointer to intermediate node 214.
- Root node 202 includes a NodeID of "R1" and a TreeID of "1.”
- the NodeID identifies the name of the node.
- the TreeID identifies the snapshot/view with which the node is associated.
- Root node 202 includes a node key that divides a set of pointers into two different subsets.
- Leaf nodes e.g., "1-3” with a data key k that is less than or equal to the node key are associated with a first branch and leaf nodes (e.g., "4-5") with a data key k that is greater than the node key are associated with a second branch.
- Leaf nodes with a data key of "1," "2,” or “3” may be found by traversing snapshot tree 200 from root node 202 to intermediate node 212 because the data keys have a value that is less than or equal to the node key.
- Leaf nodes with a data key of "4" or "5" may be found by traversing tree data structure 200 from root node 202 to intermediate node 214 because the data keys have a value that is greater than the node key.
- Root node 202 includes a first set of pointers.
- the first set of pointers associated with a data key less than the node key (e.g., "1,” "2,” or “3") indicates that traversing tree data structure 200 from root node 202 to intermediate node 212 will lead to a leaf node with a data key of "1,” "2,” or "3.”
- Intermediate node 214 includes a second set of pointers. The second set of pointers associated with a data key greater than the node key indicates that traversing tree data structure 200 from root node 202 to intermediate node 214 will lead to a leaf node with a data key of "4" or "5.”
- Intermediate node 212 includes a pointer to leaf node 222, a pointer to leaf node 224, and a pointer to leaf node 226.
- Intermediate node 212 includes a NodeID of "I1" and a TreeID of "1.”
- Intermediate node 212 includes a first node key of "1" and a second node key of "2.”
- the data key k for leaf node 222 is a value that is less than or equal to the first node key.
- the data key k for leaf node 224 is a value that is greater than the first node key and less than or equal to the second node key.
- the data key k for leaf node 226 is a value that is greater than the second node key.
- the pointer to leaf node 222 indicates that traversing tree data structure 200 from intermediate node 212 to leaf node 222 will lead to the node with a data key of "1.”
- the pointer to leaf node 224 indicates that traversing tree data structure 200 from intermediate node 212 to leaf node 224 will lead to the node with a data key of "2.”
- the pointer to leaf node 226 indicates that traversing tree data structure 200 from intermediate node 212 to leaf node 226 will lead to the node with a data key of "3.”
- Intermediate node 214 includes a pointer to leaf node 228 and a pointer to leaf node 230.
- Intermediate node 214 includes a NodeID of "I2" and a TreeID of "1.”
- Intermediate node 214 includes a node key of "4.”
- the data key k for leaf node 228 is a value that is less than or equal to the node key.
- the data key k for leaf node 230 is a value that is greater than the node key.
- the pointer to leaf node 228 indicates that traversing tree data structure 200 from intermediate node 214 to leaf node 228 will lead to the node with a data key of "4.”
- the pointer to leaf node 230 indicates that traversing tree data structure 200 from intermediate node 214 to leaf node 230 will lead the node with a data key of "5.”
- Leaf node 222 includes a data key-value pair of "1: DATA1.”
- Leaf node 222 includes NodeID of "L1" and a TreeID of "1.” To view the value associated with a data key of "1," tree data structure 200 is traversed from root node 202 to intermediate node 212 to leaf node 222.
- Leaf node 224 includes a data key-value pair of "2: DATA2.”
- Leaf node 224 includes NodeID of "L2" and a TreeID of "1.”
- tree data structure 200 is traversed from root node 202 to intermediate node 212 to leaf node 224.
- Leaf node 226 includes a data key-value pair of "3: DATA3.”
- Leaf node 226 includes NodeID of "L3” and a TreeID of "1.”
- tree data structure 200 is traversed from root node 202 to intermediate node 212 to leaf node 226.
- Leaf node 228 includes a data key-value pair of "4: DATA4.”
- Leaf node 228 includes NodeID of "L4" and a TreeID of "1.”
- tree data structure 200 is traversed from root node 202 to intermediate node 214 to leaf node 228.
- Leaf node 230 includes a data key-value pair of "5: DATA5.”
- Leaf node 230 includes NodeID of "L5" and a TreeID of "1.”
- tree data structure 200 is traversed from root node 202 to intermediate node 214 to leaf node 230.
- FIG. 2B is a block diagram illustrating an embodiment of cloning a snapshot tree of a tree data structure.
- tree data structure 250 may be created by a storage system, such as secondary storage system 104.
- snapshot tree 250 includes a snapshot tree that is comprised of root node 204, intermediate nodes 212, 214, and leaf nodes 222, 224, 226, 228, and 230.
- Tree data structure 250 may be a snapshot of file system data at a particular point in time t + n .
- the tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree.
- the snapshot tree at time t + n is linked to the snapshot tree at time t .
- a copy of the previous root node is created.
- the root node copy includes the same set of pointers as the original node. However, the root node copy also includes a different NodeID and a different TreeID.
- the TreeID is the identifier associated with a view.
- Root node 204 is associated with the snapshot of the file system data at the particular point in time t + n .
- Root node 202 is associated with the snapshot of the file system data at the particular point in time t .
- the snapshot tree at time t + n may correspond to a version of a snapshot tree.
- the snapshot tree at time t + n is a current view of the file system metadata. A current view may still accept one or more changes to the data.
- the TreeID of a root node indicates a snapshot with which the root node is associated. For example, root node 202 with a TreeID of "1" is associated with a first snapshot and root node 204 with a TreeID of "2" is associated with a second snapshot.
- the snapshot tree at time t + n is a snapshot view of the file system metadata. A snapshot view may not accept any changes to the data.
- two root node copies are created.
- Providing two new root nodes, each with a different TreeID prevents updates made to a particular view (e.g., current view) from affecting nodes of a different view (e.g., snapshot view).
- One of the new root nodes may be associated with a current view (i.e., modifiable) and the other new root node may be associated with a snapshot view (i.e., not modifiable).
- a root node associated with a previous snapshot is deleted after a snapshot is performed, i.e., root node 202 is deleted after root node 204 is created.
- root node 204 is a copy of root node 202. Similar to root node 202, root node 204 includes the same pointers as root node 202, except that root node 204 includes a different node identifier and a different view identifier. Root node 204 includes a first set of pointers to intermediate node 212.
- the first set of pointers associated with a data key k less than or equal to the node key indicates that traversing tree data structure 250 from root node 204 to intermediate node 212 will lead to a leaf node with a data key of "1,” "2,” or "3.”
- Root node 204 includes a second set of pointers to intermediate node 214.
- Root node 204 includes a NodeID of "R2" and a TreeID of "2.”
- the NodeID identifies the name of the node.
- the TreeID identifies the snapshot with which the node is associated.
- FIG. 2C is a block diagram illustrating an embodiment of modifying a snapshot tree.
- tree data structure 255 may be modified by a file system manager, such as file system manager 105.
- Tree data structure 255 may be a current view of the file system data at time t + n . A current view may still accept one or more changes to the data. Because a snapshot represents a perspective of the file system metadata that is "frozen" in time, one or more copies of one or more nodes affected by a change to file system metadata are made.
- Tree data structure 255 may include a root node that corresponds to a version of a snapshot tree.
- the value "DATA 4" has been modified to be " DATA 4'.”
- the file system manager starts at root node 204 because that is the root node associated with snapshot tree at time t + n .
- the value "DATA 4 " is associated with the data key "4.”
- the file system manager traverses tree data structure 255 from root node 204 until it reaches a target node, in this example, leaf node 228.
- the file system manager compares the TreeID at each intermediate node and leaf node with the TreeID of the root node. In the event the TreeID of a node matches the TreeID of the root node, the file system manager proceeds to the next node.
- the file system manager begins at root node 204 and proceeds to intermediate node 214.
- the intermediate node copy 216 includes the same set of pointers as intermediate node 214, but includes a TreeID of "2" to match the TreeID of root node 204.
- the file system manager updates a set of pointers of root node 204 to point to intermediate node 216 instead of pointing to intermediate node 214.
- the file system manager traverses tree data structure 255 from intermediate node 216 to leaf node 228, determines that the TreeID of leaf node 228 does not match the TreeID of root node 204, and creates a copy of leaf node 228.
- Leaf node copy 232 stores the modified value " DATA 4 ' " and includes the same TreeID as root node 204.
- the file system manager updates a pointer of intermediate node 216 to point to leaf node 232 instead of pointing to leaf node 228.
- FIG. 2D is a block diagram illustrating an embodiment of a modified snapshot tree of a tree data structure.
- the tree data structure 255 shown in FIG. 2D illustrates a result of the modifications made to tree data structure 255 as described with respect to FIG. 2C .
- FIG. 2E is a block diagram illustrating an embodiment of leaf node data.
- leaf node 260 may be leaf node 222, 224, 226, 228, 230.
- a tree data structure may be used to store data related to a value associated with a leaf node.
- a leaf node such as leaf node 222, 224, 226, 228, 230, may include a pointer to a tree data structure, such as the tree data structure depicted in FIG. 2E .
- leaf node 260 includes a data root node 270 and data leaf nodes 272, 274, 276, 278, and 280.
- a leaf node may include one or more intermediate nodes, similar to the tree data structure depicted in FIG. 2A .
- Data root node 270 includes a NodeID and a TreeID.
- Data root node 270 also includes a set of node keys.
- Data root node 270 includes a first node key of "1," a second node key of "2,” a third node key of "3,” and a fourth node key of "4.”
- the data key k for data leaf node 272 is a value that is less than or equal to the first node key.
- Data leaf node 272 includes a data block 282 that stores bits of ones and zeros. Although data block 282 is depicted as storing the bit pattern "1001," a data block may store any bit pattern. Data leaf node 272 may include a pointer to a physical location that stores the data.
- the data key k for data leaf node 274 is a value that is greater than the first node key and less than or equal to the second node key.
- Data leaf node 274 includes a data block 284 that stores bits of ones and zeros. Although data block 284 is depicted as storing the bit pattern "1011," a data block may store any bit pattern. Data leaf node 274 may include a pointer to a physical location that stores the data.
- the data key k for data leaf node 276 is a value that is greater than the second node key and less than or equal to the third node key.
- Data leaf node 276 includes a data block 286 that stores bits of ones and zeros. Although data block 286 is depicted as storing the bit pattern "0011," a data block may store any bit pattern. Data leaf node 276 may include a pointer to a physical location that stores the data.
- the data key k for data leaf node 278 is a value that is greater than the third node key and less than or equal to the fourth node key.
- Data leaf node 278 includes a data block 288 that stores bits of ones and zeros. Although data block 288 is depicted as storing the bit pattern "1010," a data block may store any bit pattern.
- Data leaf node 278 may include a pointer to a physical location that stores the data.
- the data key k for data leaf node 280 is a value that is greater than the fourth node key.
- Data leaf node 280 includes a data block 290 that stores bits of ones and zeros. Although data block 290 is depicted as storing the bit pattern "1111," a data block may store any bit pattern.
- Data leaf node 280 may include a pointer to a physical location that stores the data.
- FIG. 3A is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time.
- tree data structure 300 includes a root node 302, intermediate nodes 312, 314, and leaf nodes 322, 324, 326, 328, 330.
- tree data structure 300 is similar to the tree data structure 200 shown in FIG. 2A .
- Tree data structure 300 may correspond to a version of a snapshot tree.
- the full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot at the particular moment in time.
- FIG. 3B is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time.
- the tree data structure allows a chain of snapshot trees to be linked together.
- a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree.
- the snapshot tree includes root node 304, intermediate nodes 312, 316, and leaf nodes 322, 324, 326, 330, 332.
- the tree data structure 350 is similar to the tree data structure 255 shown in FIG. 2D .
- the full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot tree at the particular moment in time.
- An incremental snapshot may provide a partial view of the tree data structure at a particular time.
- FIG. 3C is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time.
- the tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree.
- the snapshot tree includes root nodes 306, intermediate nodes 312, 318, and leaf nodes 322, 324, 326, 330, 334.
- the full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot at the particular moment in time.
- An incremental snapshot may provide a partial view of the tree data structure at a particular time. The incremental snapshot may store each of the nodes associated with the snapshot tree at the particular moment in time that have not been previously stored.
- FIG. 3D is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time.
- the tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree.
- the snapshot tree includes root node 308, intermediate nodes 312, 318, and leaf nodes 322, 324, 326, 330, 334.
- the full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot at the particular moment in time.
- An incremental snapshot may provide a partial view of the tree data structure at a particular time. The incremental snapshot may store each of the nodes associated with the snapshot tree at a particular moment in time that has not been previously stored.
- each snapshot tree builds off of a previous snapshot tree, that is, a chain of snapshot trees exists.
- Each snapshot tree is associated with a snapshot of the file system data. As more and more snapshots are created and linked, this may require a lot of storage to store the snapshots.
- a policy may indicate that after a full snapshot is performed at a particular point in time, one or more previous snapshots may be deleted from the storage system. In some embodiments, the one or more previous snapshots are deleted after a condition of a retention time policy has passed.
- FIG. 4A is a block diagram illustrating an embodiment of archive data.
- a snapshot is the state of a system at a particular moment in time.
- a snapshot may be stored locally at a storage system, such as secondary storage system 104.
- a snapshot allows the state of a system to be rolled back to a moment in time for which a snapshot is stored.
- a system may store a large number of snapshots (e.g., thousands, millions). Each snapshot may require a significant amount of storage (e.g., GBs, TBs, PBs, etc.).
- One or more snapshots may be archived to a remote storage location for data recovery purposes (e.g., other storage systems may access the data associated with a snapshot in the event a storage location that locally stores the snapshot goes offline).
- One or more snapshots may be archived to a remote storage location to handle spikes in storage demand.
- One or more snapshots that include cold data i.e., data that is not accessed frequently
- the file system data associated with a snapshot may be archived to a remote storage location.
- An archive policy may indicate that a full snapshot archive of a snapshot or an incremental snapshot archive of the snapshot is to be performed and stored on a remote storage location.
- a full snapshot archive includes a complete view of one version of a snapshot tree at a particular moment in time.
- a full snapshot archive includes a root node associated with the view at the particular moment in time and any intermediate nodes and/or leaf nodes associated with the root node.
- a full snapshot archive does not include a node of a previous version of the snapshot tree if the node is not pointed to a node associated with the view at the particular moment in time.
- a full snapshot archive is similar to a full snapshot, except that the data associated with a full snapshot is stored at a remote location instead of on the storage system; that is the full snapshot archive includes the data stored in each of the nodes associated with the snapshot tree at the particular moment in time.
- a full snapshot archive may be performed based on one or more policies associated with a backup storage system. For example, a full snapshot archive may be performed on a periodic basis (e.g., every X day(s), every Y week(s), every Z month(s), etc.), upon a threshold size of bytes changing from the previous full snapshot, after a threshold number of incremental snapshot archives have been performed, etc.
- a policy may indicate that an incremental snapshot archive is to be performed on a more frequent basis than a full snapshot archive.
- the full snapshot archive and incremental snapshot archives are associated with a snapshot at a particular moment in time.
- each snapshot archive builds off of a previous snapshot archive, that is, a block of serialized data includes a file offset to a block associated with previously serialized data. As more and more archives are created, this may require a lot of storage to store the archives. To reduce the amount of storage needed to store the archives, a policy may indicate that after a full snapshot archive, such as depicted in FIG.
- one or more previous snapshot archives may be deleted from the remote storage location.
- the one or more previous snapshot archives are deleted after a condition of retention time policy has passed.
- archive data 400 can be archived by a storage system, such as secondary storage system 104, to a remote storage location, such as cloud storage 106 or cluster storage 108.
- archive data 400 includes file system data 451 and a serialized snapshot tree data 461.
- a full snapshot archive includes a complete view of the nodes of a snapshot of the snapshot tree at a particular moment in time (i.e., all nodes associated with a root node of the snapshot tree) and the data stored in each of the leaf nodes of the snapshot tree.
- a full snapshot archive is independent on its own and does not refer back to one or more previous snapshot archives.
- File system data of archive data that stores a full snapshot of a snapshot tree associated with a particular view includes all of the data stored in the one or more leaf nodes of a snapshot, regardless of when a leaf node was created (i.e., the snapshot may include leaf nodes associated with previous snapshots).
- file system data 451 includes the data stored in leaf nodes 322, 324, 326, 328, and 330, that is, file system data 451 includes "DATA1,” "DATA2,” “DATA3,” “DATA4,” and "DATA5.”
- File system data 451 may be archived from a storage system, such as a secondary storage system, to a remote storage location, such as a cloud storage system or a cluster backup system.
- the file system data is the data (e.g., data blocks of a file, data segments of a file) for a distributed file system.
- File system data may be stored as a flat set of data.
- file system data 451 stores all data blocks associated with leaf nodes of a snapshot tree. In other embodiments, file system data 451 stores all 1s and 0s of file data blocks associated with leaf nodes of a snapshot tree. In some embodiments, file system data 451 stores a plurality of file data blocks in a single block of file system data 451. In some embodiments, the file system data includes file system metadata, such as file size, directory structure, file permissions, physical storage locations of the files, etc.
- a serialized snapshot tree data stores the structure of the snapshot tree associated with the file system data as a flat set of data that is comprised of one or more blocks. Each block of the flat set of data corresponds to a node of the snapshot tree.
- a block may contain a file offset.
- a file offset represents of a pointer of a snapshot tree. Because some archive systems cannot store pointers, a file offset is used in place of pointers.
- the file offset may be to another block of the serialized snapshot tree data.
- the file offset may be to another block of a different serialized snapshot tree data.
- Serialized snapshot tree data 461 is comprised of a plurality of blocks. Each block corresponds to one of the snapshot tree nodes.
- Block 402 corresponds to root node 302. Because root node 302 includes pointers to intermediate nodes 312 and 314, block 402 includes file offsets to blocks 412 and 414. Blocks 412 and 414 correspond to intermediate nodes 312 and 314, respectively. Because intermediate node 312 includes pointers to leaf nodes 322, 324, and 326, block 412 includes file offsets to blocks 422, 424, and 426. The file offsets correspond to the pointers of a snapshot tree. Similarly, block 414 includes file offsets to blocks 428, 430 because intermediate node 314 includes pointers to leaf nodes 328, 330.
- Blocks 422, 424, 426, 428, and 430 correspond to the leaf nodes of snapshot tree 300 and each include a corresponding file offset to one or more blocks of the file system data stored in file system data 451.
- block 422 includes an offset to one or more blocks in file system data 451 that stores the value of L1.
- blocks 424, 426, 428, 430 include corresponding offsets to one or more blocks in file system data 451 that store the value of L2, L3, L4, and L5, respectively.
- FIG. 4B is a block diagram illustrating an embodiment of archive data.
- archive data 450 can be archived by a system, such as secondary storage system 104.
- archive data 450 includes file system data 453 and a serialized snapshot tree data 463.
- File system data 453 is an incremental snapshot archive of the file system data stored in the one or more leaf nodes of a snapshot tree.
- An incremental snapshot archive may include changes to the data of a snapshot tree since a last snapshot archive (e.g., new data or modified data).
- File system data 453 may be stored as a flat set of data.
- file system data 453 stores all data blocks associated with leaf nodes of a snapshot tree that were not previously archived.
- file system data 453 stores the corresponding 1s and 0s of file data blocks associated with leaf nodes of a snapshot tree that were not previously archived.
- file system data 453 stores a plurality of file data blocks in a single block of file system data 453.
- the file system data includes file system metadata, such as file size, directory structure, file permissions, physical storage locations of the files, etc.
- Serialized snapshot tree data 463 includes a serialized representation of one or more changes to a snapshot tree (e.g., new node, modified node, deleted node) since a previous snapshot.
- Serialized snapshot tree data may include a block for each root node of a snapshot tree.
- the file system manager To determine whether a node should be included in a serialized snapshot tree data, the file system manager starts at the root node associated with a snapshot view and traverses the snapshot tree. At each node of the snapshot tree, the file system manager determines whether that particular node existed and is the same as the one in the previous snapshot tree. In the event the node didn't exist in the previous snapshot or is different when compared to the corresponding node in the previous snapshot tree, a block corresponding to the node is included in serialized snapshot tree data.
- a block corresponding to the node is not included in the serialized snapshot tree data because a previous serialized snapshot tree data already includes a block corresponding to the node. Instead, a file offset to the block of the previous serialized snapshot tree data may be included in one or more of the blocks in the serialized snapshot tree data.
- root node 304 was added.
- Intermediate node 316 and leaf node 332 were added to the snapshot tree to ensure that each node along this path has a TreeID of "2.”
- Serialized snapshot tree data 463 is comprised of a plurality of blocks. Each block corresponds to one of the snapshot tree 350 nodes. For example, blocks 432, 416, 404 correspond to nodes 332, 316, 304, respectively.
- serialized snapshot tree data corresponding to an incremental backup includes the root node associated with a snapshot view.
- Block 404 corresponds to root node 304. Because root node 304 includes a pointer to intermediate node 312, block 404 includes a file offset to block 412 of serialized snapshot tree data 461. Previously stored serialized snapshot tree data 461 already includes block 412 that corresponds to intermediate node 312. A file offset to a previously stored serialized snapshot tree data is used to save memory and prevent storing duplicative data. Root node 304 also includes a pointer to intermediate node 316. Similarly, block 404 also includes a file offset to block 416, which corresponds to intermediate node 316.
- Block 416 corresponds to intermediate node 316.
- Intermediate node 316 includes pointers to leaf nodes 330, 332. The value of leaf node 330 has not changed and was previously stored in file system metadata 451.
- block 416 includes a file offset to block 430 of serialized snapshot tree data 461.
- Block 416 also includes a file offset to block 432.
- Block 432 corresponds to leaf node 332.
- Intermediate node 316 is a new node because snapshot tree 300 did not include intermediate node 316.
- serialized snapshot tree data 463 includes a block that corresponds to intermediate node 316.
- Block 432 corresponds to leaf node 332 of snapshot tree 350.
- Leaf node 332 is a new node because snapshot tree 300 did not include leaf node 332.
- serialized snapshot tree data 463 includes a block that corresponds to leaf node 332.
- Block 432 includes a file offset to one or more blocks in file system data 453 that store the value of leaf node 332.
- FIG. 4C is a block diagram illustrating an embodiment of archive data.
- archive data 480 can be archived by a system, such as secondary storage system 104.
- archive data 480 includes file system data 455 and a serialized snapshot tree data 465.
- File system data 455 is an incremental snapshot of the file system data stored in the one or more leaf nodes of a snapshot tree.
- File system data 455 may be stored as a flat set of data.
- file system data 455 stores all data blocks associated with leaf nodes of a snapshot tree that were not previously archived.
- file system data 455 stores the corresponding 1s and 0s of file data blocks associated with leaf nodes of a snapshot tree that were not previously archived.
- file system data 455 stores a plurality of file data blocks in a single block of file system data 455.
- the file system data includes file system metadata, such as file size, directory structure, file permissions, physical storage locations of the files, etc.
- blocks 434, 418, 406 correspond to nodes 334, 318, 306, respectively.
- Block 406 corresponds to root node 306. Because root node 306 includes a pointer to intermediate node 312, block 406 includes a file offset to block 412 of serialized snapshot tree data 461. Root node 306 includes a pointer to intermediate node 318. Similarly, block 406 includes a file offset to block 418, which corresponds to intermediate node 318.
- Block 418 corresponds to intermediate node 318.
- Intermediate node 318 includes a pointer to leaf nodes 330, 334. The value of leaf node 330 has not changed and was previously stored in file system metadata 451.
- block 418 includes a file offset to block 430 of serialized snapshot tree data 461.
- Block 418 also includes a file offset to block 434.
- Block 434 corresponds to leaf node 334.
- Intermediate node 318 is a new node because snapshot tree 350 did not include intermediate node 318.
- archive data 480 includes a block that corresponds to intermediate node 318.
- Block 434 corresponds to leaf node 334 of snapshot tree 380.
- archive data 480 includes a block that corresponds to leaf node 334.
- Block 434 includes a file offset to a block of file system metadata 455 that stores the value of leaf node 334.
- FIG. 4D is a block diagram illustrating an embodiment of archive data.
- archive data 490 can be archived by a storage system, such as secondary storage system 104.
- archive data 490 includes file system data 457 and a serialized snapshot tree data 467.
- a full snapshot archive includes a representation of all of the nodes of a snapshot of a snapshot tree at a particular moment in time (i.e., all nodes associated with a root node of the snapshot tree) and the data stored in each of the leaf nodes of the snapshot tree.
- Serialized snapshot tree data 467 is comprised of a plurality of blocks. Each block corresponds to one of the snapshot tree nodes.
- Block 408 corresponds to root node 308. Because root node 308 includes pointers to intermediate nodes 312 and 318, block 408 includes file offsets to blocks 412 and 418. Blocks 412 and 418 correspond to intermediate nodes 312 and 318, respectively. Because intermediate node 312 includes pointers to leaf nodes 322, 324, and 326, block 412 includes file offsets to blocks 422, 424, and 426. The file offsets correspond to the pointers of a snapshot tree. Similarly, block 418 includes file offsets to blocks 434, 430 because intermediate node 318 includes pointers to leaf nodes 334, 330.
- Blocks 422, 424, 426, 434, and 430 correspond to the leaf nodes of snapshot tree 390 and each include a corresponding file offset to one or more blocks of the file system data stored in file system data 457.
- block 422 includes an offset to one or more blocks in file system data 457 that stores the value of L1.
- blocks 424, 426, 434, 430 include corresponding offsets to one or more blocks in file system data 457 that store the value of L2, L3, L7, and L5, respectively.
- a serialized snapshot tree data may be linked with a previous serialized snapshot tree data. As more and more snapshots are archived, this may require a lot of storage to archive the serialized snapshot tree data.
- a policy may indicate that after a full snapshot archive, such as archive 490, is performed at a particular point in time, one or more previous archives may be deleted from cloud storage, i.e., archive data 400, 450, 480. For example, archive data 400, 450, 480 may be deleted after archive data 490 is archived.
- the one or more previous snapshot archives are deleted after a condition associated with a retention time policy has passed. For example, a policy may indicate that data is to be archived for a period of thirty days.
- FIG. 5 is a flow chart illustrating an embodiment of archiving data.
- process 500 may be implemented by a storage system, such as secondary storage system 104.
- process 500 is a full snapshot archive.
- process 500 is an incremental snapshot archive.
- a snapshot is the state of a system at a particular moment in time.
- a snapshot may be stored locally at a storage system, such as secondary storage system 104.
- a snapshot allows the state of a system to be rolled back to a moment in time for which a snapshot is stored.
- a system may store a large number of snapshots (e.g., thousands, millions). Each snapshot may require a significant amount of storage (e.g., GBs, TBs, PBs, etc.).
- the file system data associated with a snapshot may be archived to a remote storage location.
- An archive policy may indicate that a full snapshot archive of a snapshot or an incremental snapshot archive of the snapshot is to be performed and stored on a remote storage location.
- a full snapshot archive includes a complete view of one version of a snapshot tree at a particular moment in time.
- a full snapshot archive includes a root node associated with the view at the particular moment in time and any intermediate nodes and/or leaf nodes associated with the root node.
- a full snapshot archive does not include a node of a previous version of the snapshot tree if the node is not pointed to a node associated with the view at the particular moment in time.
- a full snapshot archive is similar to a full snapshot, except that the data associated with the full snapshot is stored at a remote location instead of on the storage system; that is, the full snapshot archive includes the data stored in each of the nodes associated with the snapshot tree at the particular moment in time.
- An incremental snapshot archive includes a partial view of one version of a snapshot tree at a particular moment in time.
- An incremental snapshot archive includes a representation of what was not previously archived.
- An incremental snapshot archive is similar to an incremental snapshot, except that the data associated with the incremental snapshot archive is stored at a remote location instead of on the storage system; that is, the incremental snapshot archive includes the data stored in the leaf nodes of the snapshot tree that have not been previously archived.
- the filesystem data is to be archived according to an archive policy.
- an archive policy may indicate that a full snapshot archive is to be performed on a periodic basis (e.g., every W hour(s), every X day(s), every Y week(s), every Z month(s), etc.).
- An archive policy may indicate that a full snapshot archive is to be performed each time a full snapshot is performed.
- an archive policy may indicate that one or more previous snapshot archives are to be deleted after a full snapshot archive is performed.
- an archive policy may indicate that one or more file system data files and corresponding serialized snapshot tree data are to be deleted after a full snapshot archive is performed.
- An archive policy may indicate that an incremental snapshot archive is to be performed on a periodic basis (e.g., every W hour(s), every X day(s), every Y week(s), every Z month(s), etc.).
- An archive policy may indicate that an incremental snapshot archive is to be performed each time an incremental snapshot is performed.
- An archive policy may indicate that an incremental snapshot archive is to be performed on a more frequent basis than a full snapshot archive.
- each snapshot archive builds off of a previous snapshot archive, that is, a block of serialized data includes a file offset to a block associated with previously serialized data. As more and more archives are created, this may require a lot of storage to store the archives.
- a policy may indicate that after a full snapshot archive, such as depicted in FIG. 4D , is performed at a particular point in time, one or more previous snapshot archives (i.e., archives 400, 450, 480) may be deleted from the remote storage location.
- the one or more previous snapshot archives are deleted after a condition of retention time policy has passed.
- a snapshot tree associated with a view is serialized into serialized snapshot tree data and file system data associated with the view is serialized into serialized file system data.
- Serializing the snapshot tree into serialized snapshot tree data creates a flat set of data that represents the snapshot tree.
- the file system data may be stored in a tree data structure, such as the tree data structure depicted in FIG. 2E .
- Serializing the file system data into serialized file system data creates a flat set of data that represents the file system data.
- the snapshot tree and the file system data are serialized into flat sets of data because a remote location may be incapable of storing a tree data structure.
- the view is a current view.
- a current view is a current perspective of the snapshot tree and one or more changes may be made to the snapshot tree.
- the view is a snapshot view.
- a snapshot view is a perspective of the snapshot tree at a particular moment in time and one or more changes may not be made to the snapshot tree of the snapshot view.
- the serialized snapshot tree data i.e., a flat set of data, is comprised of one or more blocks.
- the serialized snapshot tree is a representation of a snapshot tree in block form.
- Each block of the serialized snapshot tree data corresponds to a node of a snapshot tree.
- a block of the serialized snapshot tree may include one or more file offsets to one or more other blocks.
- the file offsets represent the pointers of a snapshot tree.
- a block may include a file offset to another block in the serialized snapshot tree data.
- a block may include a file offset to another block in a previously serialized snapshot tree data.
- a snapshot tree node may include a pointer to a node associated with a previous snapshot tree.
- a block that corresponds to the snapshot tree node may include a file offset to the block of a previously serialized snapshot tree data block that corresponds to the node associated with the previous snapshot tree.
- the snapshot tree node may also include a pointer to a node associated with the current snapshot tree.
- a block that corresponds to the snapshot tree node may include a file offset to the block of the current serialized snapshot tree data that corresponds to the node associated with the current snapshot tree.
- the serialized file system data i.e., a flat set of data, is comprised of one or more blocks. Each block of the serialized file system data corresponds to a data block or data segment of the file system data.
- a full snapshot is performed and the serialized snapshot tree data includes a plurality of blocks that correspond to the plurality of nodes of the snapshot tree.
- one or more snapshots performed before the full snapshot are deleted.
- an incremental snapshot is performed and the serialized snapshot tree data includes a plurality of blocks that correspond to the one or more root nodes and the one or more nodes that have been added to a snapshot tree since a previous archive.
- an incremental snapshot is performed for a plurality of different snapshot trees and the corresponding serialized snapshot tree data includes file blocks corresponding to the plurality of different snapshot trees.
- a serialized snapshot tree data combines the plurality of blocks that correspond to the one or more root nodes and the one or more nodes that have been added to a snapshot tree since a previous archive with one or more blocks from one or more previous archives.
- the serialized snapshot tree data and serialized file system data are archived.
- the file system data is comprised of data blocks of a file and/or data segments of a file, and may be stored as a set of flat data.
- the file system data is a full snapshot archive of the file system data stored in the one or more leaf nodes of a snapshot tree.
- Each of the data blocks/segments comprising the file system data stored in the one or more leaf nodes of a snapshot tree may be stored in the set of flat data.
- the file system data is an incremental snapshot archive of the file system data stored in the one or more leaf nodes of a snapshot tree.
- the incremental snapshot archive may include changes to the data of a snapshot tree since a last snapshot archive (e.g., new data or modified data).
- Each of the data blocks/segments comprising the changes to the data of a snapshot tree since a last snapshot archive may be stored in the set of flat data.
- the serialized snapshot tree data and file system data are archived to remote storage (e.g., cloud storage system, cluster storage system, etc.).
- the file system data may be stored in one or more files.
- File system metadata may be stored in one or more separate files.
- the file system metadata may include a reference to a file system data file and vice versa.
- FIG. 6A is a flow chart illustrating an embodiment of restoring archived data.
- process 600 may be performed by a storage system, such as secondary storage system 104.
- a request for data at a particular time is received.
- the request may include a data key and the particular time.
- the value associated with a data key is stored in a leaf node of a snapshot tree at the particular time.
- the snapshot tree may have been deleted from a storage system and archived to a remote storage location.
- a view associated with the particular time is determined.
- a snapshot tree has an identifier associated with a particular view.
- the snapshot tree having an identifier that matches the view associated with the particular time is determined.
- the view may be comprised of a root node, one or more intermediate nodes, and one or more leaf nodes.
- the value associated with the data key is stored in one of the leaf nodes of the view.
- An archive of file system data may comprise a first set of flat data.
- An archive of serialized snapshot tree data may comprise a second set of flat data.
- At least a portion of one or more file system archives 451, 453, 455 and at least a portion of one or more archives of serialized snapshot tree data 461, 463, 465 may be retrieved.
- the archives are retrieved from a remote storage location, such as cloud storage or cluster storage.
- data corresponding to a full snapshot archive is retrieved.
- data corresponding to an incremental snapshot archive is retrieved.
- data corresponding to a full snapshot archive and one or more incremental snapshot archives are retrieved.
- a snapshot tree associated with the particular time is reconstituted.
- the snapshot tree is reconstituted by deserializing serialized snapshot tree data associated with the particular time.
- the snapshot tree is reconstituted by deserializing serialized snapshot tree data associated with the particular time and deserializing one or more other serialized snapshot tree data.
- the one or more other serialized snapshot tree data were archived before the serialized snapshot tree data associated with the particular time.
- Reconstituting the structure of a snapshot tree at the particular time includes reading the flat set of data associated with the serialized snapshot tree data.
- the flat set of data includes blocks of data that correspond to nodes of a snapshot tree and associated file offsets that correspond to pointers of the snapshot tree.
- a file system manager may deserialize the serialized snapshot tree data.
- Leaf node 334 may be reproduced because block 418 includes an offset to block 434, which corresponds to leaf node 334.
- the value associated with leaf node 334 may be accessed and reproduced because block 434 includes an offset to one or more blocks of data stored in file system data 455.
- Leaf nodes 322, 324, 326 may be reproduced because block 406, which corresponds to root node 306, includes an offset to block 412 of serialized snapshot tree data 461.
- Block 412 of serialized snapshot tree data 461 corresponds to intermediate node 312.
- Block 412 includes an offset to blocks 422, 424, 426, which correspond to leaf nodes 322, 324, 326, respectively.
- the corresponding values associated with leaf nodes 322, 324, 326 may be accessed and reproduced because blocks 422, 424, 426 include file offsets to one or more blocks of data stored in file system data 451.
- Leaf node 330 may be reproduced because block 418 of serialized snapshot tree data 465 includes an offset to block 430 of serialized snapshot tree data 461.
- Block 430 of serialized snapshot tree data 461 corresponds to leaf node 330.
- the value associated with leaf node 330 may be accessed and reproduced because block 430 includes an offset to one or more blocks of data stored in file system data 455.
- serialized snapshot tree data 465 includes file offsets to serialized snapshot tree data 463, 461, serialized snapshot tree data 461, 463 do not need to be deserialized because the requested value may be determined without deserializing those files. In some embodiments, a subset of the serialized snapshot tree data needed to produce the entire snapshot is deserialized to determine the value for a data key at the particular time.
- the reproduced tree data structure is traversed.
- the reproduced tree is traversed starting at a root node having a TreeID that is associated with the particular time.
- the value associated with leaf node 334 indicates a current value associated with a data key of "4.” In other embodiments, the value associated with leaf node 334 indicates the value associated with a data key of "4" at a particular point in time.
- the leaf node includes a pointer to a location in file system data archive.
- the requested data is retrieved from a remote storage location and provided.
- a value of "DATA 4 "" may be retrieved from a file system data archive stored in cloud storage and provided.
- the value is retrieved from archive data that was previously retrieved and stored on a storage system.
- the value is retrieved from a remote storage location, such as a cloud storage system or a cluster storage system.
- FIG. 6B is a flow chart illustrating an embodiment of retrieving archived data.
- process 650 may be performed by a storage system, such as secondary storage system 104.
- a request for data at a particular time is received.
- the request may include a data key and the particular time.
- the value associated with a data key is stored in a leaf node of a snapshot tree at the particular time.
- the snapshot tree may have been deleted from a storage system and archived to a remote storage location.
- a view associated with the particular time is determined.
- a snapshot tree has an identifier associated with a particular view.
- the snapshot tree having an identifier that matches the view associated with the particular time is determined.
- the view may be comprised of a root node, one or more intermediate nodes, and one or more leaf nodes.
- the value associated with the data key is stored in one of the leaf nodes of the view.
- serialized snapshot tree data associated with the view is determined.
- the determined serialized snapshot tree data corresponds to a full snapshot.
- the determined serialized snapshot tree data corresponds to an incremental snapshot archive.
- the determined serialized snapshot tree data corresponds to a full snapshot archive and one or more incremental snapshot archives.
- Serialized snapshot tree data is traversed.
- Serialized snapshot tree data is a flat set of data and includes one or more blocks.
- One of the blocks corresponds to a root node associated with the particular view.
- block 406 of serialized snapshot tree data 465 corresponds to root node 306 of tree data structure 380.
- serialized snapshot tree data is traversed from block 406 to one or more blocks of file system data 455 based on file offsets included in the one or more blocks of serialized snapshot tree data 465.
- An initial block corresponding to a root node of a snapshot tree at the particular time is read to determine a file offset.
- the block with the file offset is read to determine whether the block includes a file offset to another block of serialized snapshot tree data or a file offset to one or more blocks of file system data.
- the block with the file offset is read and the process repeats until traversing the serialized snapshot tree data arrives at one or more blocks of file system data.
- block 406 of serialized snapshot tree data 465 is read and it is determined that block 406 includes a file offset to block 418.
- Block 418 of serialized snapshot tree data 465 is read and it is determined that it includes a file offset to block 434.
- Block 434 of serialized snapshot tree data is read and it is determined that block 434 includes a file offset to one or more blocks of file system data 455.
- the value associated with a data key is retrieved from remote storage.
- the value may be stored in one or more blocks of remote storage.
- the retrieved value associated with the data key is provided via a user interface. For example, the value "DATA 4 "" is provided.
- FIGS. 7A , 7B , and 7C are block diagrams illustrating an embodiment of maintaining a snapshot tree.
- tree data structure 700 can be maintained by a storage system, such as secondary storage system 104.
- Tree data structure 700 is similar to tree data structure 380 except that the intermediate nodes and leaf nodes have an associated count value.
- a count value of a node indicates a number of other nodes that include pointers to the node.
- a count value of a node is incremented each time another node includes a pointer to the node.
- intermediate node 712 has a count value of "3" because root nodes 702, 704, 706 include pointers to intermediate node 712.
- Intermediate node 714 has a count value of "1” because root node 702 is the only node that includes a pointer to intermediate node 714.
- Intermediate nodes 716, 718 have a count value of "1” and "1,” respectively.
- Leaf nodes 722, 724, 726, 728, 730, 732, and 734 have a count value of "1,” “1,” “1,” "3,” “1,” and “1,” respectively.
- An associated snapshot tree view may have an associated retention time policy associated with it.
- retention time policy may indicate that a snapshot tree view is to be deleted after a certain period of time (e.g., day(s), week(s), month(s), year(s), etc.).
- the retention time policy reduces the number of snapshot trees that a system is required to maintain and store in memory.
- a retention time policy condition is satisfied (e.g., a snapshot tree view has been stored in memory for a particular amount of time) and it is determined to remove the snapshot tree view from memory. For example, it may be determined that a snapshot tree with a particular TreeID is to be stored for a particular amount of time. In the event the particular amount of time has passed, a file system manager may determine that the snapshot tree with the particular TreeID is to be removed from memory and/or storage. This reduces the storage needed to store snapshot trees and corresponding snapshots because the data contained in a snapshot may not be needed after a certain amount of time has passed.
- a retention time policy condition indicates that a full snapshot and associated incremental snapshots are to be removed from memory in the event a subsequent snapshot occurs.
- FIG. 7B depicts an embodiment where a retention time policy condition associated with a TreeID has been satisfied.
- Root node 702 may be traversed to intermediate node 712.
- a count value associated with intermediate node 712 is decremented by one.
- the count value associated with intermediate node 712 is decremented from “3" to "2.” Because the count value associated with intermediate node 712 is not “0,” then the count values of the associated leaf nodes 722, 724, 726 retain their current value of “1.” However, if the count value associated with intermediate node 712 was "0,” then the count values associated with leaf nodes 722, 724, and 726 would also be decremented, such that the count value would change from "1" to "0.”
- Root node 702 may be traversed to intermediate node 714.
- a count value associated with intermediate node 714 is decremented by one. In this example, the count value associated with intermediate node 714 is decremented from “1" to "0.” Because the count value associated with intermediate node 714 is "0,” then tree data structure 700 is further traversed to leaf nodes 728, 730. The count value associated with leaf node 728 is decremented from “1" to "0.” The count value associated with leaf node 730 is decremented from "3" to "2.”
- root node associated with the snapshot tree view and any nodes having a count value of "0" associated with the snapshot tree view are removed from memory.
- root node 702 is removed from memory because it is the root node associated with the snapshot tree view that is to be removed from memory.
- Intermediate node 714 and leaf node 728 are removed from memory because their corresponding count values are "0.”
- FIG. 8 is a flow chart illustrating an embodiment of maintaining a snapshot tree.
- process 800 can be performed by a storage system, such as secondary storage system 104.
- a snapshot tree associated with a particular view is to be deleted.
- a retention time associated with a snapshot tree having a particular TreeID has passed. For example, it may be determined that a snapshot tree view having a TreeID of "1" is to be removed from memory. In other embodiments, a user determines that a snapshot tree is to be deleted.
- the snapshot tree is traversed.
- the snapshot tree is traversed to determine which nodes of the snapshot tree are to be deleted.
- a corresponding count value of one or more nodes associated with the snapshot tree is decremented by one.
- an intermediate node is pointed to by a plurality of root nodes and has a count value greater than one.
- intermediate node 712 as seen in FIG. 7A , has a count value of "3" because root nodes R1, R2, R3 include a pointer to intermediate node 712.
- the count value of any nodes to which the intermediate node points is not decremented. For example, as seen in FIGS.
- Intermediate node 712 includes a pointer to leaf nodes 722, 724, 726. Since the count value associated with intermediate node 712 is greater than or equal to one, the count value associated with leaf nodes 722, 724, 726 are not decremented.
- an intermediate node is only pointed to by a root node associated with the snapshot tree having the particular ID.
- intermediate node 714 as seen in FIG. 7A , has a count value of "1" because root node R1 includes a pointer to intermediate node 714.
- Such an intermediate node has a count value of one and the count value of the intermediate node is decremented from one to zero.
- the count value of any nodes pointed to by the intermediate node is also decremented by one.
- a count value of intermediate node 714 is decremented from "1" to "0.”
- Intermediate node 714 includes a pointer to leaf nodes 728, 730. Since the count value associated with intermediate node 714 is less than one, the count value associated with leaf nodes 728, 730 is also decremented.
- a root node associated with the snapshot tree having the particular TreeID and the one or more nodes having a count value of zero are deleted.
- the root node associated with the snapshot tree having the particular TreeID and the one or more nodes having a count value of zero may be removed from one or more snapshot views that reference the deleted nodes. For example, as seen in FIG. 7C , root node 702, intermediate node 714, and leaf node 728 are removed from a snapshot view. In some embodiments, the portions of memory of storage corresponding to a node having a count value of zero are cleared.
- FIG. 9 is a flow chart illustrating an embodiment of deleting archived snapshots.
- process 900 can be performed by a storage system, such as secondary storage system 104.
- a full snapshot archive of a snapshot tree is performed.
- a snapshot represents a snapshot tree at a particular moment in time.
- the full snapshot archive includes all of the nodes of a snapshot tree at the particular moment in time.
- An incremental snapshot archive includes all of the nodes of a snapshot tree that have been added to a snapshot since a previous snapshot.
- a policy may indicate that a full snapshot archive is to be performed on a periodic basis, by command from a user, and/or after a threshold number of incremental snapshots have been performed.
- a snapshot tree may include nodes associated with one or more previous snapshots.
- tree data structure 380 includes a root node 306 that is associated with nodes associated with a previous snapshot tree (nodes 312, 322, 324, 326, 330).
- a retention policy associated with the previous full snapshot and one or more associated incremental snapshots has passed. For example, to save storage space, a retention policy may indicate that a snapshot is to be deleted after a certain amount of time has passed.
- nodes that are not part of a snapshot associated with a full snapshot archive are deleted from the storage system.
- FIG. 10A is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s).
- partially restored snapshot tree 1000 may be restored by a storage system, such as secondary storage system 104.
- a tree data structure comprising one or more snapshot trees may have been deleted from a storage system, for example, due to a retention time policy associated with the one or more snapshot trees.
- a snapshot tree may be restored to the storage system based on its corresponding archive data.
- a request to access specific portions of data of archived file system data at a particular time is received.
- a portion of the snapshot tree associated with the specific portions of data of the archived file system data may be restored to provide access to the specific portions of data of the archived file system data.
- the non-requested portions of the snapshot tree are pre-fetched from remote storage and restored in the background operation of the storage system.
- a request to access archived file system data at a particular time is received. An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data.
- a snapshot archive corresponding to the particular time is identified.
- the snapshot archive is stored at a remote storage location, such as cloud storage 106 or cluster(s) 108.
- the identified snapshot archive includes serialized snapshot tree data corresponding to the snapshot tree at the particular time.
- the identified snapshot archive also includes file system data corresponding to the file system data at the particular time.
- Archive data 480 of FIG. 4C includes file system data 455 and serialized snapshot tree data 465.
- Serialized snapshot tree data 465 is identified as the serialized snapshot tree data corresponding to the particular time.
- Metadata of a root node of the identified serialized snapshot tree data may be obtained.
- metadata is obtained from a block of the identified serialized snapshot tree data.
- the metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, or a file offset to another block of a different serialized snapshot tree data.
- Block 406 includes a file offset to block 418 of serialized snapshot tree data 465 and a file offset to block 412 of serialized snapshot tree data 461.
- the metadata may also include a node ID, a view ID, and/or one or more node keys.
- the obtained metadata of the root node from the identified serialized snapshot tree data may be used to create a restored snapshot tree instance that includes a representation of the root node that references one or more intermediate nodes.
- partially restored snapshot tree 1000 of FIG. 10A may be created based on serialized snapshot tree data 465 of FIG. 4C .
- Partially restored snapshot tree 1000 includes a root node 1006, stub node 1012a, and stub node 1018a, which correspond to block 406 of serialized snapshot tree data 465, block 412 of serialized snapshot tree data 461, and block 418 of serialized snapshot tree data 465, respectively.
- Stub nodes 1012a, 1018a may each be referred to as a "stub intermediate node".
- root node 1006 includes a nodeID of "R3,” a TreeID of "3,” and a node key of "3.”
- Root node 1006 includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "3,” partially restored snapshot tree 1000 will be traversed to stub node 1012a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "3,” partially restored snapshot tree 1000 will be traversed to stub node 1018a.
- FIG. 10B is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s).
- partially restored snapshot tree 1050 may be restored by a storage system, such as secondary storage system 104.
- partially restored snapshot tree 1050 is a continuation of the restoring partially restored snapshot tree 1000 in response to a request to access specific portions of data of archived file system data at a particular time is received.
- Partially restored snapshot tree 1050 includes root node 1006, intermediate node 1018b, stub node 1012a, stub node 1030a, and stub node 1034a.
- partially restored snapshot tree 1000 is traversed from root node 1006 to stub node 1018a because the data key of "4" is greater than the node key associated with root node 1006 (e.g., "3").
- Stub node 1018a includes a pointer to block 418 of serialized snapshot tree data 465. Metadata corresponding to stub node 1018a, i.e., metadata included in block 418 of serialized snapshot tree data 465, is obtained from the remote storage location.
- the metadata included in block 418 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1000 to become partially restored snapshot tree 1050.
- the metadata included in block 418 of serialized snapshot tree data 465 includes a nodeID of "I4," a TreeID of "3,” a file offset to block 430 of serialized snapshot tree data 461 and a file offset to block 434 of serialized snapshot tree data 465.
- stub node 1018a has been updated to become intermediate node 1018b.
- Intermediate node 1018b corresponds to intermediate node 318 of FIG. 3C .
- intermediate node 1018b Similar to intermediate node 318, intermediate node 1018b includes a nodeID of "I4," a TreeID of "3,” and a node key of "4.” Intermediate node 1018b includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "4," partially restored snapshot tree 1050 will be traversed from intermediate node 1018b to stub node 1034a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "4,” partially restored snapshot tree 1000 will be traversed from intermediate node 1018b to stub node 1030a.
- Intermediate node 1018b includes a pointer to stub node 1030a and a pointer to stub node 1034a because block 418 of serialized snapshot tree data 465 includes a file offset to block 430 of serialized snapshot tree data 461 and a file offset to block 434 of serialized snapshot tree data 465, respectively.
- Stub node 1030a includes a pointer to block 430 of serialized snapshot tree data 461 because block 418 of serialized snapshot tree data 465 includes a file offset to block 430 of serialized snapshot tree data 461.
- Stub node 1034a includes a pointer to block 434 of serialized snapshot tree data 465 because block 418 of serialized snapshot tree data 465 includes a file offset to block 434 of serialized snapshot tree data 465.
- Stub nodes 1030a, 1034a may each be referred to as a "stub leaf node.”
- FIG. 10C is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s).
- partially restored snapshot tree 1060 may be restored by a storage system, such as secondary storage system 104.
- partially restored snapshot tree 1060 is a continuation of the restoring of partially restored snapshot tree 1050 in response to a request to access specific portions of data of archived file system data at a particular time is received.
- Partially restored snapshot tree 1060 includes root node 1006, intermediate node 1018b, stub node 1012a, stub node 1030a, and leaf node 1034b.
- partially restored snapshot tree 1050 is traversed from root node 1006 to intermediate node 1018b because the data key of "4" is greater than the node key associated with root node 1006 (e.g., "3").
- Partially restored snapshot tree 1050 is further traversed from intermediate node 1018b to stub node 1034a because the data key of "4" is less than or equal to the node key associated with intermediate node 1018b (e.g., "4").
- Stub node 1034a includes a pointer to block 434 of serialized snapshot tree data 465. Metadata corresponding to stub node 1034a, i.e., metadata included in block 434 of serialized snapshot tree data 465, is obtained from the remote storage location.
- the metadata included in block 434 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1050 to become partially restored snapshot tree 1060.
- the metadata included in block 434 of serialized snapshot tree data 465 includes a nodeID of "L7,” a TreeID of "3,” and a file offset to one or more blocks of file system data 455.
- stub node 1034a has been updated to become leaf node 1034b.
- Leaf node 1034b corresponds to leaf node 334 of FIG. 3C .
- leaf node 1034b includes a nodeID of "L7,” a TreeID of "3,” and a data value of DATA 4" associated with a data key of "4.”
- the data value stored in a leaf node is a pointer to a storage location in the remote storage location storing the data. In other embodiments, the data value stored in the leaf node is a pointer to a block of serialized snapshot tree data that corresponds to a root node of another snapshot tree.
- FIG. 10D is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s).
- partially restored snapshot tree 1070 may be restored by a storage system, such as secondary storage system 104.
- partially restored snapshot tree 1070 is a continuation of the restoring of partially restored snapshot tree 1000 in response to a request to access archived file system data at a particular time.
- An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data.
- partially restored snapshot tree 1070 is a continuation of the restoring of partially restored snapshot tree 1050 in response to a request to access archived file system data at a particular time.
- Partially restored snapshot tree 1070 includes root node 1006, intermediate nodes 1012b, 1018b (i.e., intermediate stub nodes), and stub nodes 1022a, 1024a, 1026a, 1030a, 1034a (i.e., leaf stub nodes).
- partially restored snapshot tree 1000 is traversed from root node 1006 to stub node 1012a because a stub node represents an incomplete portion of the snapshot tree.
- Stub node 1012a includes a pointer to block 412 of serialized snapshot tree data 461. Metadata corresponding to stub node 1012a, i.e., metadata included in block 412 of serialized snapshot tree data 461, is obtained from the remote storage location.
- the metadata included in block 412 of serialized snapshot tree data 461 and the metadata included in block 418 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1000 to become partially restored snapshot tree 1070.
- the metadata included in block 412 of serialized snapshot tree data 461 includes a nodeID of "I1,” a TreeID of "1,” a file offset to block 422 of serialized snapshot tree data 461, a file offset to block 424 of serialized snapshot tree data 461, and a file offset to block 426 of serialized snapshot tree data 461.
- stub node 1012a has been updated to become intermediate node 1012b.
- Intermediate node 1012b corresponds to intermediate node 312 of FIG. 3C .
- intermediate node 1012b includes a nodeID of "I1,” a TreeID of "1,” and a node keys of "1" and "2.”
- Intermediate node 1012b includes a first set of pointers, a second set of pointers, and a third set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "1," partially restored snapshot tree 1070 will be traversed from intermediate node 1012b to stub node 1022a.
- the second set of pointers indicates that to determine a value of a data key that is greater than the node key of "1" and less than or equal to the node key of "2,” partially restored snapshot tree 1070 will be traversed from intermediate node 1012b to stub node 1024a.
- the third set of pointers indicates that to determine a value of a data key that is greater than the node key of "2,” partially restored snapshot tree 1070 will be traversed from intermediate node 1012b to stub node 1026a.
- Intermediate node 1012b includes a pointer to stub node 1022a, a pointer to stub node 1024a, and a pointer to stub node 1026a because block 412 of serialized snapshot tree data 461 includes a file offset to block 422 of serialized snapshot tree data 461, a file offset to block 424 of serialized snapshot tree data 461, and a file offset to block 426 of serialized snapshot tree data 461, respectively.
- Stub node 1022a includes a pointer to block 422 of serialized snapshot tree data 461 because block 412 of serialized snapshot tree data 461 includes a file offset to block 422 of serialized snapshot tree data 461.
- Stub node 1023 includes a pointer to block 424 of serialized snapshot tree data 461 because block 412 of serialized snapshot tree data 461 includes a file offset to block 424 of serialized snapshot tree data 461.
- Stub node 1026a includes a pointer to block 426 of serialized snapshot tree data 461 because block 412 of serialized snapshot tree data 461 includes a file offset to block 426 of serialized snapshot tree data 461.
- Stub node 1018a includes a pointer to block 418 of serialized snapshot tree data 465.
- Metadata corresponding to stub node 1018a i.e., metadata included in block 418 of serialized snapshot tree data 465, is obtained from the remote storage location.
- the metadata included in block 418 of serialized snapshot tree data 465 includes a nodeID of "I4,” a TreeID of "3,” a file offset to block 430 of serialized snapshot tree data 461 and a file offset to block 434 of serialized snapshot tree data 465.
- stub node 1018a has been updated to become intermediate node 1018b.
- Intermediate node 1018b corresponds to intermediate node 318 of FIG. 3C .
- intermediate node 1018b includes a nodeID of "I4,” a TreeID of "3,” and a node key of "4.”
- Intermediate node 1018b includes a first set of pointers and a second set of pointers.
- the first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "4,” partially restored snapshot tree 1050 will be traversed from intermediate node 1018b to stub node 1034a.
- the second set of pointers indicates that to determine a value of a data key that is greater than the node key of "4,” partially restored snapshot tree 1000 will be traversed from intermediate node 1018b to stub node 1030a.
- Intermediate node 1018b includes a pointer to stub node 1030a and a pointer to stub node 1034a because block 418 of serialized snapshot tree data 465 includes a file offset to block 430 of serialized snapshot tree data 461 and a file offset to block 434 of serialized snapshot tree data 465, respectively.
- Stub node 1030a includes a pointer to block 430 of serialized snapshot tree data 461 because block 418 of serialized snapshot tree data 465 includes a file offset to block 430 of serialized snapshot tree data 461.
- Stub node 1034a includes a pointer to block 434 of serialized snapshot tree data 465 because block 418 of serialized snapshot tree data 465 includes a file offset to block 434 of serialized snapshot tree data 465.
- FIG. 10E is a block diagram illustrating an embodiment of a fully restored snapshot tree.
- fully restored snapshot tree 1080 may be restored by a storage system, such as secondary storage system 104.
- fully restored snapshot tree 1080 is a continuation of the restoring of partially restored snapshot tree 1070 in response to a request to access archived file system data at a particular time.
- An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data.
- Fully restored snapshot tree 1080 includes root node 1006, intermediate nodes 1012b, 1018b, and leaf nodes 1022b, 1024b, 1026b, 1030b, 1034b.
- a request for access to archived file system data at time t 3 was received.
- Stub node 1022a includes a pointer to block 422 of serialized snapshot tree data 461.
- Metadata corresponding to stub node 1022a i.e., metadata included in block 422 of serialized snapshot tree data 461, is obtained from the remote storage location.
- Stub node 1024a includes a pointer to block 424 of serialized snapshot tree data 461.
- Metadata corresponding to stub node 1024a i.e., metadata included in block 424 of serialized snapshot tree data 461, is obtained from the remote storage location.
- Stub node 1026a includes a pointer to block 426 of serialized snapshot tree data 461.
- Metadata corresponding to stub node 1026a i.e., metadata included in block 426 of serialized snapshot tree data 461, is obtained from the remote storage location.
- the metadata included in block 422 of serialized snapshot tree data 461 may be used to update partially restored snapshot tree 1070 to become fully restored snapshot tree 1080.
- the data included in block 422 of serialized snapshot tree data 461 includes a nodeID of "L1,” a TreeID of "1,” and a file offset to one or more blocks of file system data 451.
- stub node 1022a has been updated to become leaf node 1022b.
- Leaf node 1022b corresponds to leaf node 322 of FIG. 3C .
- leaf node 1022b includes a nodeID of "L1,” a TreeID of "1,” and a data value of "DATA 1 " associated with a data key of "1.”
- the metadata included in block 424 of serialized snapshot tree data 461 may be used to update partially restored snapshot tree 1070 to become fully restored snapshot tree 1080.
- the metadata included in block 424 of serialized snapshot tree data 461 includes a nodeID of "L2,” a TreeID of "1,” and a file offset to one or more blocks of file system data 451.
- stub node 1024a has been updated to become leaf node 1024b.
- Leaf node 1024b corresponds to leaf node 324 of FIG. 3C . Similar to leaf node 324, leaf node 1024b includes a nodeID of "L2,” a TreeID of "1,” and a data value of "DATA 2 " associated with a data key of "2.”
- the metadata included in block 426 of serialized snapshot tree data 461 may be used to update partially restored snapshot tree 1070 to become fully restored snapshot tree 1080.
- the metadata included in block 426 of serialized snapshot tree data 461 includes a nodeID of "L3,” a TreeID of "1,” and a file offset to one or more blocks of file system data 451.
- stub node 1026a has been updated to become leaf node 1026b.
- Leaf node 1026b corresponds to leaf node 326 of FIG. 3C .
- leaf node 1026b includes a nodeID of "L3,” a TreeID of "1,” and a data value of "DATA 3 " associated with a data key of "3.”
- Stub node 1030a includes a pointer to block 430 of serialized snapshot tree data 461. Metadata corresponding to stub node 1030a, i.e., metadata included in block 430 of serialized snapshot tree data 461, is obtained from the remote storage location. Stub node 1034a includes a pointer to block 434 of serialized snapshot tree data 465. Metadata corresponding to stub node 1034a, i.e., metadata included in block 434 of serialized snapshot tree data 465, is obtained from the remote storage location.
- the metadata included in block 430 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1070 to become fully restored snapshot tree 1080.
- the metadata included in block 430 of serialized snapshot tree data 461 includes a nodeID of "L5,” a TreeID of "1,” and a file offset to one or more blocks of file system data 451.
- stub node 1030a has been updated to become leaf node 1030b.
- Leaf node 1030b corresponds to leaf node 330 of FIG. 3C . Similar to leaf node 330, leaf node 1030b includes a nodeID of "L5,” a TreeID of "1,” and a data value of "DAT A 5 " associated with a data key of "5.”
- the metadata included in block 434 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1050 to become partially restored snapshot tree 1060.
- the metadata included in block 434 of serialized snapshot tree data 465 includes a nodeID of "L7,” a TreeID of "3,” and a file offset to one or more blocks of file system data 455.
- stub node 1034a has been updated to become leaf node 1034b.
- Leaf node 1034b corresponds to leaf node 334 of FIG. 3C .
- leaf node 1034b includes a nodeID of "L7,” a TreeID of "3,” and a data value of "DAT A 4 "" associated with a data key of "4.”
- the data value stored in a leaf node is a pointer to a storage location in the remote storage location storing the data. In other embodiments, the data value stored in the leaf node is a pointer to a block of serialized snapshot tree data that corresponds to a root node of another snapshot tree.
- FIG. 11A is a flow chart illustrating an embodiment of restoring a snapshot tree.
- process 1100 may be performed by a storage system, such as secondary storage system 104.
- a request to access an archived file system data associated with a particular point in time is received.
- the request may be a read request or a write request.
- the request may be to access one or more specific files associated the file system data at a particular point in time.
- the request may be to access an entire file system data corresponding to a system at a particular point in time.
- the archived file system data may correspond to the entire contents of a storage volume of a system at a particular point in time.
- the system may become corrupted (e.g. infected by virus, infected by malware, storage failure) and it may be desired to restore the entire file system data to the particular point in time.
- serialized snapshot tree data corresponding to the request is identified.
- the file system data associated with the particular point in time is associated with a corresponding snapshot tree.
- the file system data associated with the particular point in time and corresponding snapshot tree are associated with a corresponding snapshot archive.
- the storage system may store a data structure (e.g., table, list, etc.) that associates different versions of snapshot trees with their corresponding snapshot archive.
- a file system manager of the storage system may use the data structure to identify the snapshot tree associated with the file system data at the particular point in time and to identify the snapshot archive associated with the identified snapshot tree.
- Metadata of a root node from the identified serialized snapshot tree data is obtained.
- the metadata is stored in the identified serialized snapshot tree data and includes archived contents that can be used to restore the root node.
- the metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, or a file offset to another block of a different serialized snapshot tree data.
- Block 406 includes a file offset to block 418 of serialized snapshot tree data 465 and a file offset to block 412 of serialized snapshot tree data 461.
- the metadata may also include a node ID, a view ID, and/or a node key.
- the obtained metadata of the root node is used to create a restored snapshot tree instance that includes a representation of the root node that references one or more stub intermediate nodes.
- a stub node is a placeholder for a node of the snapshot tree.
- the stub node corresponds to a specific node of the snapshot tree and includes a pointer to a location of information associated with the specific node of the snapshot tree.
- the stub node may save storage space and reduce the amount of time to process the request because data that is not associated with the request does not need to be fetched from the remote storage location. For example, to process a request associated with the data key of "4", data associated with a key of less than or equal to the node key of root node 1006 does not need to be fetched from the remote storage location.
- a partially restored snapshot tree may be created based on the serialized snapshot tree data.
- partially restored snapshot tree 1000 includes a root node 1006, stub node 1012a, and stub node 1018a, which correspond to block 406 of serialized snapshot tree data 465, block 412 of serialized snapshot tree data 461, and block 418 of serialized snapshot tree data 465, respectively.
- access to the restored snapshot tree instance is allowed via the root node.
- access to the restored snapshot tree instance that includes the stub nodes right away instead of waiting to restore the entire snapshot tree instance faster access to the snapshot tree instance is provided.
- using stub nodes allows storage/memory to be conserved because potentially unused portions of the snapshot tree and associated file contents do not have to be restored until needed.
- the request to access the archived file system data was a read request
- the requested value associated with the read request may be provided.
- a clone of the restored snapshot tree for example as described with respect to FIGS 12A-12C , may be created to perform the write request.
- FIG. 11B is a flow chart illustrating an embodiment of restoring a snapshot tree.
- process 1120 may be performed by a storage system, such as secondary storage system 104.
- a request to access specific portions of data of archived file system data at a particular time is received.
- a portion of the snapshot tree associated with the specific portions of data of the archived file system data may be restored to provide access to the specific portions of data of the archived file system data.
- Process 1120 may be performed to restore the non-requested portions of the snapshot tree.
- a request to restore a snapshot tree is received and process 1100 of Figure 11A is performed to initially provide fast access to an instance of the snapshot tree with stubs.
- process 1120 of Figure 11B is performed in the background to replace the stubs of the snapshot tree with restored nodes, allowing the entire snapshot tree to be restored in the background while initial access to the snapshot tree is allowed via the root node in 1110 of Figure 11A .
- a request to access archived file system data at a particular time is received.
- An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data.
- Process 1120 may be performed to restore the entire snapshot tree.
- the snapshot tree is traversed to identify one or more stub node(s).
- snapshot tree 1060 may be traversed to identify stub nodes 1012a, 1030a.
- Stub node 1012a may be identified in the event a data key that is less than or equal to the node key of root node 1006 is desired to be restored.
- Stub node 1030a may be identified in the event a data key that is greater than the node key of root node 1006 and greater than the node key of intermediate node 1018b is desired to be restored.
- metadata corresponding to the identified one or more stub nodes is pre-fetched from the archived data.
- the metadata corresponding to the identified one or more stub nodes may be included in the archive data that was archived via 506 of process 500.
- the metadata is stored in the archive data snapshot tree data and includes contents that can be used to restore the snapshot tree node(s) corresponding the stub node(s).
- the archive data includes file system data and serialized snapshot tree data.
- the metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, a file offset to another block of a different serialized snapshot tree data, a node ID, a view ID, and/or one or more node keys.
- the metadata corresponding to the identified one or more stub nodes may be pre-fetched as a background operation of the storage system. In some embodiments, the metadata corresponding to the identified one or more stub nodes is pre-fetched without a specific request from a user to restore the one or more stub nodes. In some embodiments, the metadata corresponding to the identified one or more stub nodes is pre-fetched based on a particular usage pattern.
- order of traversal of the nodes in 1122 is based on a likelihood the node will be accessed. If typical usage pattern of file contents are known (e.g., particular files are known to be likely accessed often or first based on prior data usage pattern and/or received specification), then the nodes of the snapshot tree corresponding to those files may be traversed and restored prior to restoring other less likely to be accessed nodes.
- the obtained metadata is used to update the snapshot tree by replacing the identified stub node(s) with corresponding restored node(s).
- stub node 1012a includes a pointer to block 412 of serialized snapshot tree data 461.
- Metadata corresponding to stub node 1012a i.e., metadata included in block 412 of serialized snapshot tree data 461, is obtained from a remote storage location, such as cloud storage 106.
- the metadata included in block 412 of serialized snapshot tree data 461 may be used to update partially restored snapshot tree 1060.
- the metadata included in block 412 of serialized snapshot tree data 461 includes a nodeID of "I1,” a TreeID of "1,” a file offset to block 422 of serialized snapshot tree data 461, a file offset to block 424 of serialized snapshot tree data 461, a file offset to block 426 of serialized snapshot tree data 461, and node keys "1" and "2.”
- Stub node 1012a may be updated to become intermediate node 1012b.
- Intermediate node 1012b corresponds to intermediate node 312 of FIG. 3C .
- intermediate node 1012b includes a nodeID of "I1,” a TreeID of "1,” and a node keys of "1" and "2.”
- Intermediate node 1012b includes a first set of pointers, a second set of pointers, and a third set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "1," partially restored snapshot tree 1070 will be traversed from intermediate node 1012b to stub node 1022a.
- the second set of pointers indicates that to determine a value of a data key that is greater than the node key of "1" and less than or equal to the node key of "2,” partially restored snapshot tree 1070 will be traversed from intermediate node 1012b to stub node 1024a.
- the third set of pointers indicates that to determine a value of a data key that is greater than the node key of "2,” partially restored snapshot tree 1070 will be traversed from intermediate node 1012b to stub node 1026a.
- Intermediate node 1012b includes a pointer to stub node 1022a, a pointer to stub node 1024a, and a pointer to stub node 1026a because block 412 of serialized snapshot tree data 461 includes a file offset to block 422 of serialized snapshot tree data 461, a file offset to block 424 of serialized snapshot tree data 461, and a file offset to block 426 of serialized snapshot tree data 461, respectively.
- Stub node 1022a includes a pointer to block 422 of serialized snapshot tree data 461 because block 412 of serialized snapshot tree data 461 includes a file offset to block 422 of serialized snapshot tree data 461.
- Stub 1024a includes a pointer to block 424 of serialized snapshot tree data 461 because block 412 of serialized snapshot tree data 461 includes a file offset to block 424 of serialized snapshot tree data 461.
- Stub node 1026a includes a pointer to block 426 of serialized snapshot tree data 461 because block 412 of serialized snapshot tree data 461 includes a file offset to block 426 of serialized snapshot tree data 461.
- stub node 1030a includes a pointer to block 430 of serialized snapshot tree data 461.
- Stub node 1030a includes a pointer to block 430 of serialized snapshot tree data 461.
- Metadata corresponding to stub node 1030a i.e., metadata included in block 430 of serialized snapshot tree data 461, is obtained from the remote storage location.
- the metadata included in block 430 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1060.
- the data included in block 430 of serialized snapshot tree data 461 includes a nodeID of "L5," a TreeID of "1,” and a file offset to one or more blocks of file system data 451.
- leaf node 1030a may be updated to become leaf node 1030b.
- Leaf node 1030b corresponds to leaf node 330 of FIG. 3C . Similar to leaf node 330, leaf node 1030b includes a nodeID of "L5," a TreeID of "1,” and a data value of " DAT A 5" associated with a data key of "5.” The data value of "DAT A 5 " may be retrieved from the one or more blocks of file system data 451 stored at the remote storage location.
- process 1120 determines whether there are any more stub nodes. In the event there are more stub nodes, process 1120 returns to 1124.
- intermediate node 1012b may include a pointer to stub nodes 1022a, 1024a, 1026a.
- Process 1120 may return to 1124 to update the snapshot tree to include leaf node data that corresponds to stub nodes 1022a, 1024a, 1026a.
- process 1120 ends and the snapshot tree has been fully restored. For example, partially restored snapshot tree 1060 may be fully restored to become fully restored snapshot tree 1080.
- FIG. 11C is a flow chart illustrating an embodiment of selectively restoring nodes of a snapshot tree based on a request.
- process 1140 may be performed by a storage system, such as secondary storage system 104.
- a request to access desired data associated with a snapshot tree restored from archive data is received.
- the request may be a write request or a read request.
- the request may be a request to read a value associated with a data key of "4.”
- the request may be a request to modify and write a new value for the data key of "4.”
- the request received in 1102 of Figure 11A is performed to initially restore a snapshot tree that includes stub nodes.
- process 1140 is performed to selectively replace stub nodes with restored nodes required to provide access to the desired data.
- the process of restoring the snapshot tree is started from root node of the restored snapshot tree.
- the process of restoring the snapshot tree may start from root node 1006 of partially restored snapshot tree 1000.
- the restored snapshot tree is traversed using a key associated with the desired data by identifying a next node of the snapshot tree.
- the identified next node is a stub node. For example, partially restored snapshot tree 1000 is traversed from root node 1006 to stub node 1018a because the data key of "4" is greater than the node key "3" of root node 1006.
- process 1140 proceeds to 1150.
- process 1140 proceeds to 1158.
- metadata corresponding to the stub node is obtained from the archive data.
- the metadata corresponding to the stub node may be included in the archive data that was archived via 506 of process 500.
- the metadata is stored in the archive data snapshot tree data and includes contents that can be used to restore the snapshot tree node corresponding the stub node.
- the archive data includes file system data and serialized snapshot tree data.
- the metadata may be stored in a block of the serialized snapshot tree data.
- the metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, a file offset to another block of a different serialized snapshot tree data, a node ID, a view ID, and/or one or more node keys.
- the obtained metadata is used to update the snapshot tree by replacing the identified stub node(s) with corresponding restored node(s).
- the data included in block 418 of serialized snapshot tree data 465 may be used to update partially restored snapshot tree 1000 to become partially restored snapshot tree 1050.
- the data included in block 418 of serialized snapshot tree data 465 includes a nodeID of "I4," a TreeID of "3,” a file offset to block 430 of serialized snapshot tree data 461 and a file offset to block 434 of serialized snapshot tree data 465.
- stub node 1018a has been updated to become intermediate node 1018b.
- Intermediate node 1018b corresponds to intermediate node 318 of FIG.
- intermediate node 1018b Similar to intermediate node 318, intermediate node 1018b includes a nodeID of "I4," a TreeID of "3,” and a node key of "4.” Intermediate node 1018b includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "4," partially restored snapshot tree 1050 will be traversed from intermediate node 1018b to stub node 1034a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "4,” partially restored snapshot tree 1000 will be traversed from intermediate node 1018b to stub node 1030a.
- Intermediate node 1018b includes a pointer to stub node 1030a and a pointer to stub node 1034a because block 418 of serialized snapshot tree data 465 includes a file offset to block 430 of serialized snapshot tree data 461 and a file offset to block 434 of serialized snapshot tree data 465, respectively.
- Stub node 1030a includes a pointer to block 430 of serialized snapshot tree data 461 because block 418 of serialized snapshot tree data 465 includes a file offset to block 430 of serialized snapshot tree data 461.
- Stub node 1034a includes a pointer to block 434 of serialized snapshot tree data 465 because block 418 of serialized snapshot tree data 465 includes a file offset to block 434 of serialized snapshot tree data 465.
- process 1140 proceeds to the restored node.
- process 1140 may proceed to intermediate node 1018b.
- the currently visited node determines whether the currently visited node provides direct access to the desired data.
- the currently visited node may not provide direct access to the desired data because the restored node is an intermediate node of the restored snapshot tree.
- the currently visited node may provide direct access to the desired data because the restored node is a leaf node of the restored snapshot tree and it is determined in 1156 that the currently visited node provides direct access to the desired data if the currently visited node is a leaf node that links to a storage portion where the desired data is stored.
- the currently visited node is a leaf node that links to another tree structure (e.g., linked to a second tree structure used to identify blocks of an individual file)
- process 1140 proceeds to 1146.
- intermediate node 1018b does not provide access to the desired data.
- the process of restoring the snapshot tree may return to 1146 to restore stub node 1034a.
- process 1140 proceeds to 1160. For example, a leaf node has been restored.
- the desired data is obtained and access is provided to the desired data.
- read access is provided to the desired data.
- the desired data may be retrieved from a storage location of the storage system.
- write access is provided to the desired data.
- the desired data may be modified using a copy-on-write procedure.
- a snapshot tree associated with the desired data may be cloned, as described in FIGS. 12A-C .
- the snapshot tree associated with the desired data may be cloned by creating a copy of the root node of the snapshot tree associated with the desired data.
- the root node clone includes the same set of pointers as the copied root node, but includes a different nodeID and a different view identifier.
- the cloned snapshot tree is traversed from the root node copy to the leaf node associated with the desired data.
- the view identifier associated with each node along the path to the leaf node associated with the desired data is inspected.
- the cloned snapshot tree is traversed to the next node along the path.
- the view identifier associated with a node does not match the view identifier associated with the root node copy, then a copy of the node with the non-matching view identifier is created.
- the copy of the node with the non-matching view identifier includes the same set of pointers as the copied node, but includes a different node ID and a view identifier of the root node copy.
- a pointer of the node that pointed to the node with the non-matching view identifier is updated.
- the pointer is updated to point to the copy of the node with the non-matching view identifier instead of the node with the non-matching view identifier.
- the copy-on write process continues until the leaf node associated with the desired data is copied and modified.
- the root node copy may be deleted.
- FIG. 12A is a block diagram illustrating an embodiment of cloning a partially restored snapshot tree.
- tree data structure 1200 may be created by a storage system, such as secondary storage system 104.
- a clone of a restored snapshot tree is created after the snapshot tree is restored to a desired state (e.g., fully restored or partially restored to include desired data value(s)).
- a clone of a restored snapshot tree is created after the storage system receives a request to modify one or more data values associated with the restored snapshot tree.
- the cloned partially restored snapshot tree represents a new view of the partially restored snapshot tree.
- tree data structure 1200 includes a partially restored snapshot tree that is comprised of root node 1006, intermediate node 1018b, stub nodes 1012a, 1030a, and leaf node 1034b.
- the snapshot tree comprising root node 1006, intermediate node 1018b, stub nodes 1012a, 1030a, and leaf node 1034b is cloned.
- a copy of the root node is created.
- the root node copy includes the same set of pointers as the original node. However, the root node copy also includes a different NodeID and a different TreeID.
- the TreeID is the identifier associated with a view.
- root node 1206 is a copy of root node 1006. Similar to root node 1006, root node 1206 includes the same pointers as root node 1006. However, among other things, root node 1206 includes a different node identifier and a different view identifier. Root node 1206 includes a first set of pointers to stub node 1012a. The first set of pointers associated with a data key k less than or equal to the node key indicates that traversing tree data structure 1200 from root node 1206 to stub node 1012a will lead to a leaf node with a data key that is less than or equal to the node key of root node 1206.
- Root node 1206 includes a second set of pointers to intermediate node 1018b.
- the second set of pointers associated with a data key k greater than the node key indicates that traversing tree data structure 1200 from root node 1206 to intermediate node 1018b will lead to a leaf node with a data key that is greater than the node key of root node 1206.
- FIG. 12B is a block diagram illustrating an embodiment of modifying a clone of a partially restored snapshot tree.
- tree data structure 1250 may be modified by a file system manager, such as file system manager 105.
- Tree data structure 1250 may be a current view of the file system data. A current view may still accept one or more changes to the data. Because a snapshot represents a perspective of the file system metadata that is "frozen" in time, one or more copies of one or more nodes affected by a change to file system metadata, are made.
- the value " DAT A 4 " " has been modified to be “ DAT A 4 "' .”
- the value " DAT A 4 "'” is stored in a different storage block of the storage system than the value " DAT A 4 "' .”
- a corresponding modification is made to the snapshot tree so that a node pointing to the storage block associated with the storage block "DAT A 4 "” points to the storage block associated with the value "DAT A 4 ".”
- the file system manager starts at root node 1206 to make a corresponding modification to the snapshot tree because that is the root node associated with the partially cloned snapshot tree.
- the value "DAT A 4 ' " is associated with the data key "4."
- the file system manager traverses tree data structure 1250 from root node 1206 until it reaches a target node, in this example, leaf node 1034b.
- the file system manager compares the TreeID at each intermediate node and leaf node with the TreeID of the root node. In the event the TreeID of a node matches the TreeID of the root node, the file system manager proceeds to the next node. In the event the TreeID of a node does not match the TreeID of the root node, a shadow copy of the node with the non-matching TreeID is made.
- the file system manager begins at root node 1206 and proceeds to intermediate node 1018b.
- the file system manager compares the TreeID of intermediate node 1018b with the TreeID of root node 1206, determines that the TreeID of intermediate node 1018b does not match the TreeID of root node 1206, and creates a copy of intermediate node 1018b.
- the intermediate node copy 1218 includes the same set of pointers as intermediate node 1018b, but includes a TreeID of "5" to match the TreeID of root node 1206.
- the file system manager updates a set of pointers of root node 1206 to point to intermediate node 1218 instead of pointing to intermediate node 1018b.
- the file system manager traverses tree data structure 1206 from intermediate node 1218 to leaf node 1034b, determines that the TreeID of leaf node 1034b does not match the TreeID of root node 1206, and creates a copy of leaf node 1034b.
- Leaf node copy 1234 stores the modified value " DAT A 4 "' " and includes the same TreeID as root node 1206.
- the file system manager updates a pointer of intermediate node 1218 to point to leaf node 1234 instead of pointing to leaf node 1034b.
- FIG. 12C is a block diagram illustrating an embodiment of a modified partially cloned snapshot tree.
- the tree data structure 1250 shown in FIG. 12C illustrates a result of the modifications made to tree data structure 1250 as described with respect to FIG. 12B .
- the snapshot trees of tree data structure 1250 may be maintained in a similar fashion as described above with respect to FIG. 7A , 7B , and 7C .
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
Description
- This application claims priority to
U.S. Provisional Patent Application No. 62/555,456 - A snapshot is the state of a storage entity (e.g., storage volume) at a particular point in time. A full snapshot of a storage entity may be composed of large amounts of data (e.g., terabytes, petabytes, etc.). Performing a full snapshot of a storage entity at frequent intervals (e.g., hourly, daily) requires large amounts of storage to store the snapshots. To reduce the amount of storage required, an incremental snapshot of the storage entity may be performed between full snapshots. An incremental snapshot includes the changes that have occurred to the storage entity since the previous (full or incremental) snapshot. However, mounting a volume that includes a full snapshot and several incremental snapshots may require large amounts of storage.
- For example, suppose a full snapshot of a storage entity comprised of 1 TB of data was performed at t = 0 and an incremental snapshot of 100 GB of data was performed at each t, from t = 1 to t = 10. Some of the data from an incremental snapshot may overwrite the data from the full snapshot and/or a previous incremental snapshot. However, to recover and mount the storage entity at t = 10 requires starting from the full snapshot at t = 0 and adding each incremental snapshot to the storage entity until the combined snapshots reproduce the state of the storage entity at t = 10. In this example, 2 TB of storage is required to recover the storage entity comprised of 1 TB at t = 10.
- Although the above process reduces the amount of storage required to store the backup data, if only a portion of the backed up storage entity is initially desired to be recovered, recovering and updating the full snapshot may consume inefficient amount of storage, time and processing resources.
- Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
-
FIG. 1 is a block diagram illustrating an embodiment of a distributed storage system. -
FIG. 2A is a block diagram illustrating an embodiment of a snapshot tree storing file system data. -
FIG. 2B is a block diagram illustrating an embodiment of cloning a snapshot tree. -
FIG. 2C is a block diagram illustrating an embodiment of modifying a snapshot tree. -
FIG. 2D is a block diagram illustrating an embodiment of a modified snapshot tree. -
FIG. 2E is a block diagram illustrating an embodiment of leaf node data. -
FIG. 3A is a block diagram illustrating an embodiment of a snapshot tree at a particular moment in time. -
FIG. 3B is a block diagram illustrating an embodiment of a snapshot tree at a particular moment in time. -
FIG. 3C is a block diagram illustrating an embodiment of a snapshot tree at a particular moment in time. -
FIG. 3D is a block diagram illustrating an embodiment of a snapshot tree at a particular moment in time. -
FIG. 4A is a block diagram illustrating an embodiment of archive data. -
FIG. 4B is a block diagram illustrating an embodiment of archive data. -
FIG. 4C is a block diagram illustrating an embodiment of archive data. -
FIG. 4D is a block diagram illustrating an embodiment of archive data. -
FIG. 5 is a flow chart illustrating an embodiment of archiving data. -
FIG. 6A is a flow chart illustrating an embodiment of restoring archived data. -
FIG. 6B is a flow chart illustrating an embodiment of retrieving archived data. -
FIGS. 7A ,7B , and7C are block diagrams illustrating an embodiment of maintaining a snapshot tree. -
FIG. 8 is a flow chart illustrating an embodiment of maintaining a snapshot tree. -
FIG. 9 is a flow chart illustrating an embodiment of deleting archived snapshots. -
FIG. 10A is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). -
FIG. 10B is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). -
FIG. 10C is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). -
FIG. 10D is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). -
FIG. 10E is a block diagram illustrating an embodiment of a fully restored snapshot tree. -
FIG. 11A is a flow chart illustrating an embodiment of restoring a snapshot tree. -
FIG. 11B is a flow chart illustrating an embodiment of restoring a snapshot tree. -
FIG. 11C is a flow chart illustrating an embodiment selectively restoring nodes of a snapshot tree based on a request. -
FIG. 12A is a block diagram illustrating an embodiment of cloning a partially restored snapshot tree. -
FIG. 12B is a block diagram illustrating an embodiment of modifying a clone of a partially restored snapshot tree. -
FIG. 12C is a block diagram illustrating an embodiment of a modified partially cloned snapshot tree. - The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term 'processor' refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
- A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
- Tree data structures may be used in organizing and storing large amounts of data. For example, a tree data structure is searched to retrieve a value stored in the tree data structure using a data key associated with the value. Often it is desirable to periodically archive the tree data structure to archive changes and provide fault tolerance. If the storage where the tree data structure is to be archived natively understands and supports tree data structures, it can be directly copied to the archive storage in a native format. However, many storage solutions do not natively support tree data structures. The storage solutions that natively support tree data structures are often costly and inefficient for use as an archive.
- It may be more efficient to archive data to a storage/archive medium/system that is unable to natively support the tree data structure. For example, traditional third-party cloud storage solutions provide the ability to store computer files in a reliable manner but lack the ability to natively understand and support a tree data structure (e.g., does not natively provide the ability to perform tree data structure transactions). In some embodiments, to archive the tree data structure to such a storage medium, the tree data structure is serialized into a data file comprising a flat set of data. The serialized data file may be encoded in a manner that allows the serialized data file to be utilized to reconstruct a desired portion of the tree data structure to obtain a data of interest from the serialized data file without the need to reconstruct the entire tree data structure.
- Serializing is a process by which a data file is generated to store data in a manner that mimics the structure of a tree data structure. The serialized data file may be encoded in a manner that allows the serialized data file to be utilized to reconstruct a desired portion of the tree data structure to obtain a data of interest from the serialized data file without the need to reconstruct the entire tree data structure. The serialized data file is a flat set of data comprised of a plurality of data blocks. A data block of the data file may correspond to a node of a tree data structure. The order of the data blocks of the serialized data file corresponds to an order of the tree data structure. A tree data structure may have a root node, a plurality of intermediate nodes, and a plurality of leaf nodes. The serialized data file first may store the root node, then the plurality of intermediate nodes, and then the plurality of leaf nodes. For example, a first data block of the serialized data file may correspond to a root node of the tree data structure, a second data block of the serialized data file may correspond to a first intermediate node of the tree data structure, a third data block of the serialized data file may correspond to a second intermediate node of the tree data structure, a fourth data block of the serialized data file may correspond to a first leaf node of the tree data structure, ...and an nth data block of the serialized data file may correspond to the nth leaf node of the tree data structure.
- A node of the tree data structure may include a pointer to another node of the tree data structure. When the tree data structure is serialized, a data block of the serialized data file may be configured to store one or more file offsets to one or more data blocks corresponding to one or more corresponding nodes of the tree data structure. For example, the first data block of the data file corresponding to the root node of the tree data structure may store a file offset to the second data block of the data file corresponding to an intermediate node of the tree data structure. A data block corresponding to a leaf node of the tree data structure may store archived file system data. In some embodiments, a data block corresponding to a node of the tree data structure includes a file offset to a data block of a different serialized data file.
- Snapshot archive management is disclosed. File system data may be stored in a tree data structure comprised of one or more snapshot trees. In some embodiments, a snapshot tree (e.g., Cohesity Snaptree) is based on a tree data structure and may include a root node, one or more intermediate nodes, and one or more leaf nodes associated with each intermediate node. The root node is the starting point of a snapshot tree and may include pointers to one or more other nodes. The root node includes an identifier that indicates a view with which the root node is associated. An intermediate node is a node to which another node points (e.g., root node, other intermediate node) and includes one or more pointers to other nodes. A snapshot tree may include one or more levels of intermediate nodes. A leaf node is a node at the bottom of a snapshot tree. A leaf node may be configured to store key-value pairs of file system data. In some embodiments, a leaf node includes a pointer to another snapshot tree. Each node of the tree data structure includes an identifier of a snapshot tree that identifies a tree data structure with which the node is associated (e.g., TreeID).
- A snapshot of the file system data may be performed according to one or more backup policies. The backup policy may indicate when and how a snapshot of the system is to be performed. The snapshot of the system captures a view of the file system at a particular point in time. The view may be a current view or a snapshot view. A current view may represent a state of the file system that is up-to-date and capable of receiving one or more modifications to the snapshot tree that correspond to modifications to the file system data. A snapshot view may represent a state of the file system at a particular moment in time in the past and is not updated. The view of a snapshot may change from a current view to a snapshot view when a subsequent snapshot is performed. For example, a snapshot at t = 1 may be a current view and accept one or more modifications to the snapshot tree. When another snapshot is performed at t = 2, another root node is added to the tree data structure. The snapshot associated with t = 1 at t = 2 becomes a snapshot view and the snapshot at t = 2 is a current view of the snapshot tree.
- A tree data structure may be utilized to organize and store data associated with a snapshot (e.g., stored in a snapshot tree). The tree data structure can be used to capture different versions of file system data at different moments in time. In some embodiments, the tree data structure allows a chain of snapshot trees (i.e., different snapshot tree versions) to be linked together by allowing a node of a later version of a snapshot tree to reference a node of a previous version of a snapshot tree. Each time a snapshot is performed, a new root node may be created and the new root node includes the set of pointers included in the previous root node, that is, the new root node includes one or more pointers to an intermediate node or leaf node associated with a previous snapshot tree. However, the new root node includes a view identifier (e.g., TreeID) that is different than the view identifier (e.g., TreeID) of the previous root node. The view identifier associated with a node identifies a snapshot tree and view with which the node is associated. In some embodiments, the previous root node is deleted after a snapshot is performed. When a leaf node of a current view of a snapshot tree is modified, the snapshot tree is traversed from the root node of the current view to the leaf node. The view identifier associated with each intermediate node is compared with the view identifier associated with the root node of the current view. In the event the view identifier of the root node matches the view identifier of the intermediate node, the snapshot tree is traversed to the next node. In the event the view identifier of the root node does not match the view identifier of the intermediate node, a shadow copy of the node with the non-matching view identifier is made. The shadow copy includes the same set of pointers as the copied node, but includes a view identifier to match the view identifier of the root node and a different node ID. When the snapshot tree is traversed to the leaf node that is to be modified, the view identifier associated with the leaf node to be modified is compared with the view identifier associated with the root node of the current view, and a new leaf node is created. The new leaf node includes the modified value and a view identifier that matches the view identifier of the root node.
- A snapshot policy may indicate that a full snapshot or an incremental snapshot is to be performed and stored at a storage system. The full snapshot may provide a complete view of the snapshot tree at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot tree at the particular moment in time. An incremental snapshot may provide a partial view of the snapshot tree at a particular moment time. The incremental snapshot may store the difference between a snapshot and a previous snapshot and one or more pointers to one or more nodes associated with one or more previous snapshots.
- A snapshot may be archived to a remote storage system. Archiving a snapshot frees up storage that was used to store the snapshot. An archive may be used for data that is infrequently accessed (i.e., cold data). An archive may be used for data for which a loading penalty due to the need to retrieve the data from an archive will not hurt the performance of a system. An archive policy may indicate that the file system data is to be archived to a remote storage system, such as a cloud storage system or a cluster storage system. In some embodiments, the archive policy may indicate that a full snapshot archive of the file system data and/or an incremental snapshot archive of the file system data is to be performed. A full snapshot archive is an archive of a full snapshot. It includes all the nodes of a snapshot tree without referring back to the node of a previous snapshot tree. An incremental snapshot archive is an archive of an incremental snapshot. It includes the nodes that represent the difference between a snapshot and a previous snapshot and one or more references to one or more nodes associated with one or more previous snapshots.
- A snapshot archive may include file system data and serialized snapshot tree data. File system data includes one or more data chunks that make up data of a file system. In some embodiments, a version of file system data is comprised of one or more blocks that are segmented into one or more chunks of data, a chunk identifier is computed for each chunk of data, and the chunk identifiers are stored as file system metadata. The leaf nodes of a snapshot tree may store the file system metadata. In addition to archiving the file system data, a corresponding serialized snapshot tree data is archived to the cloud storage system or the cluster storage system. A serialized snapshot tree data stores the structure of the snapshot tree associated with the file system data as a flat set of data that is comprised of one or more blocks. Each block of the flat set of data corresponds to a node of the snapshot tree. The blocks that correspond to an intermediate node or a root node may include a file offset to another block of the serialized snapshot tree data or a file offset to another block of a different serialized snapshot tree data. A block that corresponds to a leaf node may include a file offset to a portion of the archived file system data.
- A request for data at a particular time may be received from a user. In some instances, the snapshots associated with the data at the particular time may not be stored locally and the archived version of the snapshot may be retrieved to determine the data at the particular time. Instead of starting with the last full snapshot and adding one or more incremental snapshots to the last full snapshot to determine the value of the data at the particular time, a view of the file system data at the particular time may be determined by retrieving the serialized snapshot tree data associated with the particular time and deserializing the serialized snapshot tree data associated with the particular time. Deserializing is a process by which at least a portion of a tree data structure is reproduced from a data file. In some embodiments, one or more additional associated serialized snapshot tree data sets may be retrieved to determine the data at the particular time. The generated view reproduces a portion of or the entire tree data structure at the particular time. The requested data may be determined based on the view, retrieved from remote storage, and provided to the user.
- In some embodiments, restoring the entire snapshot tree data structure and associated archived file contents at the particular time may be too expensive (e.g., requires large amounts of time and system resources) to because the entire serialized archive associated with the particular time may be very large (e.g., TBs) compared to a small amount of initial amount of data desired to be accessed using the restored snapshot tree. The serialized snapshot tree data associated with the snapshot tree associated with the particular may be identified and used to at least partially restore the snapshot tree. Metadata of a root node of the identified serialized snapshot tree data may be used to create a partially restored snapshot tree. The partially restored snapshot tree may include a representation of the root node that references one or more stub nodes. The partially restored snapshot tree may be traversed using a key associated with a user's request and one or more encountered stub nodes may be restored using the serialized snapshot tree data that corresponds to the encountered stub nodes. The user's request may be completed after the snapshot tree is restored to include a restored leaf node associated with the user's request. This reduces the amount to time and storage needed to restore the user's request. In some embodiments, the non-requested portions of file system data are restored as a background operation of the storage system.
-
FIG. 1 is a block diagram illustrating an embodiment of a distributed storage system. In the example shown,system 100 includesprimary storage system 102,secondary storage 104,cloud storage 106, and one ormore clusters 108. -
Primary storage system 102 is a computing system that stores file system data.Primary storage system 102 may be comprised of one or more servers, one or more computing devices, one or more storage devices, and/or a combination thereof.Primary storage system 102 may be configured to backup file system data tosecondary storage system 104 according to one or more backup policies. In some embodiments, a backup policy indicates that file system data is to be backed up on a periodic basis (e.g., hourly, daily, weekly, monthly, etc.). In other embodiments, a backup policy indicates that file system data is to be backed up when a threshold size of data has changed. In other embodiments, a backup policy indicates that file system data is to be backed up upon a command from a user associated withprimary storage system 102. -
Secondary storage system 104 is a storage system configured to backup file system data received fromprimary storage system 102.Secondary storage system 104 may protect a large volume of applications while supporting tight business requirements (recovery time objective (RTO) and recovery point objective (RPO)).Secondary storage system 104 may unify end-to-end protection infrastructure - including target storage, providing backup, replicating data, disaster recover, and/or cloud tiering.Secondary storage system 104 may provide scale-out, globally deduped, highly available storage to consolidate all secondary data, including backups, files, and test/dev copies.Secondary storage system 104 simplifies backup infrastructure and eliminates the need to run separate backup software, proxies, media servers, and archival.Secondary storage system 104 may be fully integrated with a virtual machine (VM) centralized management tool, such as vCenter, and an applications programming interface (API) for data protection.Secondary storage system 104 may reduce the amount of time to perform RPOs and support instantaneous RTOs by creating a clone of a backup VM and running the VM directly fromsecondary storage system 104.Secondary storage system 104 may integrate natively with one or more cloud servers. This eliminates the need to use tape archives by using one or more cloud servers for long-term data archival. -
Secondary storage system 104 may be configured to implement policy based archival of older snapshots on-prem to cloud storage for long-term retention. The cloud archive allows data to be indexed for fast search and retrieval back to on-prem from the cloud. The cloud archive allows recovery of data to a different site in the event the primary cluster fails. The cloud archive may allow data encryption in-flight and at-rest in the cloud.Secondary storage system 104 may be configured to archive a copy of the file system data in a remote storage for disaster recovery.Secondary storage system 104 may be configured to move certain file system data to a remote storage location, such ascloud storage 106, to handle spikes in storage demand.Secondary storage system 104 may be configured to implement a policy-based waterfall model that moves cold data to a remote storage location, such ascloud storage 106. Upon receiving a read for data that is stored at the remote storage location,secondary storage system 104 is configured to retrieve the data and store the data at the secondary storage location. -
Secondary storage system 104 is configured to store the file system data in a tree data structure and to create a snapshot of the tree data structure. The snapshot may be associated with a view at a particular moment in time. A view depicts the connections between nodes and the data stored in one or more leaf nodes at the particular moment in time. The tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree.Secondary storage system 104 may archive the file system data to cloudstorage system 106 or to acluster storage system 108. The archive may include the file system data and a serialized snapshot tree data that is a serialized version of the tree data structure at the particular moment in time. In some embodiments, the archive includes a full snapshot archive of the file system data. In other embodiments, the archive includes an incremental snapshot archive of the file system data. - In some embodiments, a backup policy may indicate that one or more previous snapshots are to be deleted after a full snapshot is performed.
-
Secondary storage system 104 may be configured to archive any of the data stored on secondary storage system 104 (e.g., tree data, other non-tree data) according to one or more archive policies. In some embodiments, an archive policy indicates that the data is to be archived to a cloud storage system and/or to a cluster storage system on a periodic basis (e.g., hourly, daily, weekly, monthly, etc.). In other embodiments, an archive policy indicates that data is to be archived to a cloud storage system and/or to a cluster storage system when a threshold size of data has changed. In other embodiments, an archive policy indicates that data is to be archived to a cloud storage system and/or to a cluster storage system upon a command from a user associated withsecondary storage system 104. -
Secondary storage system 104 may be comprised of one or more solid state drives, one or more hard disk drives, or a combination thereof.Secondary storage system 104 may include one or more processors coupled to the storage drives and configured to archive data stored in the storage drives to cloudstorage system 106, acluster 108, and/or one or more other storage mediums (e.g., tape, removable storage). In one embodiment,secondary storage system 104 is comprised of one solid state drive and three hard disk drives. -
Secondary storage system 104 may include afile system manager 105.File system manager 105 is configured to maintain file system data in the form of nodes arranged in a tree data structure. In some embodiments, leaf nodes in the file system tree include key-value pairs that associate data keys with values in the form of particular items of file system data. A user requests a particular item of data by providing a data key to filesystem manager 105, which traverses a file system tree to find the item of data associated with that data key.File system manager 105 may be configured to perform a snapshot of a snapshot tree.File system manager 105 may be configured to perform one or more modifications, as disclosed herein, to a snapshot tree. -
Cloud storage system 106 may be a public cloud storage provider (e.g., Amazon Web Services, Microsoft Azure Blob Storage, Google Cloud Storage).Cloud storage system 106 is configured to receive and store an archive fromsecondary storage system 104.Cloud storage system 106 may store a full snapshot of file system data and associated serialized snapshot tree data.Cloud storage system 106 may store an incremental snapshot of file system data and associated serialized snapshot tree data.Cloud storage system 106 may provide tosecondary storage 104 file system data and a serialized snapshot tree data associated with a particular time. - One or
more clusters 108 may be comprised of a plurality of storage nodes. The storage nodes may be comprised of one or more solid state drives, one or more hard disk drives, or a combination thereof. A cluster is configured to receive and store an archive fromsecondary storage system 104. A cluster may store a full snapshot of file system data and associated serialized snapshot tree data. A cluster may store an incremental snapshot of file system data and associated serialized snapshot tree data. A cluster may provide tosecondary storage 104 file system data and a serialized snapshot tree data associated with a particular time. In some embodiments, one ormore clusters 108 may be part ofsecondary storage 104. -
FIG. 2A is a block diagram illustrating an embodiment of a tree data structure storing file system data. In the example shown,tree data structure 200 may be created by a storage system, such assecondary storage system 104. In the example shown,tree data structure 200 is a snapshot tree that includes aroot node 202,intermediate nodes leaf nodes tree data structure 200 includes one intermediate level betweenroot node 202 andleaf nodes Tree data structure 200 may be a snapshot tree of file system data at a particular point in time t.Tree data structure 200 may correspond to a version of a snapshot tree.Root node 202 is associated with the snapshot of the file system data at the particular point in time t. In some embodiments, the file system data is metadata for a distributed file system and may include information, such as file size, directory structure, file permissions, physical storage locations of the files, etc. - A root node is the root of a snapshot tree and may include pointers to one or more other nodes. Each pointer includes a range of numerical and sorted data keys that can be found by following that particular pointer. An intermediate node is a node to which another node points (e.g., root node, other intermediate node) and includes one or more pointers to one or more other nodes. A leaf node is a node at the bottom of a snapshot tree. In some embodiments, a leaf node is a node to which another node points, but does not include a pointer to any other node. In other embodiments, a leaf node is a node to which another node points and includes a pointer to the root node of another snapshot tree. A leaf node may store key-value pairs of file system data. A data key k is a lookup value by which a particular leaf node may be accessed. For example, "1" is a data key that may be used to lookup "DATA1" of
leaf node 222. Examples of values stored by a leaf node include, but are not limited to, file size, directory structure, file permissions, physical storage locations of the files, etc. A leaf node may store a data key k and a pointer to a location that stores the value associated with the data key. - A root node or an intermediate node may include one or more node keys. The node key may be an integer value or a non-integer value. Each node key indicates a division between the branches of the node and indicates how to traverse the tree data structure to find a leaf node, i.e., which pointer to follow. For example,
root node 202 may include a node key of "3." A data key k of a key-value pair that is less than or equal to the node key is associated with a first branch of the node and a data key k of a key-value pair that is greater than the node key is associated with a second branch of the node. In the above example, to find a leaf node storing a value associated with a data key of "1," "2," or "3," the first branch ofroot node 202 would be traversed tointermediate node 212 because the data keys of "1," "2," and "3" are less than or equal to the node key "3." To find a leaf node storing a value associated with a data key of "4" or "5," the second branch ofroot node 202 would be traversed tointermediate node 214 because data keys "4" and "5" are greater than the node key of "3." - In some embodiments, a hash function may determine which branch of a node with which the non-numerical data key is associated. For example, a hash function may determine that a first bucket is associated with a first branch of a node and a second bucket is associated with a second branch of the node.
- A data key k of a key-value pair is not limited to a numerical value. In some embodiments, non-numerical data keys may be used for a data key-value pair (e.g., "name," "age," etc.) and a numerical number may be associated with the non-numerical data key. For example, a data key of "name" may correspond to a numerical key of "4." Data keys that alphabetically come before the word "name" or is the word "name" may be found following a left branch associated with a node. Data keys that alphabetically come after the word "name" may be found by following a right branch associated with the node. In some embodiments, a hash function may be associated with the non-numerical data key. The hash function may determine which branch of a node with which the non-numerical data key is associated.
- In the example shown,
root node 202 includes a pointer tointermediate node 212 and a pointer tointermediate node 214.Root node 202 includes a NodeID of "R1" and a TreeID of "1." The NodeID identifies the name of the node. The TreeID identifies the snapshot/view with which the node is associated. When a change is made to data stored in a leaf node as described with respect toFIGS. 2B ,2C , and2D , the TreeID is used to determine whether a copy of a node is to be made. -
Root node 202 includes a node key that divides a set of pointers into two different subsets. Leaf nodes (e.g., "1-3") with a data key k that is less than or equal to the node key are associated with a first branch and leaf nodes (e.g., "4-5") with a data key k that is greater than the node key are associated with a second branch. Leaf nodes with a data key of "1," "2," or "3" may be found by traversingsnapshot tree 200 fromroot node 202 tointermediate node 212 because the data keys have a value that is less than or equal to the node key. Leaf nodes with a data key of "4" or "5" may be found by traversingtree data structure 200 fromroot node 202 tointermediate node 214 because the data keys have a value that is greater than the node key. -
Root node 202 includes a first set of pointers. The first set of pointers associated with a data key less than the node key (e.g., "1," "2," or "3") indicates that traversingtree data structure 200 fromroot node 202 tointermediate node 212 will lead to a leaf node with a data key of "1," "2," or "3."Intermediate node 214 includes a second set of pointers. The second set of pointers associated with a data key greater than the node key indicates that traversingtree data structure 200 fromroot node 202 tointermediate node 214 will lead to a leaf node with a data key of "4" or "5." -
Intermediate node 212 includes a pointer toleaf node 222, a pointer toleaf node 224, and a pointer toleaf node 226.Intermediate node 212 includes a NodeID of "I1" and a TreeID of "1."Intermediate node 212 includes a first node key of "1" and a second node key of "2." The data key k forleaf node 222 is a value that is less than or equal to the first node key. The data key k forleaf node 224 is a value that is greater than the first node key and less than or equal to the second node key. The data key k forleaf node 226 is a value that is greater than the second node key. The pointer toleaf node 222 indicates that traversingtree data structure 200 fromintermediate node 212 toleaf node 222 will lead to the node with a data key of "1." The pointer toleaf node 224 indicates that traversingtree data structure 200 fromintermediate node 212 toleaf node 224 will lead to the node with a data key of "2." The pointer toleaf node 226 indicates that traversingtree data structure 200 fromintermediate node 212 toleaf node 226 will lead to the node with a data key of "3." -
Intermediate node 214 includes a pointer toleaf node 228 and a pointer toleaf node 230.Intermediate node 214 includes a NodeID of "I2" and a TreeID of "1."Intermediate node 214 includes a node key of "4." The data key k forleaf node 228 is a value that is less than or equal to the node key. The data key k forleaf node 230 is a value that is greater than the node key. The pointer toleaf node 228 indicates that traversingtree data structure 200 fromintermediate node 214 toleaf node 228 will lead to the node with a data key of "4." The pointer toleaf node 230 indicates that traversingtree data structure 200 fromintermediate node 214 toleaf node 230 will lead the node with a data key of "5." -
Leaf node 222 includes a data key-value pair of "1: DATA1."Leaf node 222 includes NodeID of "L1" and a TreeID of "1." To view the value associated with a data key of "1,"tree data structure 200 is traversed fromroot node 202 tointermediate node 212 toleaf node 222. -
Leaf node 224 includes a data key-value pair of "2: DATA2."Leaf node 224 includes NodeID of "L2" and a TreeID of "1." To view the value associated with a data key of "2,"tree data structure 200 is traversed fromroot node 202 tointermediate node 212 toleaf node 224. -
Leaf node 226 includes a data key-value pair of "3: DATA3."Leaf node 226 includes NodeID of "L3" and a TreeID of "1." To view the value associated with a data key of "3,"tree data structure 200 is traversed fromroot node 202 tointermediate node 212 toleaf node 226. -
Leaf node 228 includes a data key-value pair of "4: DATA4."Leaf node 228 includes NodeID of "L4" and a TreeID of "1." To view the value associated with a data key of "4,"tree data structure 200 is traversed fromroot node 202 tointermediate node 214 toleaf node 228. -
Leaf node 230 includes a data key-value pair of "5: DATA5."Leaf node 230 includes NodeID of "L5" and a TreeID of "1." To view the value associated with a data key of "5,"tree data structure 200 is traversed fromroot node 202 tointermediate node 214 toleaf node 230. -
FIG. 2B is a block diagram illustrating an embodiment of cloning a snapshot tree of a tree data structure. In some embodiments,tree data structure 250 may be created by a storage system, such assecondary storage system 104. In the example shown,snapshot tree 250 includes a snapshot tree that is comprised ofroot node 204,intermediate nodes leaf nodes Tree data structure 250 may be a snapshot of file system data at a particular point in time t + n. The tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree. In the example shown, the snapshot tree at time t + n is linked to the snapshot tree at time t. To create a snapshot tree of the file system data at time t + n, a copy of the previous root node is created. The root node copy includes the same set of pointers as the original node. However, the root node copy also includes a different NodeID and a different TreeID. The TreeID is the identifier associated with a view.Root node 204 is associated with the snapshot of the file system data at the particular point in time t + n.Root node 202 is associated with the snapshot of the file system data at the particular point in time t. The snapshot tree at time t + n may correspond to a version of a snapshot tree. In some embodiments, the snapshot tree at time t + n is a current view of the file system metadata. A current view may still accept one or more changes to the data. The TreeID of a root node indicates a snapshot with which the root node is associated. For example,root node 202 with a TreeID of "1" is associated with a first snapshot androot node 204 with a TreeID of "2" is associated with a second snapshot. In other embodiments, the snapshot tree at time t + n is a snapshot view of the file system metadata. A snapshot view may not accept any changes to the data. - In some embodiments, to create a snapshot of the file system at time t + n, two root node copies are created. Providing two new root nodes, each with a different TreeID prevents updates made to a particular view (e.g., current view) from affecting nodes of a different view (e.g., snapshot view). One of the new root nodes may be associated with a current view (i.e., modifiable) and the other new root node may be associated with a snapshot view (i.e., not modifiable). In some embodiments, a root node associated with a previous snapshot is deleted after a snapshot is performed, i.e.,
root node 202 is deleted afterroot node 204 is created. - In the example shown,
root node 204 is a copy ofroot node 202. Similar to rootnode 202,root node 204 includes the same pointers asroot node 202, except thatroot node 204 includes a different node identifier and a different view identifier.Root node 204 includes a first set of pointers tointermediate node 212. The first set of pointers associated with a data key k less than or equal to the node key (e.g., "1," "2," or "3") indicates that traversingtree data structure 250 fromroot node 204 tointermediate node 212 will lead to a leaf node with a data key of "1," "2," or "3."Root node 204 includes a second set of pointers tointermediate node 214. The second set of pointers associated with a data key k greater than the node key indicates that traversingtree data structure 250 fromroot node 204 tointermediate node 214 will lead to a leaf node with a data key of "4" or "5."Root node 204 includes a NodeID of "R2" and a TreeID of "2." The NodeID identifies the name of the node. The TreeID identifies the snapshot with which the node is associated. -
FIG. 2C is a block diagram illustrating an embodiment of modifying a snapshot tree. In the example shown,tree data structure 255 may be modified by a file system manager, such asfile system manager 105.Tree data structure 255 may be a current view of the file system data at time t + n. A current view may still accept one or more changes to the data. Because a snapshot represents a perspective of the file system metadata that is "frozen" in time, one or more copies of one or more nodes affected by a change to file system metadata are made.Tree data structure 255 may include a root node that corresponds to a version of a snapshot tree. - In the example shown, the value "DATA4" has been modified to be "DATA4'." At time t + n, the file system manager starts at
root node 204 because that is the root node associated with snapshot tree at time t + n. The value "DATA4" is associated with the data key "4." The file system manager traversestree data structure 255 fromroot node 204 until it reaches a target node, in this example,leaf node 228. The file system manager compares the TreeID at each intermediate node and leaf node with the TreeID of the root node. In the event the TreeID of a node matches the TreeID of the root node, the file system manager proceeds to the next node. In the event the TreeID of a node does not match the TreeID of the root node, a shadow copy of the node with the non-matching TreeID is made. For example, to reach a leaf node with a data key of "4," the file system manager begins atroot node 204 and proceeds tointermediate node 214. The file system manager compares the TreeID ofintermediate node 214 with the TreeID of root node 204 (the identifier associated with a snapshot at time t = t + n), determines that the TreeID ofintermediate node 214 does not match the TreeID ofroot node 204, and creates a copy ofintermediate node 214. Theintermediate node copy 216 includes the same set of pointers asintermediate node 214, but includes a TreeID of "2" to match the TreeID ofroot node 204. The file system manager updates a set of pointers ofroot node 204 to point tointermediate node 216 instead of pointing tointermediate node 214. The file system manager traversestree data structure 255 fromintermediate node 216 toleaf node 228, determines that the TreeID ofleaf node 228 does not match the TreeID ofroot node 204, and creates a copy ofleaf node 228.Leaf node copy 232 stores the modified value "DATA4'" and includes the same TreeID asroot node 204. The file system manager updates a pointer ofintermediate node 216 to point toleaf node 232 instead of pointing toleaf node 228. -
FIG. 2D is a block diagram illustrating an embodiment of a modified snapshot tree of a tree data structure. Thetree data structure 255 shown inFIG. 2D illustrates a result of the modifications made totree data structure 255 as described with respect toFIG. 2C . -
FIG. 2E is a block diagram illustrating an embodiment of leaf node data. In the example shown,leaf node 260 may beleaf node leaf node FIG. 2E . - In the example shown,
leaf node 260 includes adata root node 270 anddata leaf nodes FIG. 2A .Data root node 270 includes a NodeID and a TreeID.Data root node 270 also includes a set of node keys.Data root node 270 includes a first node key of "1," a second node key of "2," a third node key of "3," and a fourth node key of "4." The data key k fordata leaf node 272 is a value that is less than or equal to the first node key.Data leaf node 272 includes adata block 282 that stores bits of ones and zeros. Although data block 282 is depicted as storing the bit pattern "1001," a data block may store any bit pattern.Data leaf node 272 may include a pointer to a physical location that stores the data. - The data key k for
data leaf node 274 is a value that is greater than the first node key and less than or equal to the second node key.Data leaf node 274 includes adata block 284 that stores bits of ones and zeros. Although data block 284 is depicted as storing the bit pattern "1011," a data block may store any bit pattern.Data leaf node 274 may include a pointer to a physical location that stores the data. - The data key k for
data leaf node 276 is a value that is greater than the second node key and less than or equal to the third node key.Data leaf node 276 includes adata block 286 that stores bits of ones and zeros. Although data block 286 is depicted as storing the bit pattern "0011," a data block may store any bit pattern.Data leaf node 276 may include a pointer to a physical location that stores the data. - The data key k for
data leaf node 278 is a value that is greater than the third node key and less than or equal to the fourth node key.Data leaf node 278 includes adata block 288 that stores bits of ones and zeros. Although data block 288 is depicted as storing the bit pattern "1010," a data block may store any bit pattern.Data leaf node 278 may include a pointer to a physical location that stores the data. - The data key k for
data leaf node 280 is a value that is greater than the fourth node key.Data leaf node 280 includes adata block 290 that stores bits of ones and zeros. Although data block 290 is depicted as storing the bit pattern "1111," a data block may store any bit pattern.Data leaf node 280 may include a pointer to a physical location that stores the data. -
FIG. 3A is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time. In the example shown,tree data structure 300 is a snapshot tree at time t = 1. At t = 1,tree data structure 300 includes aroot node 302,intermediate nodes leaf nodes tree data structure 300 is similar to thetree data structure 200 shown inFIG. 2A .Tree data structure 300 may correspond to a version of a snapshot tree. - A full snapshot or an incremental snapshot of the snapshot tree at time t = 1 may be performed and stored on the storage system. The full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot at the particular moment in time. For example, a full snapshot at time t = 1 would include
root node 302,intermediate nodes leaf nodes root node 302,intermediate nodes leaf nodes -
FIG. 3B is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time. The tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree. In the example shown, the snapshot tree at time t = 2 is linked to the snapshot tree at time t = 1. At t = 2, the snapshot tree includesroot node 304,intermediate nodes leaf nodes Root node 302 is associated with a snapshot at time t = 1 androot node 304 is associated with a snapshot at time t = 2. At t = 2, thetree data structure 350 is similar to thetree data structure 255 shown inFIG. 2D . The snapshot tree at time t = 2 is a modified version of snapshot tree at time t = 1 (i.e., the value of "DATA4" has been modified to be "DATA4'"). The snapshot at t = 2 may correspond to a version of a snapshot tree. - A full snapshot or an incremental snapshot of the snapshot tree at t = 2 may be performed and stored on the storage system. The full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot tree at the particular moment in time. For example, a full snapshot at time t = 2 would include
root node 304,intermediate nodes leaf nodes root node 302,intermediate node 314, andleaf node 328 because those nodes are not associated with the snapshot at time t = 2, i.e., a node of a snapshot at time t = 2 does not include a pointer to any of those nodes. An incremental snapshot may provide a partial view of the tree data structure at a particular time. The incremental snapshot may store each of the nodes associated with the snapshot tree at the particular moment in time that have not been previously stored. For example, an incremental snapshot at time t = 2 would includeroot node 304,intermediate node 316, andleaf node 332, but in contrast to the full snapshot at t =1, would not includeintermediate node 312 andleaf nodes -
FIG. 3C is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time. In the example shown,tree data structure 380 includes a snapshot tree at time t = 3. The tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree. In the example shown, the snapshot tree at t = 3 is linked to the snapshot trees at t = 1, 2. At t = 3, the snapshot tree includesroot nodes 306,intermediate nodes leaf nodes Root node 302 is associated with a snapshot at time t = 1,root node 304 is associated with a snapshot at time t = 2, androot node 306 is associated with a snapshot at time t = 3.Snapshot tree 380 is a modified version of the snapshot at t = 2 (i.e., the value of "DATA4'" has been modified to be "DATA4""). The snapshot tree at t = 3 may correspond to a version of a snapshot tree. - A full snapshot or an incremental snapshot of the snapshot tree at t = 3 may be performed and stored on the storage system. The full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot at the particular moment in time. For example, a full snapshot at time t = 3 would include
root node 306,intermediate nodes leaf nodes root nodes intermediate nodes leaf nodes root node 306,intermediate node 318, andleaf node 334, but in contrast to the full snapshot at t = 3, would not includeintermediate node 312 andleaf nodes -
FIG. 3D is a block diagram illustrating an embodiment of a tree data structure at a particular moment in time. In the example shown,tree data structure 390 includes a snapshot tree at time t = 4. The tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is performed, a root node of the snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree. In the example shown, the snapshot tree at time t = 4 is linked to the snapshot trees at times t = 1, 2, 3. At t = 4, the snapshot tree includesroot node 308,intermediate nodes leaf nodes Root node 302 is associated with a snapshot at time t = 1,root node 304 is associated with a snapshot at time t = 2,root node 306 is associated with a snapshot at time t = 3, androot node 308 is associated with a snapshot at time t = 4. The snapshot tree at time t = 4 may correspond to a version of a snapshot tree. - A full snapshot or an incremental snapshot of the snapshot tree at time t = 4 may be performed and stored on the storage system. The full snapshot may provide a complete view of the tree data structure at a particular point in time, that is, the full snapshot stores all of the nodes associated with a snapshot at the particular moment in time. For example, a full snapshot at time t = 4 would include
root node 308,intermediate nodes leaf nodes root nodes intermediate nodes leaf nodes root node 308, but in contrast to the full snapshot at t = 4, would not includeintermediate nodes leaf nodes - As seen in
FIGS. 3B-3D , each snapshot tree builds off of a previous snapshot tree, that is, a chain of snapshot trees exists. Each snapshot tree is associated with a snapshot of the file system data. As more and more snapshots are created and linked, this may require a lot of storage to store the snapshots. To reduce the amount of storage needed to store the snapshots, a policy may indicate that after a full snapshot is performed at a particular point in time, one or more previous snapshots may be deleted from the storage system. In some embodiments, the one or more previous snapshots are deleted after a condition of a retention time policy has passed. -
FIG. 4A is a block diagram illustrating an embodiment of archive data. A snapshot is the state of a system at a particular moment in time. A snapshot may be stored locally at a storage system, such assecondary storage system 104. A snapshot allows the state of a system to be rolled back to a moment in time for which a snapshot is stored. A system may store a large number of snapshots (e.g., thousands, millions). Each snapshot may require a significant amount of storage (e.g., GBs, TBs, PBs, etc.). In some instances, it may be desirable to archive a snapshot to a remote storage location, such ascloud storage 106 orcluster storage 108. For example, one or more older snapshots may be archived to a remote storage location for long-term retention. One or more snapshots may be archived to a remote storage location for data recovery purposes (e.g., other storage systems may access the data associated with a snapshot in the event a storage location that locally stores the snapshot goes offline). One or more snapshots may be archived to a remote storage location to handle spikes in storage demand. One or more snapshots that include cold data (i.e., data that is not accessed frequently) may be archived to a remote storage location to free up local storage for one or more snapshots that include hot data (i.e., data that is accessed frequently). - The file system data associated with a snapshot may be archived to a remote storage location. An archive policy may indicate that a full snapshot archive of a snapshot or an incremental snapshot archive of the snapshot is to be performed and stored on a remote storage location. A full snapshot archive includes a complete view of one version of a snapshot tree at a particular moment in time. A full snapshot archive includes a root node associated with the view at the particular moment in time and any intermediate nodes and/or leaf nodes associated with the root node. A full snapshot archive does not include a node of a previous version of the snapshot tree if the node is not pointed to a node associated with the view at the particular moment in time. A full snapshot archive is similar to a full snapshot, except that the data associated with a full snapshot is stored at a remote location instead of on the storage system; that is the full snapshot archive includes the data stored in each of the nodes associated with the snapshot tree at the particular moment in time. For example, a full snapshot archive associated with a snapshot at t = 3, as depicted in
FIG. 3C , includesroot node 306,intermediate nodes leaf nodes - An incremental snapshot archive includes a partial view of one version of a snapshot tree at a particular moment in time. An incremental snapshot archive includes a representation of what was not previously archived. An incremental snapshot archive is similar to an incremental snapshot, except that the data associated with the incremental snapshot archive is stored at a remote location instead of on the storage system; that is, the incremental snapshot archive includes the data stored in the leaf nodes of the snapshot tree that has not been previously archived. For example, an incremental snapshot archive associated with a snapshot at t = 3, as depicted in
FIG. 3C , includesroot node 306,intermediate node 318, andleaf node 334. The incremental snapshot archive at t = 3 does not includeroot nodes intermediate nodes leaf nodes - A full snapshot archive may be performed based on one or more policies associated with a backup storage system. For example, a full snapshot archive may be performed on a periodic basis (e.g., every X day(s), every Y week(s), every Z month(s), etc.), upon a threshold size of bytes changing from the previous full snapshot, after a threshold number of incremental snapshot archives have been performed, etc. A policy may indicate that an incremental snapshot archive is to be performed on a more frequent basis than a full snapshot archive. The full snapshot archive and incremental snapshot archives are associated with a snapshot at a particular moment in time. For example, archive
data 400 is associated with the snapshot tree at time t = 1, archivedata 450 is associated with the snapshot tree at time t = 2, and archivedata 480 is associated with the snapshot tree at time t = 3. As seen inFIGS. 4A-4C , each snapshot archive builds off of a previous snapshot archive, that is, a block of serialized data includes a file offset to a block associated with previously serialized data. As more and more archives are created, this may require a lot of storage to store the archives. To reduce the amount of storage needed to store the archives, a policy may indicate that after a full snapshot archive, such as depicted inFIG. 4D , is performed at a particular point in time, one or more previous snapshot archives (i.e., archives 400, 450, 480) may be deleted from the remote storage location. In some embodiments, the one or more previous snapshot archives are deleted after a condition of retention time policy has passed. - In the example shown, archive
data 400 can be archived by a storage system, such assecondary storage system 104, to a remote storage location, such ascloud storage 106 orcluster storage 108. In the example shown,archive data 400 includesfile system data 451 and a serializedsnapshot tree data 461. In the example shown,archive data 400 is a file representation of a snapshot of the snapshot tree at a particular moment in time, t = 1.Archive data 400 stores a full snapshot of the snapshot tree at time t =1. A full snapshot archive includes a complete view of the nodes of a snapshot of the snapshot tree at a particular moment in time (i.e., all nodes associated with a root node of the snapshot tree) and the data stored in each of the leaf nodes of the snapshot tree. A full snapshot archive is independent on its own and does not refer back to one or more previous snapshot archives. - File system data of archive data that stores a full snapshot of a snapshot tree associated with a particular view includes all of the data stored in the one or more leaf nodes of a snapshot, regardless of when a leaf node was created (i.e., the snapshot may include leaf nodes associated with previous snapshots). In the example shown,
file system data 451 corresponds to data stored in the leaf nodes of the snapshot tree at time t = 1. Sincearchive data 400 includes a full snapshot of the snapshot tree at t = 1,file system data 451 includes the data stored inleaf nodes file system data 451 includes "DATA1," "DATA2," "DATA3," "DATA4," and "DATA5."File system data 451 may be archived from a storage system, such as a secondary storage system, to a remote storage location, such as a cloud storage system or a cluster backup system. In some embodiments, the file system data is the data (e.g., data blocks of a file, data segments of a file) for a distributed file system. File system data may be stored as a flat set of data. In some embodiments,file system data 451 stores all data blocks associated with leaf nodes of a snapshot tree. In other embodiments,file system data 451 stores all 1s and 0s of file data blocks associated with leaf nodes of a snapshot tree. In some embodiments,file system data 451 stores a plurality of file data blocks in a single block offile system data 451. In some embodiments, the file system data includes file system metadata, such as file size, directory structure, file permissions, physical storage locations of the files, etc. - A serialized snapshot tree data stores the structure of the snapshot tree associated with the file system data as a flat set of data that is comprised of one or more blocks. Each block of the flat set of data corresponds to a node of the snapshot tree. A block may contain a file offset. A file offset represents of a pointer of a snapshot tree. Because some archive systems cannot store pointers, a file offset is used in place of pointers. The file offset may be to another block of the serialized snapshot tree data. The file offset may be to another block of a different serialized snapshot tree data.
- In the example shown, serialized
snapshot tree data 461 corresponds to a snapshot tree at time t = 1. Serializedsnapshot tree data 461 is comprised of a plurality of blocks. Each block corresponds to one of the snapshot tree nodes. For example, blocks 422, 424, 426, 428, 430, 412, 414, and 402 correspond tonodes FIG. 3A . -
Block 402 corresponds to rootnode 302. Becauseroot node 302 includes pointers tointermediate nodes blocks Blocks intermediate nodes intermediate node 312 includes pointers toleaf nodes blocks blocks intermediate node 314 includes pointers toleaf nodes -
Blocks snapshot tree 300 and each include a corresponding file offset to one or more blocks of the file system data stored infile system data 451. For example, block 422 includes an offset to one or more blocks infile system data 451 that stores the value of L1. Similarly, blocks 424, 426, 428, 430 include corresponding offsets to one or more blocks infile system data 451 that store the value of L2, L3, L4, and L5, respectively. -
FIG. 4B is a block diagram illustrating an embodiment of archive data. In the example shown, archivedata 450 can be archived by a system, such assecondary storage system 104. In the example shown,archive data 450 includesfile system data 453 and a serializedsnapshot tree data 463. -
File system data 453 is an incremental snapshot archive of the file system data stored in the one or more leaf nodes of a snapshot tree. An incremental snapshot archive may include changes to the data of a snapshot tree since a last snapshot archive (e.g., new data or modified data). For example,file system data 453 may include one or more values stored in leaf nodes of the snapshot tree at time t = 2 that were not previously archived.File system data 453 may be stored as a flat set of data. In some embodiments,file system data 453 stores all data blocks associated with leaf nodes of a snapshot tree that were not previously archived. In other embodiments,file system data 453 stores the corresponding 1s and 0s of file data blocks associated with leaf nodes of a snapshot tree that were not previously archived. In some embodiments,file system data 453 stores a plurality of file data blocks in a single block offile system data 453. In some embodiments, the file system data includes file system metadata, such as file size, directory structure, file permissions, physical storage locations of the files, etc. - Serialized
snapshot tree data 463 is a serialized version of one or more nodes of the snapshot tree at time t = 2 and is represented as a flat set of data that is comprised of one or more blocks. Each block of the flat set of data corresponds to a node of the snapshot tree. Serializedsnapshot tree data 463 includes a serialized representation of one or more changes to a snapshot tree (e.g., new node, modified node, deleted node) since a previous snapshot. Serialized snapshot tree data may include a block for each root node of a snapshot tree. - To determine whether a node should be included in a serialized snapshot tree data, the file system manager starts at the root node associated with a snapshot view and traverses the snapshot tree. At each node of the snapshot tree, the file system manager determines whether that particular node existed and is the same as the one in the previous snapshot tree. In the event the node didn't exist in the previous snapshot or is different when compared to the corresponding node in the previous snapshot tree, a block corresponding to the node is included in serialized snapshot tree data. In the event the node is determined to have existed in the previous snapshot tree and is also the same as the corresponding node in the previous snapshot tree, a block corresponding to the node is not included in the serialized snapshot tree data because a previous serialized snapshot tree data already includes a block corresponding to the node. Instead, a file offset to the block of the previous serialized snapshot tree data may be included in one or more of the blocks in the serialized snapshot tree data.
- For example, to create a snapshot at t = 2,
root node 304 was added. The snapshot tree at t = 2 indicates that the value of "DATA4" has been modified to be "DATA4'."Intermediate node 316 andleaf node 332 were added to the snapshot tree to ensure that each node along this path has a TreeID of "2." - In the example shown, serialized
snapshot tree data 463 corresponds to the root nodes of the snapshot tree at t = 2 and the new nodes of snapshot tree at t = 2. Serializedsnapshot tree data 463 is comprised of a plurality of blocks. Each block corresponds to one of thesnapshot tree 350 nodes. For example, blocks 432, 416, 404 correspond tonodes -
Block 404 corresponds to rootnode 304. Becauseroot node 304 includes a pointer tointermediate node 312, block 404 includes a file offset to block 412 of serializedsnapshot tree data 461. Previously stored serializedsnapshot tree data 461 already includes block 412 that corresponds tointermediate node 312. A file offset to a previously stored serialized snapshot tree data is used to save memory and prevent storing duplicative data.Root node 304 also includes a pointer tointermediate node 316. Similarly, block 404 also includes a file offset to block 416, which corresponds tointermediate node 316. -
Block 416 corresponds tointermediate node 316.Intermediate node 316 includes pointers toleaf nodes leaf node 330 has not changed and was previously stored infile system metadata 451. To save memory and prevent storing duplicative data, block 416 includes a file offset to block 430 of serializedsnapshot tree data 461. Block 416 also includes a file offset to block 432.Block 432 corresponds toleaf node 332.Intermediate node 316 is a new node becausesnapshot tree 300 did not includeintermediate node 316. Thus, serializedsnapshot tree data 463 includes a block that corresponds tointermediate node 316. -
Block 432 corresponds toleaf node 332 ofsnapshot tree 350.Leaf node 332 is a new node becausesnapshot tree 300 did not includeleaf node 332. Thus, serializedsnapshot tree data 463 includes a block that corresponds toleaf node 332.Block 432 includes a file offset to one or more blocks infile system data 453 that store the value ofleaf node 332. -
FIG. 4C is a block diagram illustrating an embodiment of archive data. In the example shown, archivedata 480 can be archived by a system, such assecondary storage system 104. In the example shown,archive data 480 includesfile system data 455 and a serializedsnapshot tree data 465. -
File system data 455 is an incremental snapshot of the file system data stored in the one or more leaf nodes of a snapshot tree. For example,file system data 455 may include one or more values of the snapshot tree at time t = 3 that were not previously archived.File system data 455 may be stored as a flat set of data. In some embodiments,file system data 455 stores all data blocks associated with leaf nodes of a snapshot tree that were not previously archived. In other embodiments,file system data 455 stores the corresponding 1s and 0s of file data blocks associated with leaf nodes of a snapshot tree that were not previously archived. In some embodiments,file system data 455 stores a plurality of file data blocks in a single block offile system data 455. In some embodiments, the file system data includes file system metadata, such as file size, directory structure, file permissions, physical storage locations of the files, etc. - Serialized
snapshot tree data 465 is a serialized version of one or more nodes of the snapshot tree at time t = 3 and is represented as a flat set of data that is comprised of one or more blocks. Each block of the flat set of data corresponds to a node of the snapshot tree. To create a snapshot at t = 3,root node 306 was added. The snapshot tree indicates that the value of "DATA4'" has been modified to be "DATA4"."Intermediate node 318 andleaf node 334 were added to the snapshot tree at t = 3 to ensure that each node along this path has a TreeID of "3." - In the example shown, serialized
snapshot tree data 465 corresponds to root nodes of the snapshot tree at time t = 3 and the new nodes of snapshot tree at time t = 3. Serializedsnapshot tree data 465 is comprised of a plurality of blocks. Each block corresponds to one of the nodes of the snapshot tree at time t = 3. For example, blocks 434, 418, 406 correspond tonodes -
Block 406 corresponds to rootnode 306. Becauseroot node 306 includes a pointer tointermediate node 312, block 406 includes a file offset to block 412 of serializedsnapshot tree data 461.Root node 306 includes a pointer tointermediate node 318. Similarly, block 406 includes a file offset to block 418, which corresponds tointermediate node 318. -
Block 418 corresponds tointermediate node 318.Intermediate node 318 includes a pointer toleaf nodes leaf node 330 has not changed and was previously stored infile system metadata 451. To save memory and prevent storing duplicative data, block 418 includes a file offset to block 430 of serializedsnapshot tree data 461. Block 418 also includes a file offset to block 434.Block 434 corresponds toleaf node 334.Intermediate node 318 is a new node becausesnapshot tree 350 did not includeintermediate node 318. Thus, archivedata 480 includes a block that corresponds tointermediate node 318. -
Block 434 corresponds toleaf node 334 ofsnapshot tree 380.Leaf node 334 is a new node becausesnapshot tree 350 did not includeleaf node 334 at t = 2. Thus, archivedata 480 includes a block that corresponds toleaf node 334.Block 434 includes a file offset to a block offile system metadata 455 that stores the value ofleaf node 334. -
FIG. 4D is a block diagram illustrating an embodiment of archive data. In the example shown, archivedata 490 can be archived by a storage system, such assecondary storage system 104. In the example shown,archive data 490 includesfile system data 457 and a serializedsnapshot tree data 467. In the example shown,archive data 490 is a file representation of snapshot tree at time t = 4.Archive data 490 stores a full snapshot of the snapshot tree at time t = 4. A full snapshot archive includes a representation of all of the nodes of a snapshot of a snapshot tree at a particular moment in time (i.e., all nodes associated with a root node of the snapshot tree) and the data stored in each of the leaf nodes of the snapshot tree. - In the example shown, serialized
snapshot tree data 467 corresponds to the snapshot tree at t = 4. Serializedsnapshot tree data 467 is comprised of a plurality of blocks. Each block corresponds to one of the snapshot tree nodes. For example, blocks 422, 424, 426, 434, 430, 412, 418, and 408 correspond tonodes -
Block 408 corresponds to rootnode 308. Becauseroot node 308 includes pointers tointermediate nodes blocks Blocks intermediate nodes intermediate node 312 includes pointers toleaf nodes blocks blocks intermediate node 318 includes pointers toleaf nodes -
Blocks snapshot tree 390 and each include a corresponding file offset to one or more blocks of the file system data stored infile system data 457. For example, block 422 includes an offset to one or more blocks infile system data 457 that stores the value of L1. Similarly, blocks 424, 426, 434, 430 include corresponding offsets to one or more blocks infile system data 457 that store the value of L2, L3, L7, and L5, respectively. - As seen in
FIGS. 4A-4C , a serialized snapshot tree data may be linked with a previous serialized snapshot tree data. As more and more snapshots are archived, this may require a lot of storage to archive the serialized snapshot tree data. To reduce the amount of storage needed to store the archives, a policy may indicate that after a full snapshot archive, such asarchive 490, is performed at a particular point in time, one or more previous archives may be deleted from cloud storage, i.e., archivedata data archive data 490 is archived. In some embodiments, the one or more previous snapshot archives are deleted after a condition associated with a retention time policy has passed. For example, a policy may indicate that data is to be archived for a period of thirty days. -
FIG. 5 is a flow chart illustrating an embodiment of archiving data. In the example shown,process 500 may be implemented by a storage system, such assecondary storage system 104. In some embodiments,process 500 is a full snapshot archive. In other embodiments,process 500 is an incremental snapshot archive. - At 502, is it is determined that file system data is to be archived. A snapshot is the state of a system at a particular moment in time. A snapshot may be stored locally at a storage system, such as
secondary storage system 104. A snapshot allows the state of a system to be rolled back to a moment in time for which a snapshot is stored. A system may store a large number of snapshots (e.g., thousands, millions). Each snapshot may require a significant amount of storage (e.g., GBs, TBs, PBs, etc.). In some instances, it may be desirable to archive a snapshot to a remote storage location, such ascloud storage 106 orcluster storage 108. The file system data associated with a snapshot may be archived to a remote storage location. An archive policy may indicate that a full snapshot archive of a snapshot or an incremental snapshot archive of the snapshot is to be performed and stored on a remote storage location. A full snapshot archive includes a complete view of one version of a snapshot tree at a particular moment in time. A full snapshot archive includes a root node associated with the view at the particular moment in time and any intermediate nodes and/or leaf nodes associated with the root node. A full snapshot archive does not include a node of a previous version of the snapshot tree if the node is not pointed to a node associated with the view at the particular moment in time. A full snapshot archive is similar to a full snapshot, except that the data associated with the full snapshot is stored at a remote location instead of on the storage system; that is, the full snapshot archive includes the data stored in each of the nodes associated with the snapshot tree at the particular moment in time. For example, a full snapshot archive associated with a snapshot at t = 3, as depicted inFIG. 3C , includesroot node 306,intermediate nodes leaf nodes - An incremental snapshot archive includes a partial view of one version of a snapshot tree at a particular moment in time. An incremental snapshot archive includes a representation of what was not previously archived. An incremental snapshot archive is similar to an incremental snapshot, except that the data associated with the incremental snapshot archive is stored at a remote location instead of on the storage system; that is, the incremental snapshot archive includes the data stored in the leaf nodes of the snapshot tree that have not been previously archived. For example, an incremental snapshot archive associated with a snapshot at t = 3, as depicted in
FIG. 3C , includesroot node 306,intermediate node 318, andleaf node 334. The incremental snapshot archive at t = 3 does not includeroot nodes intermediates nodes leaf nodes - In some embodiments, the filesystem data is to be archived according to an archive policy. For example, an archive policy may indicate that a full snapshot archive is to be performed on a periodic basis (e.g., every W hour(s), every X day(s), every Y week(s), every Z month(s), etc.). An archive policy may indicate that a full snapshot archive is to be performed each time a full snapshot is performed. In some embodiments, an archive policy may indicate that one or more previous snapshot archives are to be deleted after a full snapshot archive is performed. In some embodiments, an archive policy may indicate that one or more file system data files and corresponding serialized snapshot tree data are to be deleted after a full snapshot archive is performed. An archive policy may indicate that an incremental snapshot archive is to be performed on a periodic basis (e.g., every W hour(s), every X day(s), every Y week(s), every Z month(s), etc.). An archive policy may indicate that an incremental snapshot archive is to be performed each time an incremental snapshot is performed. An archive policy may indicate that an incremental snapshot archive is to be performed on a more frequent basis than a full snapshot archive. The full snapshot archive and incremental snapshot archives are associated with a snapshot at a particular moment in time. For example, archive
data 400 is associated with the snapshot tree at time t = 1, archivedata 450 is associated with the snapshot tree at time t = 2, and archivedata 480 is associated with the snapshot tree at time t = 3. As seen inFIGS. 4A-4C , each snapshot archive builds off of a previous snapshot archive, that is, a block of serialized data includes a file offset to a block associated with previously serialized data. As more and more archives are created, this may require a lot of storage to store the archives. To reduce the amount of storage needed to store the archives, a policy may indicate that after a full snapshot archive, such as depicted inFIG. 4D , is performed at a particular point in time, one or more previous snapshot archives (i.e., archives 400, 450, 480) may be deleted from the remote storage location. In some embodiments, the one or more previous snapshot archives are deleted after a condition of retention time policy has passed. - At 504, a snapshot tree associated with a view is serialized into serialized snapshot tree data and file system data associated with the view is serialized into serialized file system data. Serializing the snapshot tree into serialized snapshot tree data creates a flat set of data that represents the snapshot tree. In some embodiments, the file system data may be stored in a tree data structure, such as the tree data structure depicted in
FIG. 2E . Serializing the file system data into serialized file system data creates a flat set of data that represents the file system data. The snapshot tree and the file system data are serialized into flat sets of data because a remote location may be incapable of storing a tree data structure. In some embodiments, the view is a current view. A current view is a current perspective of the snapshot tree and one or more changes may be made to the snapshot tree. In other embodiments, the view is a snapshot view. A snapshot view is a perspective of the snapshot tree at a particular moment in time and one or more changes may not be made to the snapshot tree of the snapshot view. - The serialized snapshot tree data, i.e., a flat set of data, is comprised of one or more blocks. The serialized snapshot tree is a representation of a snapshot tree in block form. Each block of the serialized snapshot tree data corresponds to a node of a snapshot tree. Instead of a node having one or more pointers to one or more other nodes, a block of the serialized snapshot tree may include one or more file offsets to one or more other blocks. The file offsets represent the pointers of a snapshot tree. A block may include a file offset to another block in the serialized snapshot tree data. A block may include a file offset to another block in a previously serialized snapshot tree data. For example, a snapshot tree node may include a pointer to a node associated with a previous snapshot tree. A block that corresponds to the snapshot tree node may include a file offset to the block of a previously serialized snapshot tree data block that corresponds to the node associated with the previous snapshot tree. The snapshot tree node may also include a pointer to a node associated with the current snapshot tree. A block that corresponds to the snapshot tree node may include a file offset to the block of the current serialized snapshot tree data that corresponds to the node associated with the current snapshot tree.
- The serialized file system data, i.e., a flat set of data, is comprised of one or more blocks. Each block of the serialized file system data corresponds to a data block or data segment of the file system data.
- In some embodiments, a full snapshot is performed and the serialized snapshot tree data includes a plurality of blocks that correspond to the plurality of nodes of the snapshot tree. In some embodiments, one or more snapshots performed before the full snapshot are deleted. In other embodiments, an incremental snapshot is performed and the serialized snapshot tree data includes a plurality of blocks that correspond to the one or more root nodes and the one or more nodes that have been added to a snapshot tree since a previous archive. In some embodiments, an incremental snapshot is performed for a plurality of different snapshot trees and the corresponding serialized snapshot tree data includes file blocks corresponding to the plurality of different snapshot trees. In some embodiments, a serialized snapshot tree data combines the plurality of blocks that correspond to the one or more root nodes and the one or more nodes that have been added to a snapshot tree since a previous archive with one or more blocks from one or more previous archives.
- At 506, the serialized snapshot tree data and serialized file system data are archived. The file system data is comprised of data blocks of a file and/or data segments of a file, and may be stored as a set of flat data. In some embodiments, the file system data is a full snapshot archive of the file system data stored in the one or more leaf nodes of a snapshot tree. Each of the data blocks/segments comprising the file system data stored in the one or more leaf nodes of a snapshot tree may be stored in the set of flat data. In some embodiments, the file system data is an incremental snapshot archive of the file system data stored in the one or more leaf nodes of a snapshot tree. The incremental snapshot archive may include changes to the data of a snapshot tree since a last snapshot archive (e.g., new data or modified data). Each of the data blocks/segments comprising the changes to the data of a snapshot tree since a last snapshot archive may be stored in the set of flat data. In some embodiments, the serialized snapshot tree data and file system data are archived to remote storage (e.g., cloud storage system, cluster storage system, etc.). The file system data may be stored in one or more files. File system metadata may be stored in one or more separate files. The file system metadata may include a reference to a file system data file and vice versa.
-
FIG. 6A is a flow chart illustrating an embodiment of restoring archived data. In the example shown,process 600 may be performed by a storage system, such assecondary storage system 104. - At 602, a request for data at a particular time is received. The request may include a data key and the particular time. For example, a request for data associated with a data key of "4" at time t = 3 may be received. The value associated with a data key is stored in a leaf node of a snapshot tree at the particular time. The snapshot tree may have been deleted from a storage system and archived to a remote storage location. The storage system may determine to access the requested value from a remote storage system by retrieving an archive that corresponds to the requested data at the particular time. For example, to determine the value associated with a data key of "4" at time t = 3, a corresponding archive needs to be retrieved from a remote storage location.
- To determine which archive(s) to retrieve from a remote storage location, at 604, a view associated with the particular time is determined. A snapshot tree has an identifier associated with a particular view. The snapshot tree having an identifier that matches the view associated with the particular time is determined. For example, a tree data structure has a root node with an identifier (e.g., TreeID = 3) that matches the view associated with t = 3. The view may be comprised of a root node, one or more intermediate nodes, and one or more leaf nodes. The value associated with the data key is stored in one of the leaf nodes of the view.
- At 606, one or more archives of serialized snapshot tree data and one or more archives of file system data associated with the particular time are retrieved. An archive of file system data may comprise a first set of flat data. An archive of serialized snapshot tree data may comprise a second set of flat data. At least a portion of one or more file system archives 451, 453, 455 and at least a portion of one or more archives of serialized
snapshot tree data - At 608, a snapshot tree associated with the particular time is reconstituted. In some embodiments, the snapshot tree is reconstituted by deserializing serialized snapshot tree data associated with the particular time. In other embodiments, the snapshot tree is reconstituted by deserializing serialized snapshot tree data associated with the particular time and deserializing one or more other serialized snapshot tree data. In some embodiments, the one or more other serialized snapshot tree data were archived before the serialized snapshot tree data associated with the particular time. Reconstituting the structure of a snapshot tree at the particular time includes reading the flat set of data associated with the serialized snapshot tree data. The flat set of data includes blocks of data that correspond to nodes of a snapshot tree and associated file offsets that correspond to pointers of the snapshot tree.
- For example, for the request of a value associated with a data key of "4" at time t = 3, the snapshot tree at t = 3 may be reproduced based on serialized
snapshot tree data snapshot tree data 465 includes blocks that correspond to theroot node 306 of the snapshot tree and offsets to blocks associated withintermediate nodes -
Leaf node 334 may be reproduced becauseblock 418 includes an offset to block 434, which corresponds toleaf node 334. The value associated withleaf node 334 may be accessed and reproduced becauseblock 434 includes an offset to one or more blocks of data stored infile system data 455. -
Leaf nodes block 406, which corresponds to rootnode 306, includes an offset to block 412 of serializedsnapshot tree data 461.Block 412 of serializedsnapshot tree data 461 corresponds tointermediate node 312.Block 412 includes an offset toblocks leaf nodes leaf nodes blocks file system data 451. -
Leaf node 330 may be reproduced becauseblock 418 of serializedsnapshot tree data 465 includes an offset to block 430 of serializedsnapshot tree data 461.Block 430 of serializedsnapshot tree data 461 corresponds toleaf node 330. The value associated withleaf node 330 may be accessed and reproduced becauseblock 430 includes an offset to one or more blocks of data stored infile system data 455. - In some embodiments, a partial tree data structure is reproduced by deserializing one or more serialized snapshot tree data associated with the particular time needed to determine the value associated with the requested data key. For example, for the request of a value associated with a data key of "4" at time t = 3, a portion of
tree data structure 380 may be reproduced based on serializedsnapshot tree data 465. As seen inFIG. 3C ,leaf node 334 has a data key-value pair of "4: DATA4"" and a TreeID of "3." Because a TreeID of "3" is associated with a snapshot tree view at t = 3, the value stored inleaf node 334, as opposed to the value stored inleaf nodes snapshot tree data 465 includes file offsets to serializedsnapshot tree data snapshot tree data - At 610, the reproduced tree data structure is traversed. A view associated with a particular time has an associated TreeID. For example, a view at t = 3 is associated with a TreeID of "3." The reproduced tree is traversed starting at a root node having a TreeID that is associated with the particular time. The reproduced tree is traversed based on the data key that is associated with the particular time. For example, for a request for a value associated with a data key of "4" at time t = 3,
tree data structure 380 may be traversed fromroot node 306 tointermediate node 318 toleaf node 334. Althoughleaf node 328 andleaf node 332 both have a data key of "4,"tree data structure 380 is not traversed to eitherleaf node 328 orleaf node 332 becauseleaf nodes leaf node 328 is associated with a view at time t = 1 andleaf node 332 is associated with a view at time t = 2) andintermediate node 318 does not include a pointer toleaf node leaf node 334 indicates a current value associated with a data key of "4." In other embodiments, the value associated withleaf node 334 indicates the value associated with a data key of "4" at a particular point in time. In some embodiments, the leaf node includes a pointer to a location in file system data archive. - At 612, the requested data is retrieved from a remote storage location and provided. For example, for a request for a value associated with a data key of "4" at time t = 3, a value of "DATA4"" may be retrieved from a file system data archive stored in cloud storage and provided. In some embodiments, the value is retrieved from archive data that was previously retrieved and stored on a storage system. In some embodiments, the value is retrieved from a remote storage location, such as a cloud storage system or a cluster storage system.
-
FIG. 6B is a flow chart illustrating an embodiment of retrieving archived data. In the example shown,process 650 may be performed by a storage system, such assecondary storage system 104. - At 652, a request for data at a particular time is received. The request may include a data key and the particular time. For example, a request for data associated with a data key of "4" at time t = 3 may be received. The value associated with a data key is stored in a leaf node of a snapshot tree at the particular time. The snapshot tree may have been deleted from a storage system and archived to a remote storage location. The storage system may determine to access the requested value from a remote storage system by retrieving an archive that corresponds to the requested data at the particular time. For example, to determine the value associated with a data key of "4" at time t = 3, a corresponding archive needs to be retrieved from a remote storage location.
- To determine which archive(s) to retrieve from a remote storage location, at 654, a view associated with the particular time is determined. A snapshot tree has an identifier associated with a particular view. The snapshot tree having an identifier that matches the view associated with the particular time is determined. For example, a
tree data structure 380 has aroot node 306 with an identifier (e.g., TreeID = 3) that matches the view associated with t = 3. The view may be comprised of a root node, one or more intermediate nodes, and one or more leaf nodes. The value associated with the data key is stored in one of the leaf nodes of the view. - At 656, serialized snapshot tree data associated with the view is determined. For example, serialized
snapshot file 465 is associated with a snapshot tree view at t = 3. In some embodiments, the determined serialized snapshot tree data corresponds to a full snapshot. In some embodiments, the determined serialized snapshot tree data corresponds to an incremental snapshot archive. In some embodiments, the determined serialized snapshot tree data corresponds to a full snapshot archive and one or more incremental snapshot archives. - At 658, serialized snapshot tree data is traversed. Serialized snapshot tree data is a flat set of data and includes one or more blocks. One of the blocks corresponds to a root node associated with the particular view. For example, block 406 of serialized
snapshot tree data 465 corresponds to rootnode 306 oftree data structure 380. Similar to traversing a snapshot tree from a root node to a leaf node, to find a value associated with a data key of "4" at time t = 3, serialized snapshot tree data is traversed fromblock 406 to one or more blocks offile system data 455 based on file offsets included in the one or more blocks of serializedsnapshot tree data 465. An initial block corresponding to a root node of a snapshot tree at the particular time is read to determine a file offset. The block with the file offset is read to determine whether the block includes a file offset to another block of serialized snapshot tree data or a file offset to one or more blocks of file system data. The block with the file offset is read and the process repeats until traversing the serialized snapshot tree data arrives at one or more blocks of file system data. For example, block 406 of serializedsnapshot tree data 465 is read and it is determined thatblock 406 includes a file offset to block 418.Block 418 of serializedsnapshot tree data 465 is read and it is determined that it includes a file offset to block 434.Block 434 of serialized snapshot tree data is read and it is determined thatblock 434 includes a file offset to one or more blocks offile system data 455. - At 660, the value associated with a data key is retrieved from remote storage. The value may be stored in one or more blocks of remote storage. At 662, the retrieved value associated with the data key is provided via a user interface. For example, the value "DATA4"" is provided.
-
FIGS. 7A ,7B , and7C are block diagrams illustrating an embodiment of maintaining a snapshot tree. In the example shown,tree data structure 700 can be maintained by a storage system, such assecondary storage system 104.Tree data structure 700 is similar totree data structure 380 except that the intermediate nodes and leaf nodes have an associated count value. A count value of a node indicates a number of other nodes that include pointers to the node. A count value of a node is incremented each time another node includes a pointer to the node. - For example,
intermediate node 712 has a count value of "3" becauseroot nodes intermediate node 712.Intermediate node 714 has a count value of "1" becauseroot node 702 is the only node that includes a pointer tointermediate node 714.Intermediate nodes Leaf nodes - An associated snapshot tree view may have an associated retention time policy associated with it. For example, retention time policy may indicate that a snapshot tree view is to be deleted after a certain period of time (e.g., day(s), week(s), month(s), year(s), etc.). The retention time policy reduces the number of snapshot trees that a system is required to maintain and store in memory.
- A snapshot tree view has an associated root node with a TreeID that associates the snapshot with a particular moment in time. For example, a snapshot tree associated with t = 1 may have a root node with a TreeID of "1," a snapshot tree associated with t = 2 may have a root node with a TreeID of "2," and a snapshot tree associated with t = 3 may have a root node with a TreeID of "3."
- In some embodiments, a retention time policy condition is satisfied (e.g., a snapshot tree view has been stored in memory for a particular amount of time) and it is determined to remove the snapshot tree view from memory. For example, it may be determined that a snapshot tree with a particular TreeID is to be stored for a particular amount of time. In the event the particular amount of time has passed, a file system manager may determine that the snapshot tree with the particular TreeID is to be removed from memory and/or storage. This reduces the storage needed to store snapshot trees and corresponding snapshots because the data contained in a snapshot may not be needed after a certain amount of time has passed. To remove a snapshot tree view from memory, the snapshot tree view is traversed along each branch and one or more nodes associated with the snapshot tree view are removed based on a count value associated with a node. In some embodiments, a retention time policy condition indicates that a full snapshot and associated incremental snapshots are to be removed from memory in the event a subsequent snapshot occurs.
- For example,
FIG. 7B depicts an embodiment where a retention time policy condition associated with a TreeID has been satisfied. Suppose a snapshot tree view associated with time t = 1 is to be removed from memory. To determine which nodes to remove, each branch associated withroot node 702 is traversed becauseroot node 702 has a TreeID of "1," which is the snapshot tree view associated with time t = 1.Root node 702 may be traversed tointermediate node 712. A count value associated withintermediate node 712 is decremented by one. In this example, the count value associated withintermediate node 712 is decremented from "3" to "2." Because the count value associated withintermediate node 712 is not "0," then the count values of the associatedleaf nodes intermediate node 712 was "0," then the count values associated withleaf nodes -
Root node 702 may be traversed tointermediate node 714. A count value associated withintermediate node 714 is decremented by one. In this example, the count value associated withintermediate node 714 is decremented from "1" to "0." Because the count value associated withintermediate node 714 is "0," thentree data structure 700 is further traversed toleaf nodes leaf node 728 is decremented from "1" to "0." The count value associated withleaf node 730 is decremented from "3" to "2." - After all of the branches associated with a snapshot tree view have been traversed, the root node associated with the snapshot tree view and any nodes having a count value of "0" associated with the snapshot tree view are removed from memory. For example, as depicted in
FIG. 7C ,root node 702 is removed from memory because it is the root node associated with the snapshot tree view that is to be removed from memory.Intermediate node 714 andleaf node 728 are removed from memory because their corresponding count values are "0." -
FIG. 8 is a flow chart illustrating an embodiment of maintaining a snapshot tree. In the example shown,process 800 can be performed by a storage system, such assecondary storage system 104. - At 802, it is determined that a snapshot tree associated with a particular view is to be deleted. In some embodiments, it is determined that a retention time associated with a snapshot tree having a particular TreeID has passed. For example, it may be determined that a snapshot tree view having a TreeID of "1" is to be removed from memory. In other embodiments, a user determines that a snapshot tree is to be deleted.
- At 804, the snapshot tree is traversed. The snapshot tree is traversed to determine which nodes of the snapshot tree are to be deleted.
- At 806, a corresponding count value of one or more nodes associated with the snapshot tree is decremented by one. In some embodiments, an intermediate node is pointed to by a plurality of root nodes and has a count value greater than one. For example,
intermediate node 712, as seen inFIG. 7A , has a count value of "3" because root nodes R1, R2, R3 include a pointer tointermediate node 712. In the event decrementing the count value of the intermediate node causes the intermediate node to still have a count value that is greater than one, the count value of any nodes to which the intermediate node points is not decremented. For example, as seen inFIGS. 7A and7B , a count value ofintermediate node 712 is decremented from "3" to "2."Intermediate node 712 includes a pointer toleaf nodes intermediate node 712 is greater than or equal to one, the count value associated withleaf nodes - In some embodiments, an intermediate node is only pointed to by a root node associated with the snapshot tree having the particular ID. For example,
intermediate node 714, as seen inFIG. 7A , has a count value of "1" because root node R1 includes a pointer tointermediate node 714. Such an intermediate node has a count value of one and the count value of the intermediate node is decremented from one to zero. The count value of any nodes pointed to by the intermediate node is also decremented by one. For example, as seen inFIGS. 7A and7B , a count value ofintermediate node 714 is decremented from "1" to "0."Intermediate node 714 includes a pointer toleaf nodes intermediate node 714 is less than one, the count value associated withleaf nodes - At 808, a root node associated with the snapshot tree having the particular TreeID and the one or more nodes having a count value of zero are deleted. The root node associated with the snapshot tree having the particular TreeID and the one or more nodes having a count value of zero may be removed from one or more snapshot views that reference the deleted nodes. For example, as seen in
FIG. 7C ,root node 702,intermediate node 714, andleaf node 728 are removed from a snapshot view. In some embodiments, the portions of memory of storage corresponding to a node having a count value of zero are cleared. -
FIG. 9 is a flow chart illustrating an embodiment of deleting archived snapshots. In the example shown,process 900 can be performed by a storage system, such assecondary storage system 104. - At 902, a full snapshot archive of a snapshot tree is performed. A snapshot represents a snapshot tree at a particular moment in time. The full snapshot archive includes all of the nodes of a snapshot tree at the particular moment in time. An incremental snapshot archive includes all of the nodes of a snapshot tree that have been added to a snapshot since a previous snapshot. A policy may indicate that a full snapshot archive is to be performed on a periodic basis, by command from a user, and/or after a threshold number of incremental snapshots have been performed.
- At 904, a previous full snapshot and one or more associated incremental snapshots are determined. A snapshot tree may include nodes associated with one or more previous snapshots. For example,
tree data structure 380 includes aroot node 306 that is associated with nodes associated with a previous snapshot tree (nodes - At 906, it is determined that a retention policy associated with the previous full snapshot and one or more associated incremental snapshots has passed. For example, to save storage space, a retention policy may indicate that a snapshot is to be deleted after a certain amount of time has passed.
- At 908, nodes that are not part of a snapshot associated with a full snapshot archive, such as nodes from the previous full snapshot and one or more associated incremental snapshots, are deleted from the storage system. For example,
root nodes intermediate nodes leaf nodes -
FIG. 10A is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). In the example shown, partially restoredsnapshot tree 1000 may be restored by a storage system, such assecondary storage system 104. A tree data structure comprising one or more snapshot trees may have been deleted from a storage system, for example, due to a retention time policy associated with the one or more snapshot trees. A snapshot tree may be restored to the storage system based on its corresponding archive data. - In some embodiments, a request to access specific portions of data of archived file system data at a particular time is received. A portion of the snapshot tree associated with the specific portions of data of the archived file system data may be restored to provide access to the specific portions of data of the archived file system data. In some embodiments, the non-requested portions of the snapshot tree are pre-fetched from remote storage and restored in the background operation of the storage system. In some embodiments, a request to access archived file system data at a particular time is received. An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data.
- To restore either a portion of the snapshot tree associated with the specific portions of data of the archived file system data at the particular time or the entire snapshot tree associated with the archived file system data at the particular time, a snapshot archive corresponding to the particular time is identified. The snapshot archive is stored at a remote storage location, such as
cloud storage 106 or cluster(s) 108. The identified snapshot archive includes serialized snapshot tree data corresponding to the snapshot tree at the particular time. The identified snapshot archive also includes file system data corresponding to the file system data at the particular time. - In the example shown, a request for specific portions of data of archived file system data at time t = 3 or a request to access archived file system data at time t = 3 is received.
Tree data structure 380 ofFIG. 3C includes a snapshot tree at time t = 3. The snapshot tree at time t = 3 includesroot node 306,intermediate nodes leaf nodes corresponding archive data 480.Archive data 480 ofFIG. 4C includesfile system data 455 and serializedsnapshot tree data 465. Serializedsnapshot tree data 465 is identified as the serialized snapshot tree data corresponding to the particular time. - Metadata of a root node of the identified serialized snapshot tree data may be obtained. In the example shown, metadata is obtained from a block of the identified serialized snapshot tree data. The metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, or a file offset to another block of a different serialized snapshot tree data. For example, block 406 corresponds to the
root node 306 of the snapshot tree at time t = 3.Block 406 includes a file offset to block 418 of serializedsnapshot tree data 465 and a file offset to block 412 of serializedsnapshot tree data 461. The metadata may also include a node ID, a view ID, and/or one or more node keys. - The obtained metadata of the root node from the identified serialized snapshot tree data may be used to create a restored snapshot tree instance that includes a representation of the root node that references one or more intermediate nodes. For example, partially restored
snapshot tree 1000 ofFIG. 10A may be created based on serializedsnapshot tree data 465 ofFIG. 4C . Partially restoredsnapshot tree 1000 includes aroot node 1006,stub node 1012a, andstub node 1018a, which correspond to block 406 of serializedsnapshot tree data 465, block 412 of serializedsnapshot tree data 461, and block 418 of serializedsnapshot tree data 465, respectively.Stub nodes - Similar to root
node 306,root node 1006 includes a nodeID of "R3," a TreeID of "3," and a node key of "3."Root node 1006 includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "3," partially restoredsnapshot tree 1000 will be traversed tostub node 1012a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "3," partially restoredsnapshot tree 1000 will be traversed tostub node 1018a. -
FIG. 10B is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). In the example shown, partially restoredsnapshot tree 1050 may be restored by a storage system, such assecondary storage system 104. In some embodiments, partially restoredsnapshot tree 1050 is a continuation of the restoring partially restoredsnapshot tree 1000 in response to a request to access specific portions of data of archived file system data at a particular time is received. - Partially restored
snapshot tree 1050 includesroot node 1006,intermediate node 1018b,stub node 1012a,stub node 1030a, andstub node 1034a. In the example shown, a request for a data value associated with a key value of "4" at time t = 3 was received. To determine the data value associated with the key value of "4," partially restoredsnapshot tree 1000 is traversed fromroot node 1006 to stubnode 1018a because the data key of "4" is greater than the node key associated with root node 1006 (e.g., "3").Stub node 1018a includes a pointer to block 418 of serializedsnapshot tree data 465. Metadata corresponding to stubnode 1018a, i.e., metadata included inblock 418 of serializedsnapshot tree data 465, is obtained from the remote storage location. - The metadata included in
block 418 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1000 to become partially restoredsnapshot tree 1050. The metadata included inblock 418 of serializedsnapshot tree data 465 includes a nodeID of "I4," a TreeID of "3," a file offset to block 430 of serializedsnapshot tree data 461 and a file offset to block 434 of serializedsnapshot tree data 465. As seen inFIGS 10A and10B ,stub node 1018a has been updated to becomeintermediate node 1018b.Intermediate node 1018b corresponds tointermediate node 318 ofFIG. 3C . Similar tointermediate node 318,intermediate node 1018b includes a nodeID of "I4," a TreeID of "3," and a node key of "4."Intermediate node 1018b includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "4," partially restoredsnapshot tree 1050 will be traversed fromintermediate node 1018b tostub node 1034a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "4," partially restoredsnapshot tree 1000 will be traversed fromintermediate node 1018b tostub node 1030a. -
Intermediate node 1018b includes a pointer tostub node 1030a and a pointer tostub node 1034a becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 430 of serializedsnapshot tree data 461 and a file offset to block 434 of serializedsnapshot tree data 465, respectively. -
Stub node 1030a includes a pointer to block 430 of serializedsnapshot tree data 461 becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 430 of serializedsnapshot tree data 461.Stub node 1034a includes a pointer to block 434 of serializedsnapshot tree data 465 becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 434 of serializedsnapshot tree data 465.Stub nodes -
FIG. 10C is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). In the example shown, partially restoredsnapshot tree 1060 may be restored by a storage system, such assecondary storage system 104. In some embodiments, partially restoredsnapshot tree 1060 is a continuation of the restoring of partially restoredsnapshot tree 1050 in response to a request to access specific portions of data of archived file system data at a particular time is received. - Partially restored
snapshot tree 1060 includesroot node 1006,intermediate node 1018b,stub node 1012a,stub node 1030a, andleaf node 1034b. In the example shown, a request for a data value associated with a key value of "4" at time t = 3 was received. To determine the data value associated with the key value of "4," partially restoredsnapshot tree 1050 is traversed fromroot node 1006 tointermediate node 1018b because the data key of "4" is greater than the node key associated with root node 1006 (e.g., "3"). Partially restoredsnapshot tree 1050 is further traversed fromintermediate node 1018b tostub node 1034a because the data key of "4" is less than or equal to the node key associated withintermediate node 1018b (e.g., "4").Stub node 1034a includes a pointer to block 434 of serializedsnapshot tree data 465. Metadata corresponding to stubnode 1034a, i.e., metadata included inblock 434 of serializedsnapshot tree data 465, is obtained from the remote storage location. - The metadata included in
block 434 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1050 to become partially restoredsnapshot tree 1060. The metadata included inblock 434 of serializedsnapshot tree data 465 includes a nodeID of "L7," a TreeID of "3," and a file offset to one or more blocks offile system data 455. As seen inFIGS 10B and10C ,stub node 1034a has been updated to becomeleaf node 1034b.Leaf node 1034b corresponds toleaf node 334 ofFIG. 3C . Similar toleaf node 334,leaf node 1034b includes a nodeID of "L7," a TreeID of "3," and a data value of DATA4" associated with a data key of "4." - In some embodiments, the data value stored in a leaf node is a pointer to a storage location in the remote storage location storing the data. In other embodiments, the data value stored in the leaf node is a pointer to a block of serialized snapshot tree data that corresponds to a root node of another snapshot tree.
-
FIG. 10D is a block diagram illustrating an embodiment of a partially restored snapshot tree with stub(s). In the example shown, partially restoredsnapshot tree 1070 may be restored by a storage system, such assecondary storage system 104. In some embodiments, partially restoredsnapshot tree 1070 is a continuation of the restoring of partially restoredsnapshot tree 1000 in response to a request to access archived file system data at a particular time. An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data. In some embodiments, partially restoredsnapshot tree 1070 is a continuation of the restoring of partially restoredsnapshot tree 1050 in response to a request to access archived file system data at a particular time. - Partially restored
snapshot tree 1070 includesroot node 1006,intermediate nodes stub nodes snapshot tree 1000 is traversed fromroot node 1006 to stubnode 1012a because a stub node represents an incomplete portion of the snapshot tree.Stub node 1012a includes a pointer to block 412 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1012a, i.e., metadata included inblock 412 of serializedsnapshot tree data 461, is obtained from the remote storage location. - The metadata included in
block 412 of serializedsnapshot tree data 461 and the metadata included inblock 418 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1000 to become partially restoredsnapshot tree 1070. - The metadata included in
block 412 of serializedsnapshot tree data 461 includes a nodeID of "I1," a TreeID of "1," a file offset to block 422 of serializedsnapshot tree data 461, a file offset to block 424 of serializedsnapshot tree data 461, and a file offset to block 426 of serializedsnapshot tree data 461. As seen inFIGS 10A and10D ,stub node 1012a has been updated to becomeintermediate node 1012b.Intermediate node 1012b corresponds tointermediate node 312 ofFIG. 3C . Similar tointermediate node 312,intermediate node 1012b includes a nodeID of "I1," a TreeID of "1," and a node keys of "1" and "2."Intermediate node 1012b includes a first set of pointers, a second set of pointers, and a third set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "1," partially restoredsnapshot tree 1070 will be traversed fromintermediate node 1012b tostub node 1022a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "1" and less than or equal to the node key of "2," partially restoredsnapshot tree 1070 will be traversed fromintermediate node 1012b tostub node 1024a. The third set of pointers indicates that to determine a value of a data key that is greater than the node key of "2," partially restoredsnapshot tree 1070 will be traversed fromintermediate node 1012b tostub node 1026a. -
Intermediate node 1012b includes a pointer tostub node 1022a, a pointer tostub node 1024a, and a pointer tostub node 1026a becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 422 of serializedsnapshot tree data 461, a file offset to block 424 of serializedsnapshot tree data 461, and a file offset to block 426 of serializedsnapshot tree data 461, respectively. -
Stub node 1022a includes a pointer to block 422 of serializedsnapshot tree data 461 becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 422 of serializedsnapshot tree data 461. Stub node 1023 includes a pointer to block 424 of serializedsnapshot tree data 461 becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 424 of serializedsnapshot tree data 461.Stub node 1026a includes a pointer to block 426 of serializedsnapshot tree data 461 becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 426 of serializedsnapshot tree data 461. - To further restore the entire snapshot tree associated with the archived file system data at time t = 3, partially restored
snapshot tree 1000 is traversed fromroot node 1006 to stubnode 1018a because a stub node represents an incomplete portion of the snapshot tree.Stub node 1018a includes a pointer to block 418 of serializedsnapshot tree data 465. Metadata corresponding to stubnode 1018a, i.e., metadata included inblock 418 of serializedsnapshot tree data 465, is obtained from the remote storage location. - The metadata included in
block 418 of serializedsnapshot tree data 465 includes a nodeID of "I4," a TreeID of "3," a file offset to block 430 of serializedsnapshot tree data 461 and a file offset to block 434 of serializedsnapshot tree data 465. As seen inFIGS 10A and10D ,stub node 1018a has been updated to becomeintermediate node 1018b.Intermediate node 1018b corresponds tointermediate node 318 ofFIG. 3C . Similar tointermediate node 318,intermediate node 1018b includes a nodeID of "I4," a TreeID of "3," and a node key of "4."Intermediate node 1018b includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "4," partially restoredsnapshot tree 1050 will be traversed fromintermediate node 1018b tostub node 1034a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "4," partially restoredsnapshot tree 1000 will be traversed fromintermediate node 1018b tostub node 1030a. -
Intermediate node 1018b includes a pointer tostub node 1030a and a pointer tostub node 1034a becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 430 of serializedsnapshot tree data 461 and a file offset to block 434 of serializedsnapshot tree data 465, respectively. -
Stub node 1030a includes a pointer to block 430 of serializedsnapshot tree data 461 becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 430 of serializedsnapshot tree data 461.Stub node 1034a includes a pointer to block 434 of serializedsnapshot tree data 465 becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 434 of serializedsnapshot tree data 465. -
FIG. 10E is a block diagram illustrating an embodiment of a fully restored snapshot tree. In the example shown, fully restoredsnapshot tree 1080 may be restored by a storage system, such assecondary storage system 104. In some embodiments, fully restoredsnapshot tree 1080 is a continuation of the restoring of partially restoredsnapshot tree 1070 in response to a request to access archived file system data at a particular time. An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data. - Fully restored
snapshot tree 1080 includesroot node 1006,intermediate nodes leaf nodes - To restore the entire snapshot tree associated with the archived file system data at time t = 3, partially restored
snapshot tree 1070 is traversed fromintermediate node 1012b tostub nodes Stub node 1022a includes a pointer to block 422 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1022a, i.e., metadata included inblock 422 of serializedsnapshot tree data 461, is obtained from the remote storage location.Stub node 1024a includes a pointer to block 424 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1024a, i.e., metadata included inblock 424 of serializedsnapshot tree data 461, is obtained from the remote storage location.Stub node 1026a includes a pointer to block 426 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1026a, i.e., metadata included inblock 426 of serializedsnapshot tree data 461, is obtained from the remote storage location. - The metadata included in
block 422 of serializedsnapshot tree data 461 may be used to update partially restoredsnapshot tree 1070 to become fully restoredsnapshot tree 1080. The data included inblock 422 of serializedsnapshot tree data 461 includes a nodeID of "L1," a TreeID of "1," and a file offset to one or more blocks offile system data 451. As seen inFIGS 10D and10E ,stub node 1022a has been updated to becomeleaf node 1022b.Leaf node 1022b corresponds toleaf node 322 ofFIG. 3C . Similar toleaf node 322,leaf node 1022b includes a nodeID of "L1," a TreeID of "1," and a data value of "DATA1" associated with a data key of "1." - The metadata included in
block 424 of serializedsnapshot tree data 461 may be used to update partially restoredsnapshot tree 1070 to become fully restoredsnapshot tree 1080. The metadata included inblock 424 of serializedsnapshot tree data 461 includes a nodeID of "L2," a TreeID of "1," and a file offset to one or more blocks offile system data 451. As seen inFIGS 10D and10E ,stub node 1024a has been updated to becomeleaf node 1024b.Leaf node 1024b corresponds toleaf node 324 ofFIG. 3C . Similar toleaf node 324,leaf node 1024b includes a nodeID of "L2," a TreeID of "1," and a data value of "DATA2" associated with a data key of "2." - The metadata included in
block 426 of serializedsnapshot tree data 461 may be used to update partially restoredsnapshot tree 1070 to become fully restoredsnapshot tree 1080. The metadata included inblock 426 of serializedsnapshot tree data 461 includes a nodeID of "L3," a TreeID of "1," and a file offset to one or more blocks offile system data 451. As seen inFIGS 10D and10E ,stub node 1026a has been updated to becomeleaf node 1026b.Leaf node 1026b corresponds toleaf node 326 ofFIG. 3C . Similar toleaf node 326,leaf node 1026b includes a nodeID of "L3," a TreeID of "1," and a data value of "DATA3" associated with a data key of "3." - To further restore the entire snapshot tree associated with the archived file system data at time t = 3, partially restored
snapshot tree 1070 is traversed fromintermediate node 1018b tostub nodes Stub node 1030a includes a pointer to block 430 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1030a, i.e., metadata included inblock 430 of serializedsnapshot tree data 461, is obtained from the remote storage location.Stub node 1034a includes a pointer to block 434 of serializedsnapshot tree data 465. Metadata corresponding to stubnode 1034a, i.e., metadata included inblock 434 of serializedsnapshot tree data 465, is obtained from the remote storage location. - The metadata included in
block 430 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1070 to become fully restoredsnapshot tree 1080. The metadata included inblock 430 of serializedsnapshot tree data 461 includes a nodeID of "L5," a TreeID of "1," and a file offset to one or more blocks offile system data 451. As seen inFIGS 10D and10E ,stub node 1030a has been updated to becomeleaf node 1030b.Leaf node 1030b corresponds toleaf node 330 ofFIG. 3C . Similar toleaf node 330,leaf node 1030b includes a nodeID of "L5," a TreeID of "1," and a data value of "DAT A5" associated with a data key of "5." - The metadata included in
block 434 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1050 to become partially restoredsnapshot tree 1060. The metadata included inblock 434 of serializedsnapshot tree data 465 includes a nodeID of "L7," a TreeID of "3," and a file offset to one or more blocks offile system data 455. As seen inFIGS 10B and10C ,stub node 1034a has been updated to becomeleaf node 1034b.Leaf node 1034b corresponds toleaf node 334 ofFIG. 3C . Similar toleaf node 334,leaf node 1034b includes a nodeID of "L7," a TreeID of "3," and a data value of "DAT A4 "" associated with a data key of "4." - In some embodiments, the data value stored in a leaf node is a pointer to a storage location in the remote storage location storing the data. In other embodiments, the data value stored in the leaf node is a pointer to a block of serialized snapshot tree data that corresponds to a root node of another snapshot tree.
-
FIG. 11A is a flow chart illustrating an embodiment of restoring a snapshot tree. In the example shown,process 1100 may be performed by a storage system, such assecondary storage system 104. - At 1102, a request to access an archived file system data associated with a particular point in time is received. The request may be a read request or a write request.
- The request may be to access one or more specific files associated the file system data at a particular point in time. For example, the request may be to access a version of the file "a.txt" at t = 3. The request may be to access an entire file system data corresponding to a system at a particular point in time. For example, the archived file system data may correspond to the entire contents of a storage volume of a system at a particular point in time. The system may become corrupted (e.g. infected by virus, infected by malware, storage failure) and it may be desired to restore the entire file system data to the particular point in time.
- At 1104, serialized snapshot tree data corresponding to the request is identified. The file system data associated with the particular point in time is associated with a corresponding snapshot tree. The file system data associated with the particular point in time and corresponding snapshot tree are associated with a corresponding snapshot archive. The snapshot archive is comprised of archived file system data and serialized snapshot tree data, such as the file system data and serialized snapshot tree data that were archived via 506 of
process 500. For example, for a request for specific portions of data of archived file system data at time t = 3 or a request to access archived file system data at time t = 3, serializedsnapshot tree data 465 is identified as the serialized snapshot tree data corresponding to the particular time. The storage system may store a data structure (e.g., table, list, etc.) that associates different versions of snapshot trees with their corresponding snapshot archive. A file system manager of the storage system may use the data structure to identify the snapshot tree associated with the file system data at the particular point in time and to identify the snapshot archive associated with the identified snapshot tree. - At 1106, metadata of a root node from the identified serialized snapshot tree data is obtained. The metadata is stored in the identified serialized snapshot tree data and includes archived contents that can be used to restore the root node. The metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, or a file offset to another block of a different serialized snapshot tree data. For example, block 406 corresponds to the
root node 306 of the snapshot tree at time t = 3.Block 406 includes a file offset to block 418 of serializedsnapshot tree data 465 and a file offset to block 412 of serializedsnapshot tree data 461. The metadata may also include a node ID, a view ID, and/or a node key. - At 1108, the obtained metadata of the root node is used to create a restored snapshot tree instance that includes a representation of the root node that references one or more stub intermediate nodes. A stub node is a placeholder for a node of the snapshot tree. The stub node corresponds to a specific node of the snapshot tree and includes a pointer to a location of information associated with the specific node of the snapshot tree. The stub node may save storage space and reduce the amount of time to process the request because data that is not associated with the request does not need to be fetched from the remote storage location. For example, to process a request associated with the data key of "4", data associated with a key of less than or equal to the node key of
root node 1006 does not need to be fetched from the remote storage location. - A partially restored snapshot tree may be created based on the serialized snapshot tree data. As seen in
FIG. 10A , partially restoredsnapshot tree 1000 includes aroot node 1006,stub node 1012a, andstub node 1018a, which correspond to block 406 of serializedsnapshot tree data 465, block 412 of serializedsnapshot tree data 461, and block 418 of serializedsnapshot tree data 465, respectively. - Similar to root node 306 (the root node of the snapshot tree at time t = 3),
root node 1006 includes a nodeID of "R3," a TreeID of "3," and a node key of "3."Root node 1006 also includes a first set of pointers and a second set of pointers similar toroot node 306. The first set of pointers will be used in the event a data key is less than or equal to the node key and the second set of pointers will be used in the event the data key is greater than the node key. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "3," partially restoredsnapshot tree 1000 will be traversed tostub node 1012a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "3," partially restoredsnapshot tree 1000 will be traversed tostub node 1018a. - At 1110, access to the restored snapshot tree instance is allowed via the root node. By allowing access to the restored snapshot tree instance that includes the stub nodes right away instead of waiting to restore the entire snapshot tree instance, faster access to the snapshot tree instance is provided. Additionally, using stub nodes allows storage/memory to be conserved because potentially unused portions of the snapshot tree and associated file contents do not have to be restored until needed. In the event the request to access the archived file system data was a read request, the requested value associated with the read request may be provided. In the event the request to access the archived file system data was a write request, a clone of the restored snapshot tree, for example as described with respect to
FIGS 12A-12C , may be created to perform the write request. -
FIG. 11B is a flow chart illustrating an embodiment of restoring a snapshot tree. In the example shown,process 1120 may be performed by a storage system, such assecondary storage system 104. In some embodiments, a request to access specific portions of data of archived file system data at a particular time is received. A portion of the snapshot tree associated with the specific portions of data of the archived file system data may be restored to provide access to the specific portions of data of the archived file system data.Process 1120 may be performed to restore the non-requested portions of the snapshot tree. For example, a request to restore a snapshot tree is received andprocess 1100 ofFigure 11A is performed to initially provide fast access to an instance of the snapshot tree with stubs. Thenprocess 1120 ofFigure 11B is performed in the background to replace the stubs of the snapshot tree with restored nodes, allowing the entire snapshot tree to be restored in the background while initial access to the snapshot tree is allowed via the root node in 1110 ofFigure 11A . - In some embodiments, a request to access archived file system data at a particular time is received. An entire snapshot tree associated with the archived file system data may be restored to provide the access to the archived file system data.
Process 1120 may be performed to restore the entire snapshot tree. - At 1122, the snapshot tree is traversed to identify one or more stub node(s). For example,
snapshot tree 1060 may be traversed to identifystub nodes Stub node 1012a may be identified in the event a data key that is less than or equal to the node key ofroot node 1006 is desired to be restored.Stub node 1030a may be identified in the event a data key that is greater than the node key ofroot node 1006 and greater than the node key ofintermediate node 1018b is desired to be restored. - At 1124, metadata corresponding to the identified one or more stub nodes is pre-fetched from the archived data. For example, the metadata corresponding to the identified one or more stub nodes may be included in the archive data that was archived via 506 of
process 500. The metadata is stored in the archive data snapshot tree data and includes contents that can be used to restore the snapshot tree node(s) corresponding the stub node(s). The archive data includes file system data and serialized snapshot tree data. The metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, a file offset to another block of a different serialized snapshot tree data, a node ID, a view ID, and/or one or more node keys. The metadata corresponding to the identified one or more stub nodes may be pre-fetched as a background operation of the storage system. In some embodiments, the metadata corresponding to the identified one or more stub nodes is pre-fetched without a specific request from a user to restore the one or more stub nodes. In some embodiments, the metadata corresponding to the identified one or more stub nodes is pre-fetched based on a particular usage pattern. For example, order of traversal of the nodes in 1122 is based on a likelihood the node will be accessed. If typical usage pattern of file contents are known (e.g., particular files are known to be likely accessed often or first based on prior data usage pattern and/or received specification), then the nodes of the snapshot tree corresponding to those files may be traversed and restored prior to restoring other less likely to be accessed nodes. - At 1126, the obtained metadata is used to update the snapshot tree by replacing the identified stub node(s) with corresponding restored node(s).
- For example,
stub node 1012a includes a pointer to block 412 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1012a, i.e., metadata included inblock 412 of serializedsnapshot tree data 461, is obtained from a remote storage location, such ascloud storage 106. The metadata included inblock 412 of serializedsnapshot tree data 461 may be used to update partially restoredsnapshot tree 1060. The metadata included inblock 412 of serializedsnapshot tree data 461 includes a nodeID of "I1," a TreeID of "1," a file offset to block 422 of serializedsnapshot tree data 461, a file offset to block 424 of serializedsnapshot tree data 461, a file offset to block 426 of serializedsnapshot tree data 461, and node keys "1" and "2."Stub node 1012a may be updated to becomeintermediate node 1012b.Intermediate node 1012b corresponds tointermediate node 312 ofFIG. 3C . Similar tointermediate node 312,intermediate node 1012b includes a nodeID of "I1," a TreeID of "1," and a node keys of "1" and "2."Intermediate node 1012b includes a first set of pointers, a second set of pointers, and a third set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "1," partially restoredsnapshot tree 1070 will be traversed fromintermediate node 1012b tostub node 1022a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "1" and less than or equal to the node key of "2," partially restoredsnapshot tree 1070 will be traversed fromintermediate node 1012b tostub node 1024a. The third set of pointers indicates that to determine a value of a data key that is greater than the node key of "2," partially restoredsnapshot tree 1070 will be traversed fromintermediate node 1012b tostub node 1026a. -
Intermediate node 1012b includes a pointer tostub node 1022a, a pointer tostub node 1024a, and a pointer tostub node 1026a becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 422 of serializedsnapshot tree data 461, a file offset to block 424 of serializedsnapshot tree data 461, and a file offset to block 426 of serializedsnapshot tree data 461, respectively. -
Stub node 1022a includes a pointer to block 422 of serializedsnapshot tree data 461 becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 422 of serializedsnapshot tree data 461.Stub 1024a includes a pointer to block 424 of serializedsnapshot tree data 461 becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 424 of serializedsnapshot tree data 461.Stub node 1026a includes a pointer to block 426 of serializedsnapshot tree data 461 becauseblock 412 of serializedsnapshot tree data 461 includes a file offset to block 426 of serializedsnapshot tree data 461. - For example,
stub node 1030a includes a pointer to block 430 of serializedsnapshot tree data 461.Stub node 1030a includes a pointer to block 430 of serializedsnapshot tree data 461. Metadata corresponding to stubnode 1030a, i.e., metadata included inblock 430 of serializedsnapshot tree data 461, is obtained from the remote storage location. The metadata included inblock 430 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1060. The data included inblock 430 of serializedsnapshot tree data 461 includes a nodeID of "L5," a TreeID of "1," and a file offset to one or more blocks offile system data 451. Using the metadata included inblock 430 of serializedsnapshot tree data 461,stub node 1030a may be updated to becomeleaf node 1030b.Leaf node 1030b corresponds toleaf node 330 ofFIG. 3C . Similar toleaf node 330,leaf node 1030b includes a nodeID of "L5," a TreeID of "1," and a data value of "DAT A5" associated with a data key of "5." The data value of "DAT A5" may be retrieved from the one or more blocks offile system data 451 stored at the remote storage location. - At 1128, it is determined whether there are any more stub nodes. In the event there are more stub nodes,
process 1120 returns to 1124. For example, as described above,intermediate node 1012b may include a pointer tostub nodes Process 1120 may return to 1124 to update the snapshot tree to include leaf node data that corresponds to stubnodes process 1120 ends and the snapshot tree has been fully restored. For example, partially restoredsnapshot tree 1060 may be fully restored to become fully restoredsnapshot tree 1080. -
FIG. 11C is a flow chart illustrating an embodiment of selectively restoring nodes of a snapshot tree based on a request. In the example shown,process 1140 may be performed by a storage system, such assecondary storage system 104. - At 1142, a request to access desired data associated with a snapshot tree restored from archive data is received. The request may be a write request or a read request. For example, the request may be a request to read a value associated with a data key of "4." The request may be a request to modify and write a new value for the data key of "4." In some embodiments, the request received in 1102 of
Figure 11A . For example, in response to a request,process 1100 ofFigure 11A is performed to initially restore a snapshot tree that includes stub nodes. Thenprocess 1140 is performed to selectively replace stub nodes with restored nodes required to provide access to the desired data. - At 1144, the process of restoring the snapshot tree is started from root node of the restored snapshot tree. For example, the process of restoring the snapshot tree may start from
root node 1006 of partially restoredsnapshot tree 1000. - At 1146, the restored snapshot tree is traversed using a key associated with the desired data by identifying a next node of the snapshot tree.
- At 1148, it is determined if the identified next node is a stub node. For example, partially restored
snapshot tree 1000 is traversed fromroot node 1006 to stubnode 1018a because the data key of "4" is greater than the node key "3" ofroot node 1006. In the event the identified next node is a stub node, then process 1140 proceeds to 1150. In the event the identified next node is not a stub node, then process 1140 proceeds to 1158. - At 1150, metadata corresponding to the stub node is obtained from the archive data. For example, the metadata corresponding to the stub node may be included in the archive data that was archived via 506 of
process 500. The metadata is stored in the archive data snapshot tree data and includes contents that can be used to restore the snapshot tree node corresponding the stub node. The archive data includes file system data and serialized snapshot tree data. The metadata may be stored in a block of the serialized snapshot tree data. The metadata may include a file offset to another block of the same serialized snapshot tree data, a file offset to one or more blocks of file system data associated with the serialized snapshot tree data, a file offset to another block of a different serialized snapshot tree data, a node ID, a view ID, and/or one or more node keys. - At 1152, the obtained metadata is used to update the snapshot tree by replacing the identified stub node(s) with corresponding restored node(s). For example, the data included in
block 418 of serializedsnapshot tree data 465 may be used to update partially restoredsnapshot tree 1000 to become partially restoredsnapshot tree 1050. The data included inblock 418 of serializedsnapshot tree data 465 includes a nodeID of "I4," a TreeID of "3," a file offset to block 430 of serializedsnapshot tree data 461 and a file offset to block 434 of serializedsnapshot tree data 465. As seen inFIGS 10A and10B ,stub node 1018a has been updated to becomeintermediate node 1018b.Intermediate node 1018b corresponds tointermediate node 318 ofFIG. 3C . Similar tointermediate node 318,intermediate node 1018b includes a nodeID of "I4," a TreeID of "3," and a node key of "4."Intermediate node 1018b includes a first set of pointers and a second set of pointers. The first set of pointers indicates that to determine a value of a data key that is less than or equal to the node key of "4," partially restoredsnapshot tree 1050 will be traversed fromintermediate node 1018b tostub node 1034a. The second set of pointers indicates that to determine a value of a data key that is greater than the node key of "4," partially restoredsnapshot tree 1000 will be traversed fromintermediate node 1018b tostub node 1030a. -
Intermediate node 1018b includes a pointer tostub node 1030a and a pointer tostub node 1034a becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 430 of serializedsnapshot tree data 461 and a file offset to block 434 of serializedsnapshot tree data 465, respectively. -
Stub node 1030a includes a pointer to block 430 of serializedsnapshot tree data 461 becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 430 of serializedsnapshot tree data 461.Stub node 1034a includes a pointer to block 434 of serializedsnapshot tree data 465 becauseblock 418 of serializedsnapshot tree data 465 includes a file offset to block 434 of serializedsnapshot tree data 465. - At 1154, the process of restoring the snapshot tree proceeds to the restored node. For example,
process 1140 may proceed tointermediate node 1018b. - At 1156, it is determined whether the currently visited node provides direct access to the desired data. The currently visited node may not provide direct access to the desired data because the restored node is an intermediate node of the restored snapshot tree. The currently visited node may provide direct access to the desired data because the restored node is a leaf node of the restored snapshot tree and it is determined in 1156 that the currently visited node provides direct access to the desired data if the currently visited node is a leaf node that links to a storage portion where the desired data is stored. In some embodiments, if the currently visited node is a leaf node that links to another tree structure (e.g., linked to a second tree structure used to identify blocks of an individual file), it is determined in 1156 that the currently visited node does not provide direct access to the desired data and the process returns to 1146 where the root node of this other linked tree structure is identified as the next node.
- In the event the currently visited node does not provide access to the desired data,
process 1140 proceeds to 1146. For example,intermediate node 1018b does not provide access to the desired data. The process of restoring the snapshot tree may return to 1146 to restorestub node 1034a. - In the event the currently visited node provides access to the desired data,
process 1140 proceeds to 1160. For example, a leaf node has been restored. - At 1158, the process of restoring the snapshot tree proceeds to the next node.
- At 1160, the desired data is obtained and access is provided to the desired data. In some embodiments, read access is provided to the desired data. The desired data may be retrieved from a storage location of the storage system.
- In other embodiments, write access is provided to the desired data. The desired data may be modified using a copy-on-write procedure. A snapshot tree associated with the desired data may be cloned, as described in
FIGS. 12A-C . The snapshot tree associated with the desired data may be cloned by creating a copy of the root node of the snapshot tree associated with the desired data. The root node clone includes the same set of pointers as the copied root node, but includes a different nodeID and a different view identifier. The cloned snapshot tree is traversed from the root node copy to the leaf node associated with the desired data. The view identifier associated with each node along the path to the leaf node associated with the desired data is inspected. In the event the view identifier associated with a node matches the view identifier associated with the root node copy, then the cloned snapshot tree is traversed to the next node along the path. In the event the view identifier associated with a node does not match the view identifier associated with the root node copy, then a copy of the node with the non-matching view identifier is created. The copy of the node with the non-matching view identifier includes the same set of pointers as the copied node, but includes a different node ID and a view identifier of the root node copy. A pointer of the node that pointed to the node with the non-matching view identifier is updated. The pointer is updated to point to the copy of the node with the non-matching view identifier instead of the node with the non-matching view identifier. The copy-on write process continues until the leaf node associated with the desired data is copied and modified. When the user is finished using the cloned database, the root node copy may be deleted. -
FIG. 12A is a block diagram illustrating an embodiment of cloning a partially restored snapshot tree. In some embodiments,tree data structure 1200 may be created by a storage system, such assecondary storage system 104. In some embodiments, a clone of a restored snapshot tree is created after the snapshot tree is restored to a desired state (e.g., fully restored or partially restored to include desired data value(s)). In other embodiments, a clone of a restored snapshot tree is created after the storage system receives a request to modify one or more data values associated with the restored snapshot tree. The cloned partially restored snapshot tree represents a new view of the partially restored snapshot tree. - In the example shown,
tree data structure 1200 includes a partially restored snapshot tree that is comprised ofroot node 1006,intermediate node 1018b,stub nodes leaf node 1034b.Tree data structure 1200 may be at least a portion of a snapshot of the file system data at a particular point in time. In the example shown, tree data structure is a portion of a snapshot of the file system data at time t = 3. The tree data structure allows a chain of snapshot trees to be linked together. Each time a snapshot is cloned, a root node of the cloned snapshot tree may be linked to one or more intermediate nodes associated with a previous snapshot tree. In the example shown, the snapshot tree comprisingroot node 1006,intermediate node 1018b,stub nodes leaf node 1034b is cloned. To create a clone, a copy of the root node is created. The root node copy includes the same set of pointers as the original node. However, the root node copy also includes a different NodeID and a different TreeID. The TreeID is the identifier associated with a view.Root node 1006 is associated with a partially restored snapshot of the file system data that corresponds to a partial view of the file system data at time t = 3. In some embodiments,root node 1006 is associated with a fully restored snapshot of the file system data that corresponds to a complete view of the file system data at time t = 3. - In the example shown,
root node 1206 is a copy ofroot node 1006. Similar to rootnode 1006,root node 1206 includes the same pointers asroot node 1006. However, among other things,root node 1206 includes a different node identifier and a different view identifier.Root node 1206 includes a first set of pointers to stubnode 1012a. The first set of pointers associated with a data key k less than or equal to the node key indicates that traversingtree data structure 1200 fromroot node 1206 to stubnode 1012a will lead to a leaf node with a data key that is less than or equal to the node key ofroot node 1206.Root node 1206 includes a second set of pointers tointermediate node 1018b. The second set of pointers associated with a data key k greater than the node key indicates that traversingtree data structure 1200 fromroot node 1206 tointermediate node 1018b will lead to a leaf node with a data key that is greater than the node key ofroot node 1206. -
FIG. 12B is a block diagram illustrating an embodiment of modifying a clone of a partially restored snapshot tree. In the example shown,tree data structure 1250 may be modified by a file system manager, such asfile system manager 105.Tree data structure 1250 may be a current view of the file system data. A current view may still accept one or more changes to the data. Because a snapshot represents a perspective of the file system metadata that is "frozen" in time, one or more copies of one or more nodes affected by a change to file system metadata, are made. - In the example shown, the value "DAT A4" " has been modified to be "DAT A4"'." The value "DAT A4"'" is stored in a different storage block of the storage system than the value "DAT A4"'." A corresponding modification is made to the snapshot tree so that a node pointing to the storage block associated with the storage block "DAT A4"" points to the storage block associated with the value "DAT A4"." The file system manager starts at
root node 1206 to make a corresponding modification to the snapshot tree because that is the root node associated with the partially cloned snapshot tree. The value "DAT A4'" is associated with the data key "4." The file system manager traversestree data structure 1250 fromroot node 1206 until it reaches a target node, in this example,leaf node 1034b. The file system manager compares the TreeID at each intermediate node and leaf node with the TreeID of the root node. In the event the TreeID of a node matches the TreeID of the root node, the file system manager proceeds to the next node. In the event the TreeID of a node does not match the TreeID of the root node, a shadow copy of the node with the non-matching TreeID is made. For example, to reach a leaf node with a data key of "4," the file system manager begins atroot node 1206 and proceeds tointermediate node 1018b. The file system manager compares the TreeID ofintermediate node 1018b with the TreeID ofroot node 1206, determines that the TreeID ofintermediate node 1018b does not match the TreeID ofroot node 1206, and creates a copy ofintermediate node 1018b. Theintermediate node copy 1218 includes the same set of pointers asintermediate node 1018b, but includes a TreeID of "5" to match the TreeID ofroot node 1206. The file system manager updates a set of pointers ofroot node 1206 to point tointermediate node 1218 instead of pointing tointermediate node 1018b. The file system manager traversestree data structure 1206 fromintermediate node 1218 toleaf node 1034b, determines that the TreeID ofleaf node 1034b does not match the TreeID ofroot node 1206, and creates a copy ofleaf node 1034b.Leaf node copy 1234 stores the modified value "DAT A4"'" and includes the same TreeID asroot node 1206. The file system manager updates a pointer ofintermediate node 1218 to point toleaf node 1234 instead of pointing toleaf node 1034b. -
FIG. 12C is a block diagram illustrating an embodiment of a modified partially cloned snapshot tree. Thetree data structure 1250 shown inFIG. 12C illustrates a result of the modifications made totree data structure 1250 as described with respect toFIG. 12B . The snapshot trees oftree data structure 1250 may be maintained in a similar fashion as described above with respect toFIG. 7A ,7B , and7C . - Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
Claims (19)
- A method of accessing tree data, comprising:obtaining metadata of a root node from a serialized representation of a file system metadata tree data structure;creating a representation of the root node that references a stub intermediate node that is a placeholder for an intermediate node stored in the serialized representation;receiving a request to access data of a leaf node in a tree path including the intermediate node; andin response to the request, obtaining metadata of the intermediate node from serialized metadata representation.
- The method of claim 1, further comprising identifying the serialized representation of the file system metadata tree data structure.
- The method of claim 1 or 2, wherein the request to access the data of the leaf node includes a request to modify the data of the leaf node.
- The method of claim 3, further comprising creating a clone of the root node.
- The method of any preceding claim, further comprising prefetching metadata associated with one or more stub nodes that are not part of the request to access data of the leaf node.
- The method of claim 5, wherein the metadata associated with the one or more stub nodes that are not part of the request to access data of the leaf node is prefetched based on a prior usage pattern.
- The method of any preceding claim, wherein the stub intermediate node includes a pointer to a storage block of a remote storage location.
- The method of claim 7, wherein the storage block includes one or more file offsets to one or more other storage blocks of the remote storage location.
- The method of claim 8, wherein at least one of the one or more other storage blocks is either a block of the serialized representation of the file system metadata tree structure or a block of a different serialized representation of the file system metadata tree structure.
- The method of any preceding claim, wherein the request to access data of the leaf node includes a key associated with the leaf node.
- The method of claim 10, further comprising partially restoring the file system metadata tree data structure until a restored node includes the key associated with the leaf node is restored.
- The method of claim 11, further comprising:determining that the restored node provides direct access to the requested data; and obtaining and provide the requested data.
- A system for accessing tree data, comprising:a processor configured to:obtain metadata of a root node from a serialized representation of a file system metadata tree data structure;create a representation of the root node that references a stub intermediate node that is a placeholder for an intermediate node stored in the serialized representation;receive a request to access data of a leaf node in a tree path including the intermediate node; andin response to the request, obtain metadata of the intermediate node from serialized metadata representation; anda memory coupled to the processor and configured to provide the processor with instructions.
- The system of claim 13, wherein the processor is further configured to identify the serialized representation of the file system metadata tree data structure.
- The system of claim 13 or 14, wherein the processor is further configured to allow access to the data of the leaf node.
- The system of claim 15, wherein the processor is further configured to create a clone of the root node.
- The system of any of claims 13-16, wherein the processor is further configured to prefetch metadata associated with one or more stub nodes that are not part of the request to access data of the leaf node.
- The system of any of claims 13-17, wherein the stub intermediate node includes a pointer to a storage block of a remote storage location.
- A computer program product for accessing tree data, the computer program product being embodied in a non-transitory computer readable storage medium and comprising computer instructions for:obtaining metadata of a root node from a serialized representation of a file system metadata tree data structure;creating a representation of the root node that references a stub intermediate node that is a placeholder for an intermediate node stored in the serialized representation;receiving a request to access data of a leaf node in a tree path including the intermediate node; andin response to the request, obtaining metadata of the intermediate node from serialized metadata representation.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP21162558.7A EP3913492A1 (en) | 2017-09-07 | 2018-09-05 | Remotely mounted file system with stubs |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201762555456P | 2017-09-07 | 2017-09-07 | |
US15/721,429 US10719484B2 (en) | 2017-09-07 | 2017-09-29 | Remotely mounted file system with stubs |
PCT/US2018/046724 WO2019050661A1 (en) | 2017-09-07 | 2018-08-14 | Remotely mounted file system with stubs |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP21162558.7A Division EP3913492A1 (en) | 2017-09-07 | 2018-09-05 | Remotely mounted file system with stubs |
Publications (2)
Publication Number | Publication Date |
---|---|
EP3454231A1 true EP3454231A1 (en) | 2019-03-13 |
EP3454231B1 EP3454231B1 (en) | 2021-03-17 |
Family
ID=63528525
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP21162558.7A Pending EP3913492A1 (en) | 2017-09-07 | 2018-09-05 | Remotely mounted file system with stubs |
EP18192697.3A Active EP3454231B1 (en) | 2017-09-07 | 2018-09-05 | Remotely mounted file system with stubs |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP21162558.7A Pending EP3913492A1 (en) | 2017-09-07 | 2018-09-05 | Remotely mounted file system with stubs |
Country Status (1)
Country | Link |
---|---|
EP (2) | EP3913492A1 (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110413694A (en) * | 2019-08-01 | 2019-11-05 | 重庆紫光华山智安科技有限公司 | Metadata management method and relevant apparatus |
CN111324305A (en) * | 2020-02-16 | 2020-06-23 | 西安奥卡云数据科技有限公司 | Data writing/reading method in distributed storage system |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016124959A1 (en) * | 2015-02-05 | 2016-08-11 | Hitachi Data Systems Engineering UK Limited | Management of cloned objects in file systems |
-
2018
- 2018-09-05 EP EP21162558.7A patent/EP3913492A1/en active Pending
- 2018-09-05 EP EP18192697.3A patent/EP3454231B1/en active Active
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016124959A1 (en) * | 2015-02-05 | 2016-08-11 | Hitachi Data Systems Engineering UK Limited | Management of cloned objects in file systems |
Non-Patent Citations (2)
Title |
---|
BILL NOWICKI: "NFS: Network File System Protocol Specification", 31 March 1989 (1989-03-31), XP055511550, Retrieved from the Internet <URL:https://tools.ietf.org/pdf/rfc1094.pdf> [retrieved on 20181002] * |
WINSCP COMMUNITY: "WinSCP documentation", 4 September 2017 (2017-09-04), XP055511896, Retrieved from the Internet <URL:https://web.archive.org/web/20170717223120/https://winscp.net/eng/docs/start> [retrieved on 20181002] * |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110413694A (en) * | 2019-08-01 | 2019-11-05 | 重庆紫光华山智安科技有限公司 | Metadata management method and relevant apparatus |
CN111324305A (en) * | 2020-02-16 | 2020-06-23 | 西安奥卡云数据科技有限公司 | Data writing/reading method in distributed storage system |
Also Published As
Publication number | Publication date |
---|---|
EP3454231B1 (en) | 2021-03-17 |
EP3913492A1 (en) | 2021-11-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11372824B2 (en) | Remotely mounted file system with stubs | |
US11880334B2 (en) | Snapshot archive management | |
US11914485B2 (en) | Restoration of specified content from an archive | |
US11740974B2 (en) | Restoring a database using a fully hydrated backup | |
EP3796174B1 (en) | Restoring a database using a fully hydrated backup | |
WO2013074914A1 (en) | Method of and system for merging, storing and retrieving incremental backup data | |
US11487701B2 (en) | Incremental access requests for portions of files from a cloud archival storage tier | |
US20220382654A1 (en) | Restoring a storage system using file relocation metadata | |
US11403024B2 (en) | Efficient restoration of content | |
EP3454231B1 (en) | Remotely mounted file system with stubs | |
US11874805B2 (en) | Remotely mounted file system with stubs | |
EP3451141B1 (en) | Snapshot archive management | |
US20210004301A1 (en) | Packet-based differential backup of network-attached storage device content |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE |
|
17P | Request for examination filed |
Effective date: 20180905 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
AX | Request for extension of the european patent |
Extension state: BA ME |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: EXAMINATION IS IN PROGRESS |
|
17Q | First examination report despatched |
Effective date: 20190724 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R079 Ref document number: 602018013976 Country of ref document: DE Free format text: PREVIOUS MAIN CLASS: G06F0017300000 Ipc: G06F0016110000 |
|
RIC1 | Information provided on ipc code assigned before grant |
Ipc: G06F 16/11 20190101AFI20200615BHEP Ipc: G06F 16/18 20190101ALI20200615BHEP |
|
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: GRANT OF PATENT IS INTENDED |
|
INTG | Intention to grant announced |
Effective date: 20200929 |
|
RIN1 | Information on inventor provided before grant (corrected) |
Inventor name: GUTURI, VENKATA RANGA RADHANIKANTH Inventor name: MAHATA, TUSHAR Inventor name: YARLAGADDA, PRAVEEN KUMAR |
|
GRAS | Grant fee paid |
Free format text: ORIGINAL CODE: EPIDOSNIGR3 |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE PATENT HAS BEEN GRANTED |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: EP |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R096 Ref document number: 602018013976 Country of ref document: DE |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: FP Ref country code: IE Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: REF Ref document number: 1372889 Country of ref document: AT Kind code of ref document: T Effective date: 20210415 |
|
REG | Reference to a national code |
Ref country code: LT Ref legal event code: MG9D |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: NO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210617 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210618 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: HR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: BG Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210617 |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: MK05 Ref document number: 1372889 Country of ref document: AT Kind code of ref document: T Effective date: 20210317 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LV Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: RS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: EE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: CZ Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: SM Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210719 Ref country code: PL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: RO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: SK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210717 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R097 Ref document number: 602018013976 Country of ref document: DE |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: AL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
26N | No opposition filed |
Effective date: 20211220 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
REG | Reference to a national code |
Ref country code: BE Ref legal event code: MM Effective date: 20210930 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210717 Ref country code: MC Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210905 Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210905 Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210930 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LI Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210930 Ref country code: CH Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20210930 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: NL Payment date: 20220926 Year of fee payment: 5 |
|
P01 | Opt-out of the competence of the unified patent court (upc) registered |
Effective date: 20230515 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: HU Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO Effective date: 20180905 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: MM Effective date: 20231001 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: NL Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20231001 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: TR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 Ref country code: NL Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20231001 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210317 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 20240820 Year of fee payment: 7 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20240821 Year of fee payment: 7 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 20240820 Year of fee payment: 7 |