A file system may be used to organize data on a storage device. A file system is generally an integral part of an operating system or may be installed separately as an extension of the operating system. It provides the underlying structure that a computing device uses to organize data on a storage medium.
The following detailed description references the drawings, wherein
A file system may be used to control how data is stored and retrieved from a storage system. In an example, a computer file or “file” is the basic component of a file system. A file may contain data, such as text files, image files, video files, and the like, or it may be an executable file or program.
In an object-based file system, data (for example, a file) may be stored as a single object along with metadata, and is assigned an object ID. When the data is desired, the object ID may be presented to the system, which then fetches the data along with the metadata.
Adoption of technology by businesses has led to an explosion of data, which has resulted into a file system that may contain billions of objects, and each object may be associated with metadata. If an application (for example, a software update tool, a backup application, etc.) wants to update the metadata of a large number of file objects using standard file system semantics, the number of updates would be same as the number of file objects since the application may have to operate on each object separately. This may be undesirable as it may result in a large number of disk operations. It may be further undesirable, if multiple file objects share the same metadata (for example, an Access Control List (ACL)).
To address these technical challenges, the present disclosure describes various examples for updating metadata of object in a file system. In some examples, in response to an invocation by an application to update metadata related to a plurality of objects of a file system, an Application Programming Interface (API) may initialize a new metadata deduplication database based on an active metadata deduplication database that includes the metadata related to the plurality of objects and a deduplication key linked with the metadata. The deduplication key may map to respective objects IDs of the plurality of objects. New metadata related to the plurality of objects may be added to the new metadata deduplication database 116, and a new deduplication key may be associated with new metadata. Further, a new translation database based on an active translation database may be initialized. The active translation database may include a mapping between the deduplication key linked with the metadata and the respective object IDs of the plurality of objects. The new deduplication key may be associated with the respective object IDs of the plurality of objects in the new translation database. The API may be used to indicate the new metadata deduplication database 116 as default metadata deduplication database, and the new translation database as default translation database.
In an example, the machine-executable instructions may be present on a storage medium. The storage medium may be a primary storage device such as, but not limited to, random access memory (RAM), read only memory (ROM), processor cache, or another type of dynamic storage device that may store information and machine-readable instructions that may be executed by a processor. For example, Synchronous DRAM (SDRAM), Double Data Rate (DDR), Rambus DRAM (RDRAM), Rambus RAM, non-volatile memory (NVM), etc. In some examples, the storage medium may be a secondary storage device such as, but not limited to, a floppy disk, a hard disk, a CD-ROM, a DVD, a pen drive, a flash memory (e.g. USB flash drives or keys), a paper tape, an Iomega Zip drive, and the like. In some examples, the storage medium may include a Direct Attached Storage (DAS) device, a Network Attached Storage (NAS) device, a tape drive, a magnetic tape drive, a data archival storage system, or a combination of these devices.
In some examples, device 100 may include a file system 110. In some examples, file system 110 may be a journaling file system. Some non-limiting examples of a journaling file system may include like NTFS, Ext3, and Ext4.
In an example, file system 110 may represent an object-based file system comprising a plurality of objects. In an object-based file system, data (for example, a file) may be stored as a single object. An object may include data and metadata. An object may be identified via a globally unique identifier (or an “object ID”).
In an example, a plurality of objects in file system 110 may share the same metadata. In such case, the metadata may be de-duplicated. In other words, if more than one file object shares same metadata, only one copy of the metadata may be kept by file system 110. Objects that share the metadata are assigned a pointer to the shared metadata. In an example, the pointer includes a unique deduplication key that is linked to the unique copy of the metadata. Each object that shares the same metadata is associated with the unique deduplication key. In an example, the association may be carried out by mapping the respective object IDs of the objects to the unique deduplication key.
In an example, the mapping between an object ID of an object and an associated deduplication key may be stored in an active translation database 112. In an example, active translation database 112 may be present on device 100. In another example, active translation database 112 may be present on a device communicatively coupled to device 100. As illustrated in
In an example, the mapping between a deduplication key and the associated metadata may be stored in an active metadata deduplication database 114. In an example, active metadata deduplication database 114 may be present on device 100. In another example, active metadata deduplication database 114 may be present on a device communicatively coupled to device 100. As illustrated in
In an example, an application (for example, a software update tool, a backup application, etc.) may want to update metadata shared across a plurality of file objects. In such case, file system may provide access to both active translation database 112 and active metadata deduplication database 114 to the application, for example, through Application Programming Interfaces (APIs).
In an example, in order to update metadata (for example, ACL) related to a plurality of file objects, an application may invoke an API. In response to the invocation, the API may initialize a new metadata deduplication database 116 based on the active metadata deduplication database 114 that includes the metadata related to the plurality of objects and a deduplication key linked with the metadata. The deduplication key may map to respective objects IDs of the plurality of objects. In an example, initializing a new metadata deduplication database 116 may comprise initializing an empty new metadata deduplication database for the metadata to be updated. In an example, new metadata deduplication database 116 may be present on device 100. In another example, new metadata deduplication database 116 may be present on a device communicatively coupled to device 100.
Once the new metadata deduplication database 116 has been initialized, the API may be used to add new metadata related to the plurality of objects to the new metadata deduplication database 116. In an example, adding new metadata to the new metadata deduplication database 116 may comprise opening the active metadata deduplication database 114. Opening the active metadata deduplication database 114 may return a handle, which may be used to read a record (for example, a feature_ID) from the active metadata deduplication database 114 pointed by the handle. In an example, the record may relate to a deduplication key that maps to respective object IDs of the plurality of objects. The deduplication key may be linked to its unique copy of metadata. For example, dedup_key 1 is linked to metadata 120 in active metadata deduplication database 114. The API may be used to write a new record corresponding to the record associated with the deduplication key to add new metadata related to the plurality of objects to the new metadata deduplication database 116.
Once new metadata related to the plurality of objects has been added to the new metadata deduplication database 116, the API may be used to associate a new deduplication key (“dedup_key 11”) with new metadata in the new metadata deduplication database 116. In an example, the new deduplication key may be generated by file system 110. The new deduplication key also maps to the same object IDs of the plurality of objects to which the deduplication key mapped to.
Likewise, for each record in the active metadata deduplication database 114, a new record may be written to add corresponding new metadata to the new metadata deduplication database 116. And, for each new metadata added to the new metadata deduplication database 116, a corresponding new deduplication key may be associated therewith in the new metadata deduplication database 116. For example, in the context of
As mentioned earlier, the mapping between an object ID of an object and an associated deduplication key may be stored in an active translation database 112. In an example, the API may be used to initialize a new translation database 118 based on the active translation database 112. In an example, initializing a new translation database 118 may comprise initializing an empty new translation database for the metadata to be updated. In an example, new translation database 118 may be present on device 100. In another example, new translation database 118 may be present on a device communicatively coupled to device 100.
Once the new translation database 118 has been initialized, the API may be used to add new deduplication keys to the new translation database 118. In an example, adding new deduplication keys to the new translation database 118 may comprise opening the active translation database 112. Opening the active translation database 112 may return a handle, which may be used to read a record from the active translation database 112 pointed by the handle. In an example, the record may relate to an object ID of an object in the active translation database 112. The API may then be used to write a new record corresponding to the record to add the new deduplication key mapped to the object ID, to new translation database 118.
Once a new deduplication key (for example, dedup_key 11) has been added to the new translation database 118, the API may be used to associate the new deduplication key with the object IDs of the plurality of objects in the new translation database 118.
Likewise, for the new second metadata the API may be used to add the new second deduplication key (for example, dedup_key 21) to the new translation database 118. Once the new second deduplication key has been added to the new translation database 118, the API may be used to associate the respective object IDs of the second plurality of objects with the new second deduplication key in the new translation database 118.
Once the new metadata deduplication database 116 and the new translation database 118 have been updated with their respective data, as described earlier, API may be used to indicate the new metadata deduplication database as default metadata deduplication database, and the new translation database as default translation database. The active metadata deduplication database 114 and the active translation database 112 may be deleted.
Machine-readable storage medium 304 may store instructions 306, 308, 310, 312, 314, 316, 318, and 320. In some examples, instructions 306 may be executed by processor 302 to initialize, by an API, in response to an invocation by an application to update metadata related to a plurality of objects of a file system, a new metadata deduplication database based on an active metadata deduplication database that includes the metadata related to the plurality of objects and a deduplication key linked with the metadata. The deduplication key may map to respective objects IDs of the plurality of objects. Instructions 308 may be executed by processor 302 to add, by the API, new metadata related to the plurality of objects to the new metadata deduplication database. Instructions 310 may be executed by processor 302 to associate, by the API, a new deduplication key with the new metadata in the new metadata deduplication database. Instructions 312 may be executed by processor 302 to initialize, by the API, a new translation database based on an active translation database. The active translation database may include a mapping between the deduplication key linked with the metadata and the respective object IDs of the plurality of objects. Instructions 314 may be executed by processor 302 to add, by the API, the new deduplication key to the new translation database. Instructions 316 may be executed by processor 302 to associate, by the API, the respective object IDs of the plurality of objects with the new deduplication key in the new translation database. Instructions 318 may be executed by processor 302 to indicate, by the API, the new metadata deduplication database as default metadata deduplication database, and the new translation database as default translation database. Instructions 320 may be executed by processor 302 to delete, by the API, the active metadata deduplication database, and the active translation database.
For the purpose of simplicity of explanation, the example method of
It should be understood that the above-described examples of the present solution is for the purpose of illustration only. Although the solution has been described in conjunction with a specific embodiment thereof, numerous modifications may be possible without materially departing from the teachings and advantages of the subject matter described herein. Other substitutions, modifications and changes may be made without departing from the spirit of the present solution. All of the features disclosed in this specification (including any accompanying claims, abstract and drawings), and/or all of the steps of any method or process so disclosed, may be combined in any combination, except combinations where at least some of such features and/or steps are mutually exclusive.