Cloud-based disaster recovery of backup data and metadata
Cloud storage services can be used to facilitate secondary backup and disaster data recovery without the need for specialized backup servers at the secondary location or cloud storage service. Backup data streams are transferred to a cloud storage service. In addition to the backup data streams, backup metadata is generated for each backup data stream. The backup metadata is adapted to configure a backup server to retrieve and access data in the backup data stream. The backup metadata is also transferred to the cloud storage service. To access data from the backup data stream, a recovery backup system is connected with the cloud storage service. Backup metadata is transferred from the cloud storage service to the recovery backup system. The recovery backup system is updated with the backup metadata, which configures the recovery backup system to retrieve and access data in the backup data stream.
Latest NetApp, Inc. Patents:
- DISTRIBUTED STORAGE SYSTEMS AND METHODS TO PROVIDE CHANGE TRACKING INTEGRATED WITH SCALABLE DATABASES
- DATA TRAFFIC MANAGEMENT IN A COMPUTING ENVIRONMENT UTILIZING DIRECT MEMORY ACCESS FUNCTIONALITY
- Data connector component for implementing management requests
- Use of cluster-level redundancy within a cluster of a distributed storage management system to address node-level errors
- Methods and multi-site systems to provide recovery point objective (RPO) protection and automatically initiate realignment and reconfiguration of a protection configuration from the secondary storage site to the tertiary storage site upon primary storage site failure
This application is related to U.S. Patent Application No. 61/290,334, filed Dec. 28, 2009 and entitled “DEDUPLICATED OBJECT STORAGE SYSTEM AND APPLICATIONS,” and U.S. Provisional Patent Application No. 61/315,392, filed Mar. 18, 2010 and entitled “WAN-OPTIMIZED LOCAL AND CLOUD SPANNING DEDUPLICATED STORAGE SYSTEM,” which is incorporated by reference herein for all purposes. This application is related to U.S. patent application Ser. No. 12/895,811, filed Sep. 30, 2010 and entitled “CLOUD SYNTHETIC BACKUPS,” which is incorporated by reference herein for all purposes.
BACKGROUND OF THE INVENTIONThe present invention relates generally to data storage systems, and systems and methods to improve storage efficiency, compactness, performance, reliability, and compatibility. Many data storage systems are tasked with handling enormous amounts of data. To protect their data, many organizations use backup systems to store multiple copies of important data on-site and/or off-site. Backup systems can create multiple backup data sets and/or snapshots, enabling organizations to maintain copies of their data at different time periods or instances. Backup systems can also create incremental backups, which record changes in an organization's data subsequent to a previous full or incremental backup data set.
Organizations often prefer to store at least some backup data sets at a different location than their primary data center. This protects the organization's data from accidents or disasters occurring at the primary data center. However, maintaining computers and data storage at multiple locations is expensive and time-consuming. As an alternative, many organizations rely on a third-party to provide off-site data storage. Cloud storage services are one type of off-site data storage. Cloud storage services are data storage services available via a wide-area network. Cloud storage services provide storage to users in the form of a virtualized storage device available via the Internet. In general, users access cloud storage to store and retrieve data using web services protocols, such as REST or SOAP.
Cloud storage service providers manage the operation and maintenance of the physical data storage devices. Users of cloud storage can avoid the initial and ongoing costs associated with buying and maintaining storage devices. Cloud storage services typically charge users for consumption of storage resources, such as storage space and/or transfer bandwidth, on a marginal or subscription basis, with little or no upfront costs. In addition to the cost and administrative advantages, cloud storage services often provide dynamically scalable capacity to meet its users changing needs.
Despite the cost and administrative advantages of cloud storage services, integrating cloud storage services with backup systems can be challenging. First, many backup systems require a specialized backup server at each backup site to store and maintain backup data sets. However, cloud storage services often only provide a virtualized data storage device to their users. Adding and maintaining a backup server at the cloud storage site, for example as a physical server or within a virtual machine, increases the cost and complexity of the cloud storage of the cloud storage service. Additionally, because the wide-area network typically has much lower bandwidth and higher latency than local-area networks, access to backup data sets in the cloud storage service is much slower. This can make some operations too slow to be practical. For example, using cloud storage services to create a synthetic backup, which is a complete backup data set created by copying data from two or more previous backup data sets, including at least one incremental backup data set, is extremely slow due to the performance of the wide-area network.
The invention will be described with reference to the drawings, in which:
An embodiment of the invention eliminates the need for specialized backup servers at the secondary location, such as the secondary backup master policy server and secondary backup media server. This enables cloud storage to be used as inexpensive and easily configured and maintained off-site data storage for backup systems. In an embodiment, backup data streams or other forms of backup data are transferred to a cloud storage service. In addition to the backup data streams, backup metadata is generated for each backup data stream. The backup metadata is adapted to configure a backup server to retrieve and access data in the backup data stream. The backup metadata is also transferred to the cloud storage service.
To access data from the backup data stream, an embodiment of the invention connects to the cloud storage service from a secondary or recovery location. Backup metadata is transferred from the cloud storage service to a recovery backup system at the secondary or recovery location. The recovery backup system is updated with the backup metadata, which configures the recovery backup system to retrieve and access data in the backup data stream. In an embodiment, the recovery backup system processes the backup metadata in order of its creation.
Embodiments of the invention transfer backup data streams and/or backup metadata to the cloud storage service in deduplicated form. The backup data stream and/or backup metadata is provided to the recovery location in deduplicated form, where the corresponding undeduplicated versions are reconstructed in whole or part. In an embodiment, a cloud spanning storage interface is used to convert data between deduplicated and undeduplicated forms.
DETAILED DESCRIPTIONPrimary backup system 103 includes a backup master policy server 115. Backup master policy server 115 initiates data backups according to policies and/or commands provided by system administrators. Backup master policy server 115 may initiate full or incremental data backups from one or more client systems 105. Full data backups copy all or a specified portion of the data of one or more client systems 105. Incremental data backups copy only the portion of data from a data set that has changed since a previously completed full or incremental data backup.
Backup master policy server 115 maintains backup metadata describing the contents of each data backup. Backup metadata can include the source of the data in the data backup, the time and date of the data backup, and, if the data backup is an incremental backup, the dependencies of the data backup on previously completed data backups. In general, backup metadata instructs the primary backup system 103, or any other backup system, how to use one or more backup data sets to restore data on one or more client systems 105. Without backup metadata, the backup data sets cannot be used.
The primary backup system 103 also includes a backup media server 120. Backup media server 120 is adapted to receive data from one or more client systems 105 during one or more data backups, assemble the received data into one or more data backup files or backup data streams, and transfer the assembled data backup to one or more data storage devices 125, such as local data storage devices 125a and 125b. Local data storage devices 125 can include file servers, block-based storage devices, and storage array networks. The backup media server 120 may access data storage devices 125 using one or more file system protocols, such as CIFS or NFS, or block-based storage protocols, such as iSCSI or iFCP.
The primary backup system 103 may include one or more local-area networks, such as LAN 107, for facilitating communications between client systems 105, the backup master policy server 115, and the backup media server 120. Additionally, LAN 107 may connect the backup media server 120 with one or more of the storage devices 125. Optionally, a separate storage array network SAN or LAN 109 may connect the backup media server 120 with one or more of the storage devices 125.
To protect data against accidents or disasters occurring at the location of the primary backup system 103, redundant backup system 100 includes a secondary backup system 130 at a different physical location than the primary backup system 103. Secondary backup system 130 includes a secondary backup master policy server 135, a backup media server 140, and one or more storage devices 145. Secondary backup system 130 is capable of communicating with the primary backup system via a wide-area network (WAN), such as the internet or a private WAN.
Typically, the secondary backup system 130 requires its own backup master policy server 135 and backup media server 140, because the backup master policy server 115 and backup media server 120 in the primary backup system 103 are incapable communicating with storage outside of the primary backup system location. Thus, transferring data backups from the primary backup system 103 to the secondary backup system 130 is a convoluted process.
For example, a backup data set created by the primary backup system 103 may be stored on storage device 125b. Storage device 125b initiates the copying of the backup data set to storage device 145a in the secondary backup system 130. This transfer may use one or more local-area and/or wide-area networks.
Once the backup data set has copied to one of the storage devices 145 in the secondary backup system 130, the secondary backup master policy server 135 needs to be updated with backup metadata for the copied backup data set. Typically, the secondary backup master policy server 135 is updated with backup metadata for a transferred backup data set by transferring a copy of the backup metadata 150 from the primary backup system 103 to the secondary backup system 130. For example, a copy of the backup metadata 150 for a copied backup data set is transferred from the backup master policy server 115 to the storage device 125b via the backup media server 120. The storage device 125b then transfers 155 the copy of the backup metadata to the storage device 145a. Storage device 145a transfers this copy of the backup metadata to the secondary backup master policy server 135 by transferring 160 the copy of the backup metadata 150 from the storage device 145a to the secondary backup media server 140. Then, the copy of the backup metadata 150 is transferred 165 from the secondary backup media server 140 to the secondary backup master policy server 135. The secondary backup master policy server 135 uses the copy of the backup metadata to recognize the copied data backup set and make this copied data backup set available to restore data if needed.
An embodiment of the invention eliminates the need for specialized backup servers at the secondary location, such as the secondary backup master policy server 135 and secondary backup media server 140. This enables cloud storage to be used as inexpensive and easily configured and maintained off-site data storage for backup systems.
Primary backup system 203 includes a backup master policy server 215. Backup master policy server 215 initiates data backups according to policies and/or commands provided by system administrators. Backup master policy server 215 may initiate full or incremental data backups from one or more client systems 205.
Backup master policy server 215 maintains backup metadata describing the contents of each data backup. Backup metadata can include the source of the data in the data backup, the time and data of the data backup, and, if the data backup is an incremental backup, the dependencies of the data backup on previously completed data backups. In general, backup metadata instructs the primary backup system 203, or any other backup system, how to use one or more backup data sets to restore data on one or more client systems 205.
The primary backup system 203 also includes a backup media server 220. Backup media server 220 is adapted to receive data from one or more client systems 205 during one or more data backups, assemble the received data into one or more data backup files or backup data streams, and transfer the assembled data backup to one or more data storage devices 225, such as a local data storage device 225a. Local data storage devices 225 can include file servers, block-based storage devices, and storage array networks. The backup media server 220 may access data storage devices 225 using one or more file system protocols, such as CIFS or NFS, or block-based storage protocols, such as iSCSI or iFCP.
The primary backup system 203 may include one or more local-area networks, such as LAN 207, for facilitating communications between client systems 205, the backup master policy server 215, and the backup media server 220. Additionally, LAN 207 may connect the backup media server 220 with one or more of the storage devices 225. Optionally, a separate storage array network SAN 209 may connect the backup media server 220 with one or more of the storage devices 225.
To protect data against accidents or disasters occurring at the location of the primary backup system 203, cloud backup system 200 includes a cloud storage service 250. Cloud storage service 250 is connected with the primary backup system 203 via a wide-area network 230, such as the internet or a private WAN. Cloud storage service 250 includes a cloud storage interface 255 and data storage 260. Cloud storage interface 255 receives data read and write requests using cloud storage protocols, for example based on web services protocols such as SOAP or REST, and performs corresponding storage operations with data storage 260.
In an embodiment, primary backup system 203 includes a cloud spanning storage interface device 225b. Cloud spanning storage interface 225b enables backup media server 220 to communicate with cloud storage service 250 as if the service 250 was a local storage device. The cloud spanning storage interface 225b stores and retrieves data from a cloud storage service 250 via wide-area network 230 using cloud storage service access protocols, such as SOAP or REST. The cloud spanning storage interface 225 may provide an interface to the backup media server 220 in the form of a file system protocol, such as CIFS or NFS, a block-based storage protocols, such as iSCSI or iFCP, or a standard or proprietary API provided by the backup media server 220. In a further embodiment, the backup media server 220 uses an API to support one or more storage plug-in software modules adapted to communicate with the cloud spanning storage interface 225b.
Embodiments of the cloud spanning storage interface 225b include a local storage cache for storing data frequently accessed by the backup media server. Embodiments of the cloud spanning storage interface 225b may use local storage to queue data that is being transferred to the cloud storage service 250 via the wide-area network. Further embodiments of the cloud spanning storage interface 225b may predict data likely to be requested by the backup media server 220 and prefetch and cache this data in local storage. In still further embodiments, the cloud spanning storage interface 225b may perform data deduplication and/or data compression to reduce the amount of data storage required to store data and to maximize the use of available bandwidth of the wide-area network 230 in transferring data between the primary backup system 203 and the cloud storage service 250.
As shown in
Step 305 receives a data backup from a backup media server and transfers the data backup to a cloud storage service. The data backup may include one or more backup data files and/or one or more one or more raw streams of backup data. Step 305 may optionally maintain a local copy of some or all of the transferred data backup.
Step 310 generates backup metadata for the received data backup. Embodiments of step 310 may receive backup metadata for the received data backup from a master policy backup server in the primary backup system. Alternate embodiments of step 310 may query or access the master policy backup server or its associated data to retrieve backup metadata.
In an embodiment, backup metadata is in a format adapted to be read by one or more additional master policy backup servers to recognize the copied data backup set and make this copied data backup set available to restore data if needed. For example, backup metadata may be provided in a portable data format.
In a further embodiment, backup metadata is in the form of a log file or other data structure that indicates the completion of one or more data backup and/or replications of data backups to a secondary backup system. In yet a further embodiment, a cloud spanning storage interface may provide the primary backup system with an indication that a backup data set has been replicated by a secondary backup system, even though the cloud spanning storage interface has actually only transferred the data backup to the cloud storage. The cloud spanning storage interface then receives or retrieves a backup replication completion log file from the primary backup system to be used as backup metadata.
Step 315 transfers the backup metadata to the cloud storage service for storage. In an embodiment, step 315 stores the backup metadata in the cloud storage separately from the data backup, such as in a different storage location or associated with a different storage identifier. In an embodiment, the backup metadata is stored in the cloud storage in a manner such that an association between the backup metadata and the data backup is apparent.
Steps 305, 310, and 315 may optionally be repeated any arbitrary number of times to transfer additional data backups and associated backup metadata from the primary backup system to the cloud storage.
If there is a need to restore data from one or more data backups using a different backup system, such as following an accident, disaster, or other catastrophic failure at the location of the primary backup system, step 320 connects a new backup system, referred to as the recovery system, to the cloud storage service. The recovery system includes a recovery master policy server, a recovery media server, and a recovery cloud spanning storage interface, similar to their counterparts in the primary backup system.
In step 325, the recovery system retrieves the backup metadata for the data backups stored in the cloud storage. In an embodiment, upon connecting with the cloud storage service, the recovery cloud spanning storage interface searches for and retrieves all of the backup metadata the cloud storage service.
Following the retrieval of the backup metadata from the cloud storage service in step 325, step 330 updates the recovery master policy server in the recovery system using the retrieved backup metadata. In an embodiment of step 330, the recovery cloud spanning storage interface provides backup metadata to the recovery master policy server in the same order that the backup metadata was created. In response to each set of backup metadata, the recovery master policy server updates its internal data structures so that it recognizes the associated data backup stored in the cloud storage service.
In a further embodiment, the backup metadata is in the form of a log file or other data structure that indicates the completion of one or more data backup and/or replications of data backups to a secondary backup system. An embodiment of step 330 “replays” operations, transactions, or other events described in the backup metadata log file or other data structure to configure the recovery master policy server. For example, a cloud spanning storage interface in the recovery system may use an API to inform the recovery master policy server that the data backups identified in the backup metadata are complete. In this example, even though the recovery master policy server did not initiate the data backups identified in the backup metadata (because they were performed by the primary backup system), replaying the operations, transactions, or other events in the backup metadata log file will configure the recovery master policy server appropriately. This embodiment using data backup or replication log files or other data structures as backup metadata allow for the implementation of cloud-based disaster recovery systems without explicit support for disaster recovery or cloud-based storage by the backup system.
Following the processing of all of the backup metadata retrieved from the cloud storage service, the recovery master policy server is configured to access any of the available data backups in the cloud service. Following step 330, the recovery system may restore data from one or more data backups stored by the cloud storage service. For example, a system administrator may initiate a data recovery by selecting data to restore from a list of data backups provided by the recovery master policy server of the recovery system. The recovery master policy server can provide this list of data backups because its internal data has been configured with backup metadata as described above. In response to a selection of data to restore, the recovery media server requests the appropriate data backups from the recovery cloud spanning storage interface. The recovery cloud spanning storage interface retrieves the requested data backups from the cloud storage service. The recovery media server uses the retrieved data backups to restore the requested data.
It should be noted that there is no limit to the amount of time that may pass between the transfer of backup metadata to the cloud storage service and the updating of the recovery system with the backup metadata. Provided that backup metadata is processed in the correct order when it is eventually retrieved, backup metadata stored in the cloud storage service is still valid months or years following its creation.
The term “data deduplication” refers to some process of eliminating redundant data for the purposes of storage or communication. Data deduplicating storage typically compares incoming data with the data already stored, and only stores the portions of the incoming data that do not match data already stored in the data storage system. Data deduplicating storage maintains metadata to determine when portions of data are no longer in use by any files or other data entities.
In an optional embodiment, the cloud spanning storage interface performs data deduplication to reduce the amount of cloud storage required to store data backups, maximize data transfer performance via a wide-area network with the cloud storage service, and, as discussed in detail below, efficiently create synthetic backups from backup data stored in cloud storage services.
Examples of deduplicating cloud spanning storage interfaces are described in detail in U.S. Provisional Patent Application No. 61/315,392, filed Mar. 18, 2010 and entitled “WAN-OPTIMIZED LOCAL AND CLOUD SPANNING DEDUPLICATED STORAGE SYSTEM,” which is incorporated by reference herein for all purposes.
Embodiments of cloud spanning storage interface 400 may support a variety of different storage applications using cloud data storage, including general data storage, data backup, disaster recovery, and deduplicated cloud data storage. In the case of general data storage applications, a client, such as client 405c, may communicate with the cloud spanning storage interface 425 via a file system protocol, such as CIFS or NFS, or a block-based storage protocol, such as iSCSI or IFCP. Data backup and disaster recovery applications may also use these protocols or specific backup and recovery protocols, such as VTL or OST. For backup applications, a client system 405a may include a backup agent 410 for initiating data backups. The backup agent 410 may communicate directly with the cloud spanning storage interface 425 or a backup server 405b, which in cloud spanning storage interface 400 is equivalent to a client. For cloud storage applications, a client 403c may communicate with the cloud spanning storage interface 425 via a web services protocol, such as SOAP or REST. The web services protocol may present a virtualized storage device to client 403c. The web services protocol used by clients 405 to communicate with the cloud spanning storage interface 425 may be the same or different than the protocol used by the cloud spanning storage interface 425 to communicate with the cloud storage 475.
Embodiments of the cloud spanning storage interface 400 may optimize data access to cloud storage 475 in a number of different ways. An embodiment of the cloud spanning storage interface 425 may present clients 405 with a file system, backup device, storage array, or other data storage interface, while transparently storing and retrieving data using the cloud storage 475 via the wide-area network 477. In a further embodiment, the cloud spanning storage interface 425 may perform data deduplication on data received from clients 405, thereby reducing the amount of storage capacity required in cloud storage 475. Additionally, because the bandwidth of the wide-area network is often limited, data deduplication by the cloud spanning storage interface 425 increases the data access performance, as perceived by the clients 425. In still a further embodiment, the cloud spanning storage interface 425 may locally cache a portion of the clients' data using local storage 470. The locally cached data may be accessed rapidly, further improving the perceived data access performance. As described in detail below, the cloud spanning storage interface 425 may use a variety of different criteria for selecting the portion of the clients' data to cache locally and may locally cache data in a deduplicated form to reduce the required capacity of local storage 475.
An embodiment of cloud spanning storage interface 425 includes one or more front end interfaces 430 for communicating with one or more client systems 405. Examples of front end interfaces 430 include a backup front end interface 430a, a file system front end interface 430b, a cloud storage front end interface 430c, a file archival front end interface 430d, and a object front end interface 430e. An example backup front end interface 430a enables backup applications, such as a backup agent 410 and/or a backup server 405b, to store and retrieve data to and from the cloud storage 475 using data backup and recovery protocols such as VTL or OST. In this example, the backup front end interface 430a allows the cloud spanning storage interface 425 and cloud storage 475 to appear to clients 405 as a backup storage device.
An example file system front end interface 430b enables clients 405 to store and retrieve data to and from the cloud data storage 475 using a file system protocol, such as CIFS or NFS, or a block-based storage protocol, such as iSCSI or IFCP. In this example, the file system front end interface 430b allows the cloud spanning storage interface 425 and cloud storage 475 to appear to clients 405 as one or more storage devices, such as a CIFS or NFS storage volume or a iSCSI or FibreChannel logical unit number (LUN).
An example cloud storage front end interface 430c enables clients 405 to store and retrieve data to and from the cloud data storage 475 using a cloud storage protocol or API. Typically, cloud storage protocols or APIs are implemented using a web services protocol, such as SOAP or REST. In this example, the cloud storage front end interface 430c allows the cloud spanning storage interface 425 and cloud storage 475 to appear to clients 405 as one or more cloud storage services. By using cloud spanning storage interface 425 to provide a cloud storage interface to clients 405, rather than letting clients 405 communicate directly with the cloud storage 475, the cloud spanning storage interface 425 may perform data deduplication, local caching, and/or translation between different cloud storage protocols.
An example file archival front end interface 430d enables clients 405 to store and retrieve file archives. Clients 405 may use the cloud spanning storage interface 425 and the cloud storage 475 to store and retrieve files or other data in one or more archive files. The file archival front end interface 430d allows clients 405 to store archive files using cloud storage 475 using archive file interfaces, rather than a cloud storage interface. Additionally, the cloud spanning storage interface 425 may perform data deduplication and local caching of the file archives.
An example object front end interface 430e enables clients to store and retrieve data in any arbitrary format, such as object formats and blobs or binary large objects. The object front end interface 430e allows clients 405 to store data in arbitrary formats, such as object formats or blobs, using cloud storage 475 using object protocols, such as object serialization or blob storage protocols, rather than a cloud storage protocol. Additionally, the cloud spanning storage interface 425 may perform data deduplication and local caching of the object or blob data.
In an embodiment, cloud spanning storage interface 425 also includes one or more shell file systems 445. Shell file system 445 includes a representation of all of the entities, such as files, directories, objects, blobs, and file archives, stored by clients 425 via the front end interfaces 430. In an embodiment, the shell file system 445 includes all of the entities stored by the clients 425 in a shell form. In this embodiment, each entity, such as a file or other entity, is a represented by a “shell” entity that does not include the data contents of the original entity. For example, a shell file in the shell file system 445 includes the same name, file path, and file metadata as the original file. However, the shell file does not include the actual file data, which is stored in the cloud storage 475. It should be noted that although the size of the shell file is less than the size of the actual stored file (in either its original or deduplicated format, an embodiment of the shell file system 445 sets the file size metadata attribute of the shell file to the size of the original file. In a further embodiment, each entity in the shell file system 445, such as a file, directory, object, blob, or file archive, may include additional metadata for use by the cloud spanning storage interface 425 to access the corresponding data from the cloud storage 475.
An embodiment of the cloud spanning storage interface 425 includes a deduplication module 450 for deduplicating data received from clients 405. Deduplication module 450 analyzes data from clients 405 and compares incoming data with previously stored data to eliminate redundant data for the purposes of storage or communication. Data deduplication reduces the amount of storage capacity used by cloud storage 475 to store clients' data. Also, because wide-area network 477 typically has bandwidth limitations, the reduction of data size due to data deduplication also reduces the amount of time required to transfer data between clients 405 and the cloud storage 475. Additionally, deduplication module 450 retrieves deduplicated data from the cloud storage 475 and converts it back to its original form for use by clients 405.
In an embodiment, deduplication module 450 performs data deduplication on incoming data and temporarily stores this deduplicated data locally, such as on local storage 470. Local storage 470 may be a physical storage device connected with or integrated within the cloud spanning storage interface 425. Local storage 470 is accessed from cloud spanning storage interface 425 by a local storage interface 460, such as an internal or external data storage interface, or via a local-area network.
In an embodiment, the cloud storage 475 includes a complete and authoritative version of the clients' data. In a further embodiment, the cloud spanning storage interface 425 may maintain local copies of some or all of the clients' data for the purpose of caching. In this embodiment, the cloud spanning storage interface 425 uses the local storage 470 to cache client data. The cloud spanning storage interface 425 may cache data in its deduplicated format to reduce local storage requirements or increase the effective cache size. In this embodiment, the cloud spanning storage interface 425 may use a variety of criteria for selecting portions of the deduplicated client data for caching. For example, if the cloud spanning storage interface 425 is used for general file storage or as a cloud storage interface, the cloud spanning storage interface may select a specific amount or percentage of the client data for local caching. In another example, the data selected for local caching may be based on usage patterns of client data, such as frequently or recently used data. Caching criteria may be based on elapsed time and/or the type of data. In another example, the cloud spanning storage interface 425 may maintain locally cached copies of the most recent data backups from clients, such as the most recent full backup and the previous week's incremental backups.
In an embodiment, replication module 455 transfers locally stored deduplicated data from the cloud spanning storage interface 425 to the cloud storage 475. Embodiments of the deduplication module and the replication module 455 may operate in parallel and/or asynchronously, so that the bandwidth limitations of wide-area network 477 do not interfere with the throughput of the deduplication module 450. The operation of embodiments of deduplication module 450 and replication module 455 are described in detail below.
An embodiment of cloud spanning storage interface 425 includes a cloud storage backend interface 465 for communicating data between the cloud spanning storage interface 425 and the cloud storage 475. Embodiments of the cloud storage backend interface 465 may use cloud storage protocols or API and/or web services protocols, such as SOAP or REST, to store and retrieve data from the cloud storage 475. In an embodiment, the replication module transfers deduplicated data from local storage 470 to cloud storage 475 using the cloud storage backend interface 465. In an embodiment, the deduplication module retrieves deduplicated data from the cloud storage 475 using the cloud storage backend interface 465.
In an embodiment, the cloud spanning storage interface 425 performs data deduplication by segmenting an incoming data stream to aid data compression. For example, segmentation may be designed to produce many identical segments when the data stream includes redundant data. Multiple instances of redundant data may be represented by referencing a single copy of this data.
Additionally, a data stream may be segmented based on data types to aid data compression, such that different data types are in different segments. Different data compression techniques may then be applied to each segment. Data compression may also determine the length of data segments. For example, data compression may be applied to a data stream until segment boundary is reached or the segment including the compressed data reaches a predetermined size, such as 4 KB. The size threshold for compressed data segments may be based on optimizing disk or data storage device access.
Regardless of the technique used to segment data in the data stream, the result is a segmented data stream having its data represented as segments. In some embodiments of the invention, data segmentation occurs in memory and the segmented data stream is not written back to data storage in this form. Each segment is associated with a label. Labels are smaller in size than the segments they represent. The segmented data stream is then replaced with deduplicated data in the form of a label map and segment storage. Label map includes a sequence of labels corresponding with the sequence of data segments identified in the segmented data stream. Segment storage includes copies of the segment labels and corresponding segment data. Using the label map and the data segment storage, a storage system can reconstruct the original data stream by matching in sequence each label in a label map with its corresponding segment data from the data segment storage.
Embodiments of the invention attempt (but do not always succeed) in assigning a single label to each unique data segment. Because the segmentation of the data stream produces many identical segments when the data stream includes redundant data, these embodiments allow a single label and one copy of the corresponding segment data to represent many instances of this segment data at multiple locations in the data stream. For example, a label map may include multiple instances of a given label at different locations. Each instance of this label represents an instance of the corresponding segment data. Because the label is smaller than the corresponding segment data, representing redundant segment data using multiple instances of the same label results in a substantial size reduction of the data stream.
Memory 505 includes a slab cache data structure 515. The slab cache 515 is adapted to store a set of labels 520 and a corresponding set of data segments 525. In typical applications, the sets of labels 520 and data segments 525 stored in the slab cache 515 represent only a small fraction of the total number of data segments and labels used to represent stored data. A complete set of the labels and data segments is stored in disk storage 510.
An embodiment of the slab cache 515 also includes segment metadata 530, which specifies characteristics of the data segments 525. In an embodiment, the segment metadata 530 includes the lengths of the data segments 525; hashes or other characterizations of the contents of the data segments 525; and/or anchor indicators, which indicate whether a particular data segment has been designated as a representative example of the contents of a data segment slab file, as discussed in detail below.
An embodiment of the slab cache 515 also includes data segment reference count values. The cloud spanning storage interface 500 recognizes that some data segments are used in multiple places in one or more data streams. For at least some of the data segments, an embodiment of the cloud spanning storage interface 500 maintains counts, referred to as reference counts, of the number of times these data segments are used. As discussed in detail below, if a data stream includes a data segment previously defined, an embodiment of the cloud spanning storage interface 500 may increment the reference count value associated with this data segment. Conversely, if a data stream is deleted from the cloud spanning storage interface 500, an embodiment of the cloud spanning storage interface 500 may decrement the reference count values associated with the data segments included in the deleted data stream. If the reference count value of a data segment drops to zero, the data segment and label may be deleted and its storage space reallocated.
In addition to the slab cache 515, an embodiment of the cloud spanning storage interface 500 includes a reverse map cache 540. In an embodiment, the reverse map cache 540 maps the contents of a data segment to a label, for the labels stored in the slab cache 515. In an embodiment, a hashing or other data characterization technique is applied to segment data. The resulting value is used as an index in the reverse map cache 540 to identify an associated label in the slab cache 515. If the hash or other value derived from the segment data matches an entry in the reverse map cache 540, then this data segment has been previously defined and is stored in the slab cache 515. If the hash or other value derived from the segment data does not match any entry in the reverse map cache 540, then this data segment is not currently stored in the slab cache 515. Because the slab cache 515 only includes a portion of the total number of labels used to represent data segments, a data segment that does not match a reverse map cache entry may either have not been previously defined or may have been previously defined but not loaded into the slab cache 515.
In an embodiment, memory 505 of the cloud spanning storage interface 500 also includes an anchor cache 545. Anchor cache 545 is similar to reverse map cache 540; however, anchor cache 545 matches the contents of data segments with representative data segments in data segment slab files stored on disk storage 510. A complete set of data segments are stored in one or more data segment slab files in disk storage 510. In an embodiment, one or more representative data segments from each data segment slab file are selected by the cloud spanning storage interface 500. The cloud spanning storage interface 500 determines hash or other data characterization values for these selected representative data segments and stores these values along with data identifying the file or disk storage location including this data segment in the anchor cache 545. In an embodiment, the data identifying the file or disk storage location of a representative data segment may be its associated label. The cloud spanning storage interface 500 uses the anchor cache 545 to determine if a data segment from a data stream matches a data segment from another data stream previously stored in disk storage but not currently stored in the slab cache.
In an embodiment, potential representative data segments are identified during segmentation of a data stream. As discussed in detail below, when one or more potential representative data segments are later stored in disk storage 510, for example in a data segment slab file, an embodiment of the cloud spanning storage interface 500 selects one or more of these potential representative data segments for inclusion in the anchor cache.
A variety of criteria and types of analysis may be used alone or together in various combinations to identify representative data segments in data streams and/or in data segment slab files stored in disk storage 510. For example, the cloud spanning storage interface 500 selects the first unique data segment in a data stream as a representative data segment. In another example, the cloud spanning storage interface 500 uses the content of the data stream to identify potential representative data segments. In still another example, the cloud spanning storage interface 500 uses criteria based on metadata such as a file type, data type, or other attributes provided with a data stream to identify potential representative data segments. For example, data segments including specific sequences of data and/or located at specific locations within a data stream of a given type may be designated as representative data segments based on criteria or heuristics used by the cloud spanning storage interface 500. In a further example, a random selection of unique segments in a data stream or a data segment slab file may be designated as representative data segments. In yet a further example, representative data segments may be selected at specific locations of data segment slab files, such as the middle data segment in a slab file.
Disk storage 510 stores a complete set of data segments and associated labels used to represent all of the data streams stored by cloud spanning storage interface 500. In an embodiment, disk storage 510 may be comprised of multiple physical and/or logical storage devices. In a further embodiment, disk storage 510 may be implementing using a storage area network.
Disk storage 510 includes one or more data segment slab files 550. Each data segment slab file 550 includes a segment index 555 and a set of data segments 565. The segment index 555 specifies the location of each data segment within the data segment slab file. Data segment slab file 550 also includes segment metadata 560, similar to the segment metadata 530 discussed above. In an embodiment, segment metadata 560 in the data segment slab file 550 is a subset of the segment metadata in the slab cache 515 to improve compression performance. In this embodiment, the cloud spanning storage interface 500 may recompute or recreate the remaining metadata attribute values for data segments upon transferring data segments into the slab cache 515.
Additionally, data segment slab file 550 may include data segment reference count values 570 for some or all of the data segments 565. In an embodiment, slab file 550 may include slab file metadata 575, such as a list of data segments to be deleted from the slab file 550.
Disk storage 510 includes one or more label map container files 580. Each label map container file 580 includes one or more label maps 590. Each of the label maps 590 corresponds with all or a portion of a deduplicated data stream stored by the cloud spanning storage interface 500. Each of the label maps 590 includes a sequence of one or more labels corresponding with the sequence of data segments in all or a portion of a deduplicated data stream. In an embodiment, each label map also includes a label map table of contents providing the offset or relative position of sections of the label map sequence with respect to the original data stream. In one implementation, the label maps are compressed in sections, and the label map table of contents provides offsets or relative locations of sections of the label map sequence relative to the uncompressed data stream. The label map table of contents may be used to allow random or non-sequential access to a deduplicated data stream.
Additionally, label map container file 580 may include label map container index 585 that specifies the location of each label map within the label map container file.
In an embodiment, label names are used not only identify data segments, but also to locate data segments and their containing data segment slab files. For example, labels may be assigned to data segments during segmentation. Each label name may include a prefix portion and a suffix portion. The prefix portion of the label name may correspond with the file system path and/or file name of the data segment slab file used to store its associated segment. All of the data segments associated with the same label prefix may be stored in the same data segment slab file. The suffix portion of the label name may be used to specify the location of the data segment within its data segment slab file. The suffix portion of the label name may be used directly as an index or location value of its data segment or indirectly in conjunction with segment index data in the slab file. In this implementation, the complete label name associated with a data segment does not need to be stored in the slab file. Instead, the label name is represented implicitly by the storage location of the slab file and the data segment within the slab file. In a further embodiment, label names are assigned sequentially in one or more namespaces or sequences to facilitate this usage.
An embodiment similarly uses data stream identifiers to not only identify deduplicated data streams but to locate label maps and their containing label map containers. For example, a data stream identifier is assigned to a data stream during deduplication. Each data stream identifier name may include a prefix portion and a suffix portion. The prefix portion of the data stream identifier may correspond with the file system path and/or file name of the label map container used to store the label map representing the data stream. The suffix portion of the data stream identifier may be used to directly or indirectly specify the location of the label map within its label map container file. In a further embodiment, data stream identifiers are assigned sequentially in one or more namespaces or sequences to facilitate this usage.
Embodiments of the cloud spanning storage interface 500 may specify the sizes, location, alignment, and optionally padding of data in data segment slab files 550 and label map container files 580 to optimize the performance of disk storage 510. For example, segment reference counts are frequently updated, so these may be located at the end of the data segment slab file 550 to improve update performance. In another example, data segments may be sized and aligned according to the sizes and boundaries of clusters or blocks in the disk storage 510 to improve access performance and reduce wasted storage space.
A synthetic backup is a complete backup data set created by copying data from two or more previous backup data sets, including one full backup data set followed by one or more incremental backup data set. For example, if a complete backup data set was created on June 1 and an incremental data backup was created on June 2, a synthetic backup representing the complete backup data set on June 2 may be created by combining these two backups. The incremental data backup only includes data that has been added or changed since the complete backup data set was created. The synthetic data backup can be created by combining the contents of the incremental data backup with unchanged portions of the complete backup data set. If the synthetic backup is created from multiple incremental backups, then the synthetic backup includes the most recent version of each portion of data in the backup data, as selected from one of the backup data sets.
A cloud synthetic backup is a synthetic backup created from two or more previous backup data sets, including at least one incremental backup data set, stored in a cloud storage service. As described in detail below, an embodiment of the invention can create cloud synthetic backups without retrieving backup data from the cloud storage service or transferring additional backup data to the cloud storage service. Further embodiments of the invention may also be used to create synthetic backups from locally-stored deduplicated backup data alone or in combination with deduplicated backup data stored by a cloud storage service.
Following one or more iterations of steps 605, 610, and 615, the cloud storage service includes one or more backup data sets, stored in deduplicated form as data segments, labels, and label maps. These backup data sets may be used by an embodiment of the invention to create one or more synthetic backups in the cloud storage service without retrieving backup data from the cloud storage service, transferring additional backup data to the cloud storage service, or performing intensive data manipulation on data in the cloud storage service.
To generate a synthetic backup, the backup media server identifies the portions of previously created backup data sets that need to be copied to the new synthetic backup. Additionally, the backup media server identifies the locations or sequence of portions from previously created backup data sets to be copied to the new synthetic backup.
Step 660 receives a specification of a portion of a previously created backup to be copied to the new synthetic backup from the backup media server. In an embodiment, this portion to be copied is specified by identifying the previous backup data stream; the location, such as an address or offset, of the beginning of this portion; the size or ending location of this portion; and the destination location, such as an address or offset, of the portion in the synthetic backup. Alternate embodiments may specify the portion of a previously created backup to be copied to the new synthetic backup in a variety of different ways. For example, the destination location may be omitted if the backup media server specifies portions to be copied sequentially. In this example, the destination location is implicitly defined as immediately following the previously specified portion.
Step 665 identifies one or more data segments corresponding with the specified portion. In an embodiment, step 665 accesses the label map for the previously created backup data set including the specified portion. Step 665 may retrieve copies of label maps as needed from the cloud storage service or local copies of label maps after deduplicating data. In an embodiment, each label map includes metadata, such as data segment sizes or data segment locations, for each label. Thus, step 665 is able to identify a data segment corresponding with a given location in a previously generated backup data stream. Based on the starting and ending locations of the specified portion of a backup data set, step 665 can identify corresponding labels in the label map.
Step 670 adds the identified labels to a new label map representing the synthetic backup. Step 670 adds the identified labels to the new label map according to the destination location specified by the backup media server. This may require inserting the identified labels between previously added labels if the backup media server specifies an explicit destination location or appending the identified labels to the end of a sequence of previously added labels if the backup media server specifies portions sequentially.
Often, the portions of one or more previously created backup to be copied to a new synthetic backup may not correspond with the boundaries of corresponding data segments. For example, the portion of the previously created backup may have a starting address or offset after the beginning of a data segment and/or an ending address, offset or location before the end of a data segment. In this case, an embodiment of step 670 creates a label map for the synthetic backup that includes indicators specifying the use of partial data segments. For example, a label and its optional indicators in a label map specify starting addresses or locations and/or ending addresses or locations of data to be included from their associated data segments. If a data segment is to be included in its entirety in a synthetic backup, these indicators may be omitted.
Steps 660, 665, and 670 may be repeated for an arbitrary number of iterations in response to the backup media server specifying additional portions of one or more backup data sets to be copied to the synthetic backup. Once the backup media server has specified all of the portions of one or more backup media sets to be copied to create the synthetic backup, step 675 transfers the label map representing the synthetic backup to the cloud storage.
Because this embodiment of the invention stores backup data in a segmented and deduplicated form, there is no need to directly copy or otherwise access the backup data or corresponding data segments from previously created backup data sets. Instead, the creation of the synthetic backup can be performed as a manipulation of labels and label maps.
Furthermore, because all of the previously created backup data sets have been stored in the cloud storage service, there is no need to transfer any additional backup data, apart from the new label map, to the cloud storage service. Typical label maps are several orders of magnitude smaller than the actual backup data. Thus, steps 665 through 675, including the transferring of the new label map to the cloud storage service, can be performed very quickly.
Following the completion of the deduplicated synthetic backup, an embodiment of the invention provides a data stream identifier or one or more shell files representing the deduplicated synthetic backup to the backup system and/or any other storage clients. The deduplicated synthetic backup can be accessed by the backup system via the cloud spanning storage interface in the same manner as any other backup data set. There is no additional overhead in assembling the synthetic backup from its label map and data segments as compared with any other deduplicated data stored in the cloud storage service.
Computer system 2000 includes a central processing unit (CPU) 2005 for running software applications and optionally an operating system. CPU 2005 may be comprised of one or more processing cores. Memory 2010 stores applications and data for use by the CPU 2005. Examples of memory 2010 include dynamic and static random access memory. Storage 2015 provides non-volatile storage for applications and data and may include fixed or removable hard disk drives, flash memory devices, ROM memory, and CD-ROM, DVD-ROM, Blu-ray, HD-DVD, or other magnetic, optical, or solid state storage devices.
In a further embodiment, CPU 2005 may execute virtual machine software applications to create one or more virtual processors capable of executing additional software applications and optional additional operating systems. Virtual machine applications can include interpreters, recompilers, and just-in-time compilers to assist in executing software applications within virtual machines. Additionally, one or more CPUs 2005 or associated processing cores can include virtualization specific hardware, such as additional register sets, memory address manipulation hardware, additional virtualization-specific processor instructions, and virtual machine state maintenance and migration hardware.
Optional user input devices 2020 communicate user inputs from one or more users to the computer system 2000, examples of which may include keyboards, mice, joysticks, digitizer tablets, touch pads, touch screens, still or video cameras, and/or microphones. In an embodiment, user input devices may be omitted and computer system 2000 may present a user interface to a user over a network, for example using a web page or network management protocol and network management software applications.
Computer system 2000 includes one or more network interfaces 2025 that allow computer system 2000 to communicate with other computer systems via an electronic communications network, and may include wired or wireless communication over local area networks and wide area networks such as the Internet. Computer system 2000 may support a variety of networking protocols at one or more levels of abstraction. For example, computer system may support networking protocols at one or more layers of the seven layer OSI network model. An embodiment of network interface 2025 includes one or more wireless network interfaces adapted to communicate with wireless clients and with other wireless networking devices using radio waves, for example using the 802.11 family of protocols, such as 802.11a, 802.11b, 802.11 g, and 802.11n.
An embodiment of the computer system 2000 may also include one or more wired networking interfaces, such as one or more Ethernet connections to communicate with other networking devices via local or wide-area networks.
The components of computer system 2000, including CPU 2005, memory 2010, data storage 2015, user input devices 2020, and network interface 2025 are connected via one or more data buses 2060. Additionally, some or all of the components of computer system 2000, including CPU 2005, memory 2010, data storage 2015, user input devices 2020, and network interface 2025 may be integrated together into one or more integrated circuits or integrated circuit packages. Furthermore, some or all of the components of computer system 2000 may be implemented as application specific integrated circuits (ASICS) and/or programmable logic.
Further embodiments can be envisioned to one of ordinary skill in the art. In other embodiments, combinations or sub-combinations of the above disclosed invention can be advantageously made. The block diagrams of the architecture and flow charts are grouped for ease of understanding. However it should be understood that combinations of blocks, additions of new blocks, re-arrangement of blocks, and the like are contemplated in alternative embodiments of the present invention.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereunto without departing from the broader spirit and scope of the invention as set forth in the claims.
Claims
1. A method comprising:
- receiving a plurality of incremental backups from a client of a backup system in response to initiation of backup;
- maintaining, by the backup system, backup information comprising backup times and dependency relationships among the plurality of incremental backups;
- generating, for each of the plurality of incremental backups, a plurality of identifiers for locating data of an incremental backup;
- transmitting the plurality of incremental backups and the plurality of identifiers to a cloud data storage;
- in response to a request to generate in the cloud data storage a synthetic backup corresponding to a restore time, identifying, by the backup system, a set of the plurality of incremental backups to be included in the synthetic backup based, at least in part, on the backup information, wherein identifying, by the backup system, the set of incremental backups to be included in the synthetic backup based, at least in part, on the backup information comprises: analyzing the backup times to identify one or more of the plurality of incremental backups that occurred on or prior to the restore time; analyzing the dependency relationships to identify those of the plurality of incremental backups on which the one or more of the plurality of incremental backups depend; and indicating in the set of incremental backups the one or more of the plurality of incremental backups and those of the plurality of incremental backups on which the one or more of the plurality of incremental backups depend; creating, by the backup system, a representation of the synthetic backup comprising a set of identifiers, wherein creating the representation of the synthetic backup comprises determining from the plurality of identifiers for each of the set of incremental backups the set of identifiers that correspond to data to be included in the synthetic backup; and transmitting the representation of the synthetic backup to the cloud data storage for generation of the synthetic backup.
2. The method of claim 1 further comprising:
- deduplicating a first of the plurality of incremental backups; and
- associating a first of the plurality of identifiers with at least a first deduplicated portion and a second deduplicated portion of the deduplicated first incremental backup;
- wherein transmitting the plurality of incremental backups and the plurality of identifiers comprises transmitting the deduplicated first incremental backup and the first identifier for the first incremental backup to the cloud data storage.
3. The method of claim 1, wherein generating, for each of the plurality of incremental backups, the plurality of identifiers for locating data of an incremental backup comprises:
- for each of the plurality of incremental backups, dividing data of the incremental backups into a plurality of data segments; and associating the plurality of identifiers with the plurality of data segments, wherein each of the plurality of identifiers is unique.
4. The method of claim 3, wherein determining from the plurality of identifiers for each of the set of incremental backups the set of identifiers that correspond to data to be included in the synthetic backup comprises:
- determining that only a portion of a data segment associated with a first of the plurality of identifiers for a first of the plurality of incremental backups is to be included in the synthetic backup; and
- in response to determining that only the portion of the data segment associated with the first identifier is to be included in the synthetic backup, determining a first offset and a second offset for the portion of the data segment, wherein the first offset indicates a beginning of the portion and the second offset indicates an end of the portion within the data segment; and modifying in the representation of the synthetic backup the first identifier to indicate the first offset and the second offset for the data segment.
5. The method of claim 1 further comprising after transmitting the representation of the synthetic backup, supplying, by the backup system to the client, a plurality of shell files associated with data of the synthetic backup in the cloud data storage.
6. The method of claim 5 further comprising:
- receiving, from the client, an indication of a first of the plurality of shell files;
- determining, by the backup system, a first identifier of the set of identifiers that corresponds to data of the first shell file;
- transmitting the first identifier to the cloud data storage; and
- after transmitting the first identifier to the cloud data storage, supplying the data of the first shell file that corresponds to the first identifier to the client.
7. The method of claim 1, wherein the backup information is maintained locally by the backup system and is not transmitted to the cloud data storage.
8. One or more non-transitory computer readable media having program code stored therein, the program code to:
- receive a plurality of incremental backups from a client of a backup system in response to initiation of backup;
- maintain backup information comprising backup times and dependency relationships among the plurality of incremental backups;
- generate, for each of the plurality of incremental backups, a plurality of identifiers for locating data of an incremental backup;
- transmit the plurality of incremental backups and the plurality of identifiers to a cloud data storage;
- in response to a request to generate in the cloud data storage a synthetic backup corresponding to a restore time, identify a set of the plurality of incremental backups to be included in the synthetic backup based, at least in part, on the backup information, wherein the program code to identify the set of incremental backups to be included in the synthetic backup based, at least in part, on the backup information comprises program code to: analyze the backup times to identify one or more of the plurality of incremental backups that occurred on or prior to the restore time; analyze the dependency relationships to identify those of the plurality of incremental backups on which the one or more of the plurality of incremental backups depend; and indicate in the set of incremental backups the one or more of the plurality of incremental backups and those of the plurality of incremental backups on which the one or more of the plurality of incremental backups depend; create a representation of the synthetic backup comprising a set of identifiers, wherein the program code to create the representation of the synthetic backup comprises program code to determine from the plurality of identifiers for each of the set of incremental backups the set of identifiers that correspond to data to be included in the synthetic backup; and transmit the representation of the synthetic backup to the cloud data storage for generation of the synthetic backup.
9. The non-transitory computer readable media of claim 8 further comprising program code to:
- deduplicate a first of the plurality of incremental backups; and
- associate a first of the plurality of identifiers with at least a first deduplicated portion and a second deduplicated portion of the deduplicated first incremental backup;
- wherein the program code to transmit the plurality of incremental backups and the plurality of identifiers comprises program code to transmit the deduplicated first incremental backup and the first identifier for the first incremental backup to the cloud data storage.
10. The non-transitory computer readable media of claim 8, wherein the program code to generate, for each of the plurality of incremental backups, the plurality of identifiers for locating data of an incremental backup comprises program code to:
- for each of the plurality of incremental backups, divide data of the incremental backups into a plurality of data segments; and associate the plurality of identifiers with the plurality of data segments, wherein each of the plurality of identifiers is unique.
11. The non-transitory computer readable media of claim 10, wherein the program code to determine from the plurality of identifiers for each of the set of incremental backups the set of identifiers that correspond to data to be included in the synthetic backup comprises program code to:
- determine whether only a portion of a data segment associated with a first of the plurality of identifiers for a first of the plurality of incremental backups is to be included in the synthetic backup; and
- in response to a determination that only the portion of the data segment associated with the first identifier is to be included in the synthetic backup, determine a first offset and a second offset for the portion of the data segment, wherein the first offset indicates a beginning of the portion and the second offset indicates an end of the portion within the data segment; and modify in the representation of the synthetic backup the first identifier to indicate the first offset and the second offset for the data segment.
12. The non-transitory computer readable media of claim 8 further comprising program code to, after transmitting the representation of the synthetic backup, supply to the client a plurality of shell files associated with data of the synthetic backup in the cloud data storage.
13. The non-transitory computer readable media of claim 12 further comprising program code to:
- receive, from the client, an indication of a first of the plurality of shell files;
- determine a first identifier of the set of identifiers that corresponds to data of the first shell file;
- transmit the first identifier to the cloud data storage; and
- after transmitting the first identifier to the cloud data storage, supply the data of the first shell file that corresponds to the first identifier to the client.
14. An apparatus comprising:
- a processor; and
- a machine-readable medium having program code executable by the processor to cause the apparatus to, receive a plurality of incremental backups from a client of the apparatus in response to initiation of backup; maintain backup information comprising backup times and dependency relationships among the plurality of incremental backups; generate, for each of the plurality of incremental backups, a plurality of identifiers for locating data of an incremental backup; transmit the plurality of incremental backups and the plurality of identifiers to a cloud data storage; in response to a request to generate in the cloud data storage a synthetic backup corresponding to a restore time, identify a set of the plurality of incremental backups to be included in the synthetic backup based, at least in part, on the backup information, wherein the program code executable by the processor to cause the apparatus to identify the set of incremental backups to be included in the synthetic backup based, at least in part, on the backup information comprises program code executable by the processor to cause the apparatus to: analyze the backup times to identify one or more of the plurality of incremental backups that occurred on or prior to the restore time; analyze the dependency relationships to identify those of the plurality of incremental backups on which the one or more of the plurality of incremental backups depend; and indicate in the set of incremental backups the one or more of the plurality of incremental backups and those of the plurality of incremental backups on which the one or more of the plurality of incremental backups depend; create a representation of the synthetic backup comprising a set of identifiers, wherein the program code executable by the processor to cause the apparatus to create the representation of the synthetic backup comprises program code executable by the processor to cause the apparatus to determine from the plurality of identifiers for each of the set of incremental backups the set of identifiers that correspond to data to be included in the synthetic backup; and transmit the representation of the synthetic backup to the cloud data storage for generation of the synthetic backup.
15. The apparatus of claim 14 further comprising program code executable by the processor to cause the apparatus to:
- deduplicate a first of the plurality of incremental backups; and
- associate a first of the plurality of identifiers with at least a first deduplicated portion and a second deduplicated portion of the deduplicated first incremental backup;
- wherein the program code executable by the processor to cause the apparatus to transmit the plurality of incremental backups and the plurality of identifiers comprises program code executable by the processor to cause the apparatus to transmit the deduplicated first incremental backup and the first identifier for the first incremental backup to the cloud data storage.
16. The apparatus of claim 14, wherein the program code executable by the processor to cause the apparatus to generate, for each of the plurality of incremental backups, the plurality of identifiers for locating data of an incremental backup comprises program code executable by the processor to cause the apparatus to:
- for each of the plurality of incremental backups, divide data of the incremental backups into a plurality of data segments; and associate the plurality of identifiers with the plurality of data segments, wherein each of the plurality of identifiers is unique.
17. The apparatus of claim 16, wherein the program code executable by the processor to cause the apparatus to determine from the plurality of identifiers for each of the set of incremental backups the set of identifiers that correspond to data to be included in the synthetic backup comprises program code executable by the processor to cause the apparatus to:
- determine whether only a portion of a data segment associated with a first of the plurality of identifiers for a first of the plurality of incremental backups is to be included in the synthetic backup; and
- in response to a determination that only the portion of the data segment associated with the first identifier is to be included in the synthetic backup, determine a first offset and a second offset for the portion of the data segment, wherein the first offset indicates a beginning of the portion and the second offset indicates an end of the portion within the data segment; and modify in the representation of the synthetic backup the first identifier to indicate the first offset and the second offset for the data segment.
18. The apparatus of claim 14 further comprising program code executable by the processor to cause the apparatus to, after transmitting the representation of the synthetic backup, supply to the client a plurality of shell files associated with data of the synthetic backup in the cloud data storage.
19. The apparatus of claim 18 further comprising program code executable by the processor to cause the apparatus to:
- receive, from the client, an indication of a first of the plurality of shell files;
- determine a first identifier of the set of identifiers that corresponds to data of the first shell file;
- transmit the first identifier to the cloud data storage; and
- after transmitting the first identifier to the cloud data storage, supply the data of the first shell file that corresponds to the first identifier to the client.
20. The apparatus of claim 14, wherein the backup information is maintained locally by the apparatus and is not transmitted to the cloud data storage.
6161109 | December 12, 2000 | Matamoros |
7529785 | May 5, 2009 | Spertus et al. |
7979404 | July 12, 2011 | Sim-Tang |
20030158831 | August 21, 2003 | Zaremba |
20030191918 | October 9, 2003 | Flaherty et al. |
20050172092 | August 4, 2005 | Lam |
20050240813 | October 27, 2005 | Okada et al. |
20060036658 | February 16, 2006 | Henrickson |
20090164527 | June 25, 2009 | Spektor et al. |
20100257403 | October 7, 2010 | Virk et al. |
20100274765 | October 28, 2010 | Murphy et al. |
20100274983 | October 28, 2010 | Murphy et al. |
20110106768 | May 5, 2011 | Khanzode et al. |
Type: Grant
Filed: Sep 30, 2010
Date of Patent: Nov 22, 2016
Patent Publication Number: 20120084261
Assignee: NetApp, Inc. (Sunnyvale, CA)
Inventor: Nitin Parab (Menlo Park, CA)
Primary Examiner: Kannan Shanmugasundaram
Application Number: 12/895,835
International Classification: G06F 7/00 (20060101); G06F 17/30 (20060101); G06F 11/14 (20060101); G06F 17/00 (20060101);