A network storage server is a processing system that is used to store and retrieve data on behalf of one or more hosts (clients) on a network. A storage server operates on behalf of one or more hosts to store and manage data in a set of mass storage devices, such as magnetic or optical storage-based disks or tapes. Some storage servers are designed to service file-level requests from hosts, as is commonly the case with file servers used in a network attached storage (NAS) environment. Other storage servers are designed to service block-level requests from hosts, as with storage servers used in a storage area network (SAN) environment. Still other storage servers are capable of servicing both file-level requests and block-level requests, as is the case with certain storage servers made by NetApp, Inc. of Sunnyvale, Calif.
One common use of storage servers is data replication. Data replication is a technique for backing up data in which a given data set at a source is replicated at a destination that is often geographically remote from the source. The replica data set created at the destination is called a “mirror” of the original data set. Typically replication involves the use of at least two storage servers, e.g., one at the source and another at the destination, which communicate with each other through a computer network or other type of data interconnect.
Each data block in a given unit of data, such as a file in a storage server, can be represented by both a physical block, pointed to by a corresponding physical block pointer, and a logical block pointed to by a corresponding logical block pointer. These two blocks are actually the same data block. However, the physical block pointer indicates the actual physical location of the data block on a storage medium, whereas the logical block pointer indicates the logical position of the data block within the data unit (e.g., a file) relative to other data blocks.
In some replication systems, replication is done at a logical block level. In these systems, the replica at the destination storage server has the identical structure of logical block pointers as the original data set at the source storage server, but may (and typically does) have a different structure of physical block pointers than the original data set at the source storage server. To execute a logical replication, the file system of the source storage server is analyzed to determine changes that have occurred to the file system. The changes are transferred to the destination storage server. This typically includes “walking” the directory trees at the source storage server to determine the changes to various file system objects within each directory tree, as well as identifying the changed file system object's location within the directory tree structure.
A goal of many replication systems is that the replication should be transparent to clients. If a failure occurs in the source storage server, file handles that point to file system objects on the source storage server should be usable to access the corresponding file system object on the destination storage server. By preserving file handles, the replication enables clients to transition easily from the source storage server to the destination storage server.
A further goal is interoperability. In many storage networks, storage server software may be upgraded at different times based on the needs of the network. Thus, replication systems should be able to execute even if the source and destination storage servers use different versions of a storage operating system. At the same time, replication systems should be designed to operate efficiently and without unnecessary extra complexity in achieving these other goals.
The present disclosure relates to a system and method for maintaining multiple inode containers in a network storage server. The system uses the multiple inode containers in a single logical volume to store inodes for different types of file system objects. In one embodiment, the system stores inodes for private file system objects (i.e., file system objects used to manage the operation of the storage server) in a first inode container and stores public file system objects (i.e., file system objects that are available to clients of the storage server) in a second inode container. During a replication process, the replication system replicates only file system objects with inodes stored in the public inode container. When the destination storage server receives the replication information, it generates new inodes based on the information and stores the inodes in the public inode container. The new inodes are stored with the same inode numbers as the corresponding inodes on the source storage server.
An advantage of the system is that it allows the storage server to maintain a separation between file system objects that are visible to users and file system objects that are only for internal use by the storage server. By separating the types of files, the system ensures that replicated inodes are able to have the same inode numbers as the corresponding inodes on the source storage server without the risk that the inode numbers will conflict with private inodes that already existed on the destination storage server.
The system has advantages in simplicity over alternate solutions. For example, the system is less complex than a system that maintains a translation table to map the source inode number to a corresponding destination inode. Maintaining multiple inode containers also adds flexibility for future versions of the file system, because it provides additional inodes for private use for any additional private file system objects that are added. In addition, the private inode container can be expanded to accommodate new private inodes without reducing the number of inodes available for public file system objects.
A system and method for maintaining multiple inode containers in a single logical volume of a network storage server is disclosed (hereinafter referred to as “the multiple inode container system” or “the system”). Storage servers maintain a set of inodes for file system objects that store metadata used to manage the operations of the storage server. An “inode” is a metadata container that is used to store metadata about the file, such as ownership, access permissions, file size, file type, and pointers to the highest-level of indirect blocks for the file. A “file system” is an independently managed, self-contained, organized structure of data units (e.g., files, blocks, or logical unit numbers (LUNs)). These inodes are specific to the storage server and are generally hidden from clients of the storage server. During a replication process, problems can occur when these inodes have inode numbers that are identical to inode numbers of inodes from a source storage server. To solve this, the system provides multiple inode containers to store metadata for file system objects in the logical volume. In one embodiment, the system introduced here uses a first inode container to store private inodes used by the storage server. The system then uses a second inode container to store public inodes that are usable by clients of the storage server. The storage server uses a special metadata block called a VolumeInfo block stored in a predefined location to store volume information, such as the name and size of the volume. In one embodiment, the VolumeInfo block stores references pointing to each of the first and second inode containers. In another embodiment, the VolumeInfo block stores a reference to the first inode container and the first inode container stores an inode that references the second inode container.
During a replication process, the source storage server generates a set of replication operations to replicate the source storage server. In general, inodes in the private inode container are considered to be for the source storage server only and are not replicated to the destination storage server. Thus, if the source storage server implements the multiple inode container system, it generates the replication operations based on the inodes in the public inode container and excludes inodes in the private inode container. The replication operations are then transferred to a destination storage server. If the destination storage server implements the multiple inode container system, it generates inodes based on the replication operations and stores the inodes in the public inode container. These new inodes are stored in the public inode container with the same inode number or identifier as the corresponding inode on the source storage server.
In one embodiment, source storage server 2A includes a storage operating system 7A, storage manager 123A, snapshot differential module 122, and replication engine 8A. Each of storage operating system 7A, storage manager 123A, snapshot differential module 122, and replication engine 8A are computer hardware components of the storage server, which can be implemented as special purpose hardware circuitry (e.g., “hardwired”), programmable hardware circuitry that is programmed with software and/or firmware, or any combination thereof. Storage of data in the source storage subsystem 4A is managed by storage manager 123A of source storage server 2A. Source storage server 2A and source storage subsystem 4A are collectively referred to as a source storage server. The storage manager 123A receives and responds to various read and write requests from the hosts 1, directed to data stored in or to be stored in storage subsystem 4A. Storage subsystem 4A includes a number of nonvolatile mass storage devices 5, which can be, for example, magnetic disks, optical disks, tape drives, solid-state memory, such as flash memory, or any combination of such devices. The mass storage devices 5 in storage subsystem 4A can be organized as a RAID group, in which case the storage controller 2 can access the storage subsystem 4 using a conventional RAID algorithm for redundancy.
Storage manager 123A processes write requests from hosts 1 and stores data to unused storage locations in mass storage devices 5 of the storage subsystem 4A. In one embodiment, the storage manager 123A implements a “write anywhere” file system such as the proprietary Write Anywhere File Layout (WAFL™) file system developed by NetApp, Inc. Such a file system is not constrained to write any particular data or metadata to any particular storage location or region. Rather, such a file system can write to any unallocated block on any available mass storage device and does not overwrite data on the devices. If a data block on disk is updated or modified with new data, the data block is thereafter stored (written) to a new location on disk instead of modifying the block in place to optimize write performance.
The storage manager 123A of source storage server 2A is responsible for managing storage of data in the source storage subsystem 4A, servicing requests from hosts 1, and performing various other types of storage related operations. In one embodiment, the storage manager 123A, the source replication engine 8A and the snapshot differential module 122 are logically on top of the storage operating system 7A. In other embodiments, the components may be logically separate from the storage operating system 7A and may interact with the storage operating system 7A on a peer-to-peer basis. The source replication engine 8A operates in cooperation with a remote destination replication engine 8B, described below, to perform logical replication of data stored in the source storage subsystem 4A. Note that in other embodiments, one or more of the storage manager 123A, replication engine 8A and the snapshot differential module 122 may be implemented as elements within the storage operating system 7A.
The source storage server 2A is connected to a destination storage server 2B through an interconnect 6, for purposes of replicating data. Although illustrated as a direct connection, the interconnect 6 may include one or more intervening devices and/or may include one or more networks. In the illustrated embodiment, the destination storage server 2B includes a storage operating system 7B, replication engine 8B and a storage manager 123B. The storage manager 123B controls storage related operations on the destination storage server 2B. In one embodiment, the storage manager 123B and the destination replication engine 8B are logically on top of the storage operating system 7B. In other embodiments, the storage manager 123B and the destination replication engine 8B may be implemented as elements within storage operating system 7B. The destination storage server 2B and the destination storage subsystem 4B are collectively referred to as the destination storage server.
The destination replication engine 8B works in cooperation with the source replication engine 8A to replicate data from the source storage server to the destination storage server. In certain embodiments, the storage operating systems 7A and 7B, replication engines 8A and 8B, storage managers 123A and 123B, and snapshot differential module 122 are all implemented in the form of software. In other embodiments, however, any one or more of these elements may be implemented in hardware alone (e.g., specially-designed dedicated circuitry), firmware, or any combination of hardware, software and firmware.
Storage servers 2A and 2B each may be, for example, a storage server which provides file-level data access services to hosts 1, such as commonly done in a NAS environment, or block-level data access services such as commonly done in a SAN environment, or they may be capable of providing both file-level and block-level data access services to hosts 1. Further, although the storage servers 2 are illustrated as monolithic systems in
The processor(s) 122 is/are the central processing unit(s) (CPU) of the storage servers 2 and, therefore, control the overall operation of the storage servers 2. In certain embodiments, the processor(s) 122 accomplish this by executing software or firmware stored in memory 124. The processor(s) 122 may be, or may include, one or more programmable general-purpose or special-purpose microprocessors, digital signal processors (DSPs), programmable controllers, application specific integrated circuits (ASICs), programmable logic devices (PLDs), trusted platform modules (TPMs), or the like, or a combination of such devices. The memory 124 is or includes the main memory of the storage servers 2.
The memory 124 represents any form of random access memory (RAM), read-only memory (ROM), flash memory, or the like, or any combination of such devices. Also connected to the processor(s) 122 through the interconnect bus 125 is a network adapter 126 and a storage adapter 128. The network adapter 126 provides the storage servers 2 with the ability to communicate with remote devices, such as hosts 1, over the interconnect 3 of
It is useful now to consider how data can be structured and organized by storage servers 2A and 2B in certain embodiments. Reference is now made to
In certain embodiments, each aggregate uses a physical volume block number (PVBN) space that defines the physical storage space of blocks provided by the storage devices of the physical volume, and likewise, each volume uses a virtual volume block number (WBN) space to organize those blocks into one or more higher-level objects, such as directories, subdirectories, and files. A PVBN, therefore, is an address of a physical block in the aggregate and a WBN is an address of a block in a volume (the same block as referenced by the corresponding PVBN), i.e., the offset of the block within the volume. The storage manager 300 tracks information for all of the VVBNs and PVBNs in each storage server 2. Each WBN space is an independent set of values that corresponds to locations within a directory or file, which are translated to device block numbers (DBNs) on the physical storage device. The storage manager 300 may manage multiple volumes on a common set of physical storage in the aggregate.
In addition, data within the storage server is managed at a logical block level. At the logical block level, the storage manager maintains a logical block number (LBN) for each data block. If the storage server stores data in the form of files, the LBNs are called file block numbers (FBNs). Each FBN indicates the logical position of the block within a file, relative to other blocks in the file, i.e., the offset of the block within the file. For example, FBN 0 represents the first logical block in a particular file, while FBN 1 represents the second logical block in the file, and so forth. Note that the PVBN and VVBN of a data block are independent of the FBN(s) that refer to that block. In one embodiment, the FBN of a block of data at the logical block level is assigned to a PVBN-WBN pair.
In certain embodiments, each file is represented in the storage server in the form of a hierarchical structure called a “buffer tree.” As used herein, the term buffer tree is defined as a hierarchical metadata structure containing references (or pointers) to logic blocks of data in the file system. A buffer tree is a hierarchical structure which used to store file data as well as metadata about a file, including pointers for use in locating the data blocks for the file. A buffer tree includes one or more levels of indirect blocks (called “L1 blocks”, “L2 blocks”, etc.), each of which contains one or more pointers to lower-level indirect blocks and/or to the direct blocks (called “L0 blocks”) of the file. All of the data in the file is stored only at the lowest level (L0) blocks. The root of a buffer tree is stored in the “inode” of the file. As noted above, an inode is a metadata container that is used to store metadata about the file, such as ownership, access permissions, file size, file type, and pointers to the highest-level of indirect blocks for the file. Each file has its own inode. The inode is stored in a separate inode container, which may itself be structured as a buffer tree. The inode container may be, for example, an inode file. In hierarchical (or nested) directory file systems, this essentially results in buffer trees within buffer trees, where subdirectories are nested within higher-level directories and entries of the directories point to files, which also have their own buffer trees of indirect and direct blocks. Directory entries include the name of a file in the file system, and directories are said to point to (reference) that file. Alternatively, a directory entry can point to another directory in the file system. In such a case, the directory with the entry is said to be the “parent directory,” while the directory that is referenced by the directory entry is said to be the “child directory” or “subdirectory.”
File system objects can be, for example, files, directories, sub-directories, and/or LUNs of the file system. File system object inodes are arranged sequentially in the inode container, and a file system object's position in the inode container is given by its inode number or inode identifier. For directory entries, each entry includes the names of the files the directory entry references and the files' inode numbers. In addition, a directory has its own inode and inode number. An inode includes a master location catalog for the file, directory, or other file system object and various bits of information about the file system object called metadata. The metadata includes, for example, the file system object's creation date, security information such as the file system object's owner and/or protection levels, and its size. The metadata also includes a “type” designation to identify whether the file system object is one of the following types: 1) a “file;” 2) a “directory;” or 3) “unused.”
The metadata also includes the “generation number” of the file system object. As time goes by, file system objects are created or deleted, and slots in the inode file are recycled. When a file system object is created, its inode is given a new generation number, which is guaranteed to be different from (e.g., larger than) the previous file system object at that inode number (if any). If repeated accesses are made to the file system object by its inode number (e.g., from clients, applications, etc.), the generation number can be checked to avoid inadvertently accessing a different file system object after the original file system object was deleted. The metadata also includes “parent information,” which is the inode number of the file system object's parent directory. A file system object can have multiple parent directories.
Storage servers maintain a set of inodes for file system objects that store metadata used to manage the operations of the storage server. These inodes are referred to as “private” inodes because they refer to file system objects that are generally not visible to clients of the storage server (in contrast to “public” inodes that are visible to clients). These objects store metadata for controlling aspects of the physical device and the logical volume, such as tracking which data blocks in a volume or aggregate are available for use. Much of the metadata relates only to the private state of the particular device. The inodes for these objects are often generated when the storage server first starts, but may also be generated in response to a system reconfiguration (e.g., activating a new feature such as encryption). These file system objects may also include application metadata (i.e., hidden metafiles created by the storage server on behalf of an application).
For various reasons, it may be desirable to maintain a replica of a data set in the source storage server. For example, in the event of a power failure or other type of failure, data lost at the source storage server can be recovered from the replica stored in the destination storage server. In at least one embodiment, the data set is a file system of the storage server and replication is performed using snapshots. A “snapshot” is a persistent image (usually read-only) of the file system at a point in time and can be generated by the source snapshot differential module 122. At a point in time, the differential source module 122 generates a first snapshot of the file system of the source storage server, referred to as the baseline snapshot. This baseline snapshot is then provided to the source replication engine 8A for replication operations. Subsequently, the source differential module 122 generates additional snapshots of the file system from time to time.
At some later time, the source replication engine 8A executes another replication operation (which may be at the request of the destination replication engine 8B). To do so, the source replication engine 8A needs to be updated with the changes to the file system of the source storage server since a previous replication operation was performed. The snapshot differential module 122 compares the most recent snapshot of the file system of the source storage server to the snapshot of a previous replication operation to determine differences between a recent snapshot and the previous snapshot. The snapshot differential module 122 identifies any data that has been added or modified since the previous snapshot operation, and sends those additions or modifications to the source replication engine 8A for replication. The source replication engine 8A then generates change messages for each of the additions or modifications. The change messages include information defining a file system operation that will be executed on the destination storage server 2B to replicate the changes to the source system following the previous replication. The change messages are then transmitted to the destination replication engine 8B for execution on the destination storage server 2B.
A replication operation transfers information about a set of file system operations from a source file system to the replica destination file system. In one embodiment, a file system operation includes data operations, directory operations, and inode operations. A “data operation” transfers 1) a block of file data, 2) the inode number of the block of data, 3) the generation number of the file, and 4) the position of the block within the file (e.g., FBN). A “directory operation” transfers 1) the inode number of the directory, 2) the generation number of the directory, and 3) enough information to reconstitute an entry in that directory including: 1) the name; 2) inode number; and 3) generation number of the file system object the directory entry points to. Finally, an “inode operation” transfers 1) the meta-data of an inode and 2) its inode number. To perform a replication of an entire file system, the source storage server sends a sequence of data operations, directory operations, and inode operations to the destination, which is expected to process the operations and send acknowledgments to the source. As used herein, the inode number (or numbers) in each file system operation is referred to as the “target inode number”.
A replication of a file system may be either an “initialization”, in which the destination file system starts from scratch with no files or directories, or it may be an “update”, in which the destination file system already has some files and directories from an earlier replication operation of an earlier version of the source. In an update, the source file system does not need to send every file and directory to the destination; rather, it sends only the changes that have taken place since the earlier version was replicated. Inode operations have various types, including delete (where the file system object associated with the inode number is deleted), create (where a new file system object is created at the target inode number), and modify (where the contents or metadata of the file system object are modified).
During the replication process, the destination storage server executes each of the replication operations. In some systems, the destination storage server generates each new inode to have an inode number identical to the inode number of the corresponding inode on the source storage server. Maintaining the same inode number allows clients of the destination storage server to use file handles that were used for files on the source storage server to interact with the corresponding inodes on the destination storage server. This is more efficient than invalidating the file handles or requiring the destination storage server to maintain a mapping from the original file handle to the corresponding inode.
However, a problem occurs when the destination storage server receives a replication operation directing it to create an inode with an inode number that is already used by a private inode. This can occur because many of the private inodes are generated on the destination storage server before the replication process is initiated. One possible solution to this problem is for the destination storage server to relocate a conflicting private inode to a new inode number in response to the conflict. However, this imposes additional processing for the replication process. In addition, the private inode might need to be relocated again if the new inode number conflicts with another replication operation. Alternatively, the destination storage server could define a specific range of inode numbers that are specifically for storing private inodes. However, this solution is not scalable, because the number of private inodes that can be created by the system are limited by the size of the range.
To avoid these problems, the system provides multiple inode containers to store the different types of inodes. These inode containers could be implemented as, for example, a set of files stored in a file system of a logical volume. In one embodiment, the system uses two inode containers to store the data: a first inode container that stores the private inodes (the “private inode container”) and a second inode container that stores public inodes (the “public inode container”). In this embodiment, file system objects referenced by inodes in the private inode container are hidden from clients of the storage server, while file system objects referenced by inodes in the public inode container are generally visible to clients. In some embodiments, inodes are automatically assigned to a particular inode container based on various factors, such as the entity that created the inode (e.g., the operating system or a client) or the type of file system object represented by the inode (e.g., by assigning metafiles to the private inode container). In other implementations, the assignment is determined in advance by a designer specifying that particular inodes should be placed in the private inode container. In another embodiment, the system provides more than two inode containers. For example, the storage server can be configured to support multiple inode sizes in order to optimize space consumption. The system could then use multiple inode containers to store inodes based on the size of the structure.
An advantage of the configuration shown in
As shown in
Similarly, the system 700 includes a storage interface 706, which is configured to interact with one or more storage components in a storage subsystem. These may be, for example, the storage devices 5 in the storage subsystem 4 shown in
The public inode container stores a root inode, which represents the highest level of a hierarchical file system. In some embodiments, the root inode is a root directory that represents the highest level of a directory-based file system hierarchy. In some systems, the root inode is stored at an inode number that is predefined by the storage operating system. However, in some cases, the system 700 may be used to replicate data from a storage server that uses a different operating system from the operating system of the destination storage server (e.g., the source storage server uses the Linux operating system while the destination storage server uses the WAFL file system). In these cases, the source storage server may store the root inode at a different location than the destination storage server's predefined location. To handle this, the system 700 communicates with the source storage server to determine a new location for the root inode. The system then stores the location of the root inode in a known data structure, such as the VolumeInfo block 714. The root inode is visible to clients and is stored in the public inode container.
The system 700 also includes a processing component 704, which is configured to manage access to the inode containers 716 and 718 and to manage the replication process using the multiple inode containers. The processing component 704 could be implemented, for example, by the processor 122 of
The processing component 704 includes a volume interface component 708, which is configured to manage interaction with a logical volume on a storage server. The volume interface component 708 encapsulates the functionality required to enable access to the inodes on the logical volume and therefore logically includes a broad set of components of the storage operating system 7, including the storage manager 300. In particular, the volume interface component 708 accesses the information in the VolumeInfo block 714 and the inode containers 716 and 718 to determine the locations of file system objects in response to client requests or storage management requirements.
The processing component 704 also includes a source replication component 710, which is configured to generate a set of replication operations from the storage server. The source replication component 710 executes when the storage server is acting as a source storage server 2A. As discussed above, in a storage server with two inode containers, the system 700 may use the first inode container 716 as a private inode container and the second inode container 718 as a public inode container. In this embodiment, the source replication component 710 generates a set of replication operations to mirror the inodes in the public inode container (i.e., second inode container 718) but not the inodes in the private inode container 716. This is practical because the inodes in the private inode container are only necessary for internal use by the source storage server. The set of replication operations can be provided to the destination storage server regardless of whether the destination supports a single inode container or multiple inode containers.
Similarly, the processing component 704 includes a destination replication component 712, which is configured to execute a set of replication operations received from a source storage server. In a system with a private inode container and a public inode container, the destination replication component 712 stores all new inodes in the public inode container, because the private inode container is reserved for internal use on the destination system. Thus, the destination replication component 712 can generate new inodes for storage in the public inode container 718 without having to determine whether the new inodes have the same inode numbers as the storage server's private inodes.
Processing then proceeds to step 804, where the system creates a private inode container for the logical volume. After creating the private inode container, the system stores the private inode container in the logical volume and stores a reference to the private inode container in the VolumeInfo block. The system then executes similar steps in step 806 to create the public inode container in step 806. As discussed above, after storing the public inode container on the logical volume, the system stores a reference to the public inode container in the VolumeInfo block or in the private inode container, depending on which of the methods disclosed in
The system then proceeds to step 808, where it generates private inodes for the storage server. As discussed above, these inodes are generally created at the time that the volume is created, although additional private inodes may be created during later operation. The system then stores the private inodes in the private inode container. In some embodiments, the private inodes are assigned inode numbers according to a predetermined mapping. An advantage of this is that the storage server does not have to maintain a lookup data structure to track the locations of these private inodes. In other embodiments, the private inodes are assigned inode numbers in an arbitrary order as each new inode is created.
The system then proceeds to step 810, where it creates the root inode for the file system on the logical volume. As discussed above, the root inode is a container inode (e.g., a directory inode) that serves as the highest level of the file system hierarchy on the logical volume. The root inode can be stored in the public inode container at a predetermined inode number. In one embodiment, the inode number for the root inode is determined at design time and is the same for all storage servers implementing a particular version of the storage operating system. In another implementation, the root inode is initially stored at the predetermined location, but the location may be modified when a mirroring relationship is established. In particular, if the source storage server uses a different operating system from the destination storage device, establishing the mirroring relationship may include negotiating between the source storage server and the destination storage server to establish a location for the root inode. A reference to the new location may be stored in the VolumeInfo block.
Processing begins at step 902, where the source replication component 710 catalogs public inodes on the storage server. If the source storage server implements the multiple inode container system, this step can be executed by determining a list of all inodes stored in the public inode container. In a single inode container system, the step 902 includes determining a subset of inodes to be replicated based on all of the inodes in the single inode container. Note that although the discussion of
After cataloging the public inodes, processing proceeds to step 904, where the source replication engine 8A (
At step 908, the destination replication engine 8B receives the generated replication operations. Processing then proceeds to step 910, where the destination replication component 712 creates new inodes (or otherwise modifies the destination storage server 2B) based on the received replication operations. If the destination storage server 2B does not implement the multiple inode container system, the storage server generates new inodes according to current technology. If the destination storage server 2B implements the multiple inode container system, the system generates new inodes based on the replication operations and stores the inodes in the public inode container on the destination storage server.
A similar process may be used to upgrade the operating system of a storage server to a software version that supports multiple inode containers. During upgrade, the system catalogs each inode from the initial system to determine whether the inode should be placed in the public inode container or the private inode container. In one embodiment, the system determines a first set of inodes that are to be placed in the private inode container (i.e., inodes of file system objects used for system management) and assigns the remaining inodes to the public inode container. During the upgrade, the system creates the public and private inode containers and relocates each set of inodes to the corresponding inode container. The public inodes can be assigned the same inode number as they had in the initial system, while the private inodes can be assigned inode numbers using any desired method, such as a pre-determined mapping. If the operating system is later reverted to the prior operating system version (i.e., a single inode container system), the system simply relocates inodes from the public inode container to the same inode number in the single inode container. The system then relocates inodes from the private inode container to the single inode container by storing the inodes in locations not used by the public inodes.
From the above, it will be appreciated that specific embodiments of the invention have been described herein for purposes of illustration, but that various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.