This application relates to and claims priority from Japanese Patent Application No. 2008-134939, filed on May 23, 2008, the entire disclosure of which is incorporated herein by reference.
The present invention generally relates to a storage apparatus and its control method, and for instance can be suitably applied to a storage apparatus loaded with an AOU (Allocation On Use) function.
In recent years, a SAN (Storage Area Network) environment that uses a SAN to connect a plurality of storage apparatuses to one or more host computers has been put into practical application. Further, there is technology of managing a plurality of storage apparatuses available to one or more host computers as though they are a single common storage apparatus by virtually consolidating a plurality of storage apparatuses under the SAN environment.
Japanese Patent Laid-Open Publication No. 2005-275526 discloses a storage area allocation method of allocating an appropriate storage area to a host computer in a SAN environment to which a plurality of storage apparatuses are connected based on performance/reliability information and location information assigned to the storage areas provided by the respective storage apparatuses,
Japanese Patent Laid-Open Publication No. 2007-280319 discloses virtualization technology referred to as AOU of presenting a virtual volume (hereinafter referred to as a “virtual volume”) as a volume for reading and writing data from and into a host apparatus, and dynamically allocating a physical storage area for actually storing data to the virtual volume according to the usage status of the virtual volume.
Meanwhile, with conventional AOU technology, if a failure occurs in one of the parity groups in the memory apparatus, data stored in a storage area in that parity group will be lost.
In this case, with conventional AOU technology, since a storage area provided by a plurality of parity groups is allocated to one virtual volume, a failure in a single parity group will induce data loss in a plurality of virtual volumes. In other words, numerous virtual volumes in an “incomplete” status will arise.
The present invention was made in view of the foregoing points. Thus, an object of the present invention is to propose a storage apparatus and its control method capable of improving the maintainability of important data.
In order to achieve the foregoing object, the present invention provides a storage apparatus for presenting a plurality of virtual volumes to a host apparatus, and dynamically allocating to each of the plurality of virtual volumes a physical storage area for storing data according to the usage status of each of the plurality of virtual volumes. This storage apparatus comprises a management unit for managing the importance set to each of the plurality of virtual volumes, and a storage area allocation unit for dynamically allocating a storage area to each of the plurality of virtual volumes. The storage area allocation unit allocates, based on the importance, a storage area provided by a plurality of memory apparatus groups respectively configured from a plurality of memory apparatuses to one or more virtual volumes with low importance among the plurality of virtual volumes, and allocates a storage area provided by one of the memory apparatus groups to other virtual volumes among the plurality of virtual volumes.
Consequently, with the storage apparatus according to the present invention, virtual volumes other than the low importance virtual volumes are not easily affected by the generation of a failure in the memory apparatus group, and it is thereby possible to reduce the probability of loss of data stored in virtual volumes other than the virtual volumes with low importance.
The present invention additionally provides a control method of a storage apparatus for presenting a plurality of virtual volumes to a host apparatus, and dynamically allocating to each of the plurality of virtual volumes a physical storage area for storing data according to the usage status of each of the plurality of virtual volumes. This control method of a storage apparatus comprises a first step of managing the importance set to each of the plurality of virtual volumes, and a second step of dynamically allocating a storage area to each of the plurality of virtual volumes. At the second step, based on the importance, a storage area provided by a plurality of memory apparatus groups respectively configured from a plurality of memory apparatuses is allocated to one or more virtual volumes with low importance among the plurality of virtual volumes, and a storage area provided by one of the memory apparatus groups is allocated to other virtual volumes among the plurality of virtual volumes.
Consequently, with the control method of a storage apparatus according to the present invention, virtual volumes other than the low importance virtual volumes are not easily affected by the generation of a failure in the memory apparatus group, and it is thereby possible to reduce the probability of loss of data stored in virtual volumes other than the virtual volumes with low importance.
According to the present invention, since it is possible to reduce the probability of loss of data stored in virtual volumes other than the virtual volumes with low importance, it is possible to realize a storage apparatus and its control method capable of improving the maintainability of important data.
An embodiment of the present invention is now explained in detail with reference to the attached drawings.
The host computer 2 is a computer device comprising information processing resources such as a CPU (Central Processing Unit) and a memory, and is configured from a personal computer, a workstation a mainframe or the like.
The storage apparatus 4 comprises a storage unit 10 configured from a plurality of hard disk devices (HDD: Hard Disk Drives), and a controller 11 for controlling the input and output of data into and from the storage unit 10.
Each hard disk device of the storage unit 10 is configured from an expensive disk such as a SCSI (Small Computer System Interface) disk or an inexpensive disk such as a SATA (Serial AT Attachment) disk. Volumes as one or more logical storage areas are associated with the storage areas provided by the hard disk devices. A unique identifier (referred to as a volume ID) is assigned to each volume, and the respective volumes are managed using the volume ID.
As attributes of the volumes to be created in the storage apparatus 4, there are real volumes RVOL, virtual volumes WOL and pool volumes PLVOL. A real volume RVOL is a tangible volume, and is allocated with a storage area in advance in the amount of the capacity. A virtual volume WOL is a virtual volume that is intangible when it is initially created, and a storage area is dynamically allocated thereto according to the usage status. A pool volume PLVOL is an aggregate of storage areas allocated to the virtual volume VVOL.
The controller 11 comprises information processing resources such as a CPU 12 and a memory 13, a cache memory for temporarily storing data to be read from and written into the volumes, and so on. The controller 11 controls the reading and writing of data from and into a designated volume according to an access request (read request and write request) from the host computer 2.
The management computer 5 comprises information processing resources such as a CPU 20 and a memory 21, an input device 22 configured from a keyboard, a mouse and the like, and an output device 23 configured from a CRT (Cathode-Ray Tube) or an LCD (Liquid Crystal Display). The CPU 20 is a processor for governing the overall operational control of the management computer 5, and executes necessary processing based on various control programs stored in the memory 21. The memory 21 is used for primarily storing control programs and control parameters. The virtual volume creation I/O program 24 described later is also stored in the memory 21.
The method of managing storage areas in the storage apparatus 4 of the computer system 1 is now explained with reference to
As shown in
Meanwhile, the storage apparatus 4 operates a plurality of (for instance, four) hard disk devices 30 in the storage unit 10 as one parity group 31, and further operates the hard disk devices 30 in RAID (Redundant Array of Inexpensive Disks) format in parity group units. A system administrator is able to set an intended RAID level (“RAID 0,” “RAID 1,” “RAID 1+0,” “FRAID 2” to “RAID 6”) to each parity group 31.
Among the parity groups 31 defined in the storage apparatus 4, a real volume RVOL is defined in the storage areas provided by the parity groups 31 for real volumes, and the real volume RVOL is associated with the foregoing logical unit LU.
Consequently, if the storage apparatus 4 receives an access request to the logical unit LU associated with the real volume RVOL, it reads and writes data from and into the corresponding address location in the corresponding real RVOL (to be precise, the corresponding address location in the storage area provided by the corresponding parity group 31).
Moreover, among the parity groups 31 in the storage apparatus 4, each of the storage areas provided by the respective parity groups 31 for virtual volumes is managed as one pool volume PLVOL. The storage apparatus 4 collectively manages one or more pool volumes PLVOL as one pool 32.
Here, as shown in
When the storage apparatus 4 receives an access request to a logical unit LU associated with the virtual volume VVOL, it converts this access request into an access request to a virtual volume VVOL, and reads and writes data from and into the chunk 33 allocated to the corresponding data block 34 in the corresponding virtual volume VVOL based on the converted access request.
In this case, if the access request is a write request to a virtual volume VVOL to which a chunk 33 has not yet been allocated, the storage apparatus 4 allocates a chunk 33 in the pool volume PLVOL configured from one of the parity groups 31 to the data block 34, and writes the write-target data, which is to be written into the data block 34, into the chunk 33.
Like this, with the storage apparatus 4, by dynamically allocating a storage area (chunk 33) to the virtual volume VVOL, it is possible to effectively use the storage areas provided by the hard disk device 30 mounted on the storage apparatus 4.
The chunk allocation function loaded in the storage apparatus 4 according to the present embodiment is now explained.
With the computer system I of this embodiment, the system administrator is able to set the importance to the respective virtual volumes VVOL, A characteristic of the computer system 1 this embodiment is in that, when the storage apparatus 4 is to allocate a chunk 33 to the virtual volume VVOL, the chunk 33 is allocated based on rules according to the importance of that virtual volume VVOL.
Another characteristic of the computer system 1 of this embodiment is that the storage apparatus 4 manages the quality level of the storage areas (chunks 33) provided by the respective parity groups 31, and allocates chunks 33 of a parity group 31 with a relatively high quality level to a virtual volume VVOL with relatively, high importance, and allocates chunks 33 of a parity group 31 with a relatively low quality level to a virtual volume VVOL with relatively low importance.
As means for the storage apparatus 4 to execute the foregoing processing, the memory 13 of the storage apparatus 4 stores, as shown in
The virtual volume control program 40, the chunk allocation program 41, the high importance volume allocation program 42, the mid importance volume allocation program 43, the low-importance volume allocation program 44, the virtual volume migration program 45, the pool remaining capacity monitoring program 46, the chunk rearrangement program 47 and the failed volume recovery program 48 are programs for executing the various types of processing described later, and the details thereof will be described later.
The real volume management table 50 is a table for the controller 11 of the storage apparatus 4 to manage the real volume RVOL (
The real volume ID column 50A stores the volume ID assigned to each real volume RVOL set in the storage apparatus 4, the host allocation status column 50B stores host allocation information (“Allocated” when allocated and “Unallocated” when not allocated) representing whether the corresponding real volume RVOL is allocated to the host computer 2. The capacity column 50C stores the capacity of the corresponding real volume RVOL.
Accordingly, for instance, the example of
The virtual volume management table 51 is a table for the controller 11 of the storage apparatus 4 to manage the virtual volume VVOL defined in the storage apparatus 4 and, as shown in
The virtual volume ID column 51A stores the volume ID of each virtual volume VVOL set in the storage apparatus 4, and the host allocation status column 51B stores the host allocation information representing whether the corresponding virtual volume VVOL is allocated to the host computer 2 via the logical unit LU (
The virtual capacity column 51C stores the capacity of the corresponding virtual volume VVOL, and the threshold value column 51D stores the threshold value upon migrating the data stored in the virtual volume VVOL to the real volume RVOL. The allocated capacity column 51E stores the total capacity of the chunk 33 already allocated to the virtual volume VVOL, and the importance column 51F stores the importance set by the system administrator to the virtual volume VVOL. In the case of this embodiment, the importance is set at three levels of “High,” “Mid” and “Low.”
Accordingly, the example of
The allocated chunk management table 52 is a table for managing the allocation status of the chunks 33 in the respective virtual volumes VVOL and, as shown in
The volume ID column 52A stores the volume ID of each virtual volume VVOL, and the pool ID column 52B stores an identifier of the pool 31 (
The allocated chunk column 52D stores an identifier of the chunk 33 (hereinafter referred to as the “chunk ID”) allocated to the corresponding data block 34 in the virtual volume VVOL, and the parity group ID column 52E stores an identifier (hereinafter referred to as the “parity group ID”) assigned to the parity group 31 providing that chunk 33.
Accordingly, the example of
The pool management table 53 is a table for managing the pool 32 (
The pool ID column 53A stores an identifier (hereinafter referred to as the “pool ID”) assigned to each pool 32 provided in the self-storage apparatus, and the parity group ID column 53B stores a parity group ID of each parity group 31 (
The chunk column 53C stores a chunk ID assigned to each chunk 33 provided by the corresponding parity group 31, and the pool volume ID column 53D stores a volume ID assigned to the pool volume PLVOL configured from the corresponding parity group 31 as well as its capacity.
The LBA column 53E stores the range from the top volume of each chunk 33 (
As the type of volume allocation status information, there are, for example, “Allocated” representing the status where that chunk 33 has already been allocated to one of the data blocks 34 (
The quality level column 53G stores the quality level of the storage area (chunk 33) provided by the pool volume PLVOL configured from the corresponding parity group 31. In the case of this embodiment, the quality level is set to the three levels of “High,” “Mid” and “Low.”
Accordingly, the example of
The quality level to be stored in the quality level column 53G of the pool management table 53 may be automatically set by the controller 11 of the storage apparatus 3 based on the type of hard disk devices 30 (
Specifically, with a configuration where hard disk devices 30 such as SCSI disks with high reliability and hard disk devices 30 such as SATA disks with low reliability coexist, the quality level of the pool volume PLVOL provided by a parity group 31 configured from hard disk device 30 with relatively high reliability can be set to “High,” and the quality level of the pool volume PLVOL provided by a parity group configured from other hard disk devices 30 can be set to “Mid.”
If hard disk devices 30 with low reliability are mounted on the storage apparatus 4, the quality level of all pool volumes PLVOL may be set to “Low.” Moreover, if there is a plan to add highly reliable hard disk devices 30 in the future, the quality level of the pool volume PLVOL provided by the parity group 31 configured from those hard disk devices 30 may be initially set to “Mid” and, at the stage of adding the highly reliable hard disk devices 30, the quality level of the pool volume PLVOL provided by the parity group 31 configured from those hard disk device 30 may be set to “High.” Upon adding the hard disk devices 30, the quality level of all pool volumes PLVOL may also be reconfigured.
Further, the quality level of a pool volume PLVOL with a RAID level with relatively high fault tolerance may be set to “High” or “Mid,” and the quality level of a pool volume PLVOL with a RAID level with relatively low fault tolerance may be set to “Mid” or “Low.” For instance, if a pool volume PLVOL with a RAID level of “1” and a pool volume PLVOL with a RAID level of “0” coexist, the quality level of the pool volume PLVOL with a RAID level of “1” may be set to “Mid” and the quality level of the pool volume PLVOL with a RAID level of “0” may be set to “Low.”
The parity group management table 54 is a table for the controller 11 to manage the parity groups 31 defined in the storage apparatus 4 and, as shown in
Among the above, the parity group ID column 54A stores a parity group ID of each parity group 31 defined in the storage apparatus 4, and the corresponding hard disk device column 54B stores an identifier (hereinafter referred to as the “hard disk device ID”) assigned to each hard disk device 4 configuring the corresponding parity group 31.
The attribute column 54C stores an attribute (“real volume” or “pool volume”) of the volume provided by the parity group 31, and the volume ID column 54D stores a volume ID assigned to the volume. The operating status column 54E stores operating status information representing the operating status of that volume (“Normal” when the volume is operating and “Stopped” when the volume is not operating).
Accordingly, the example of
Details concerning the pool remaining capacity monitoring table 55 will be described later.
The virtual volume creation screen 60 is configured from a storage apparatus name input field 61, an allocation destination PID input field 62, an allocation destination LUN input field 63, a capacity input field 64, a data migration threshold value input field 65 and the importance input field 66.
Among the above, the storage apparatus name input field 61 is a filed for inputting a storage apparatus name of the storage apparatus 4 to become the creation destination of the virtual volume VVOL to be created, and the allocation destination PID input field 62 is a field for inputting the PID of the I/O port, among the I/O ports provided to the storage apparatus 4, to become the access destination upon the host computer 2 accessing the logical unit LU (
The allocation destination LUN input field 63 is a field for inputting the LUN of the logical unit LU to be associated with the virtual volume VVOL, and the capacity input field 64 is a field for inputting the capacity of that virtual volume VVOL. The data migration threshold value input field 65 is a field for inputting the data migration threshold value described later, and the importance input field 66 is a field for inputting the importance of the virtual volume VVOL.
By inputting necessary information in the storage apparatus name input field 61, the allocation destination PID input field 62, the allocation destination LUN input field 63, the capacity input field 64, the data migration threshold value input field 65 and the importance input field 66 of the virtual volume creation screen 60, and thereafter clicking the Create button 67, the system administrator is able to send a virtual volume creation request including the various types of information designated in the virtual volume creation screen 60 from the management computer 5 to the creation destination storage apparatus 4 of the virtual volume VVOL.
The controller 11 of the storage apparatus 4 that received the virtual volume creation request creates the virtual volume VVOL designated by the system administrator in the storage apparatus 4 based on the various types of information described above contained in the virtual volume creation request.
Specifically, the controller 11 that received the virtual volume creation request secures an entry (one line of the virtual volume management table 51) for the virtual volume VVOL in the virtual volume management table 51, and stores the volume ID assigned to that virtual volume VVOL in the virtual volume ID column 51A of that entry.
The controller 11 stores the host allocation status information of “Unallocated” representing that the corresponding virtual volume VVOL has not yet been allocated to the host computer 2, the PID of the I/O port for accessing the virtual volume VVOL designated in the virtual volume creation request, and the LUN of the logical unit LU to be associated with that virtual volume VVOL in the host allocation status column 51B of that entry. For instance, in the example of
The controller 11 respectively stores corresponding information contained in the virtual volume creation request in the virtual capacity column 51C and the importance column 51F of that entry. For instance, in the example of
The controller 11 stores the numerical values according to the information of capacity and threshold value contained in the virtual volume creation request in the threshold value column 51D of that entry. For instance, in the example of
The controller 11 stores the numerical value of “0GB” in the allocated capacity column 51E of that entry. According to the foregoing processing, the virtual volume VVOL designated by the system administrator is created in the storage apparatus 4.
The processing contents of the controller 11 of the storage apparatus 4 when an access request to the virtual volume VVOL is issued from the host computer 2 are now explained.
(1-4-1) Access Request Reception Processing
Specifically, the controller 11 starts the access request reception processing when the access request is sent from the host computer 2, and foremost determines whether a chunk 33 (
If the controller 11 obtains a positive result in this determination, it proceeds to step SP3. Contrarily, if the controller 11 obtains a negative result in this determination, it boots the chunk allocation program 41 (
Subsequently, the controller 11 executes processing according to the access request, and sends the processing result to the host computer 2 that sent the access request (SP3).
Specifically, if the access request is a read request, the controller 11 reads data from the chunk 33 allocated to the data block 34 associated with the access destination designated in the read request in the virtual volume VVOL associated with the logical unit LU designated in the read request, and sends this data to the source host computer 2 of the access request.
If the access request is a write request, the controller 11 writes the write-target data sent from the host computer 2 together with the write request into the chunk 33 allocated to the data block 34 associated with the access destination designated in the write request in the virtual volume VVOL associated with the logical unit LU designated in the write request, and sends a write processing completion notice to the host computer 2.
The controller 11 thereafter ends this access request reception processing.
(1-4-2) Chunk Allocation Processing
(1-4-2-1) Processing Routine of Chunk Allocation Processing
When the controller 11 proceeds to step SP2 of the access request reception processing, based on the chunk allocation program 41, it refers to the allocated chunk management table 52, and confirms the importance of the virtual volume VVOL associated with the logical unit LU designated in the access request (write request in this case) (SP10).
If the importance of the virtual volume VVOL is “High,” the controller 11 boots the high importance volume allocation program 42 (
If the importance of the virtual volume VVOL is “Mid,” the controller 11 boots the mid importance volume allocation program 43 (
Moreover, if the importance of the virtual volume VVOL is “Low,” the controller 11 boots the low importance volume allocation program 44 (
(1-4-2-2) High Priority Volume Allocation Processing
When the controller 11 proceeds to step SP11 of the chunk allocation processing, it starts the high importance volume allocation processing, and foremost refers to the virtual volume management table 51, and determines whether a chunk 33 has already been allocated to the virtual volume VVOL associated with the logical unit LU of the access destination designated in the access request (SP20).
If the controller 11 obtains a negative result in this determination, it refers to the pool management table 53, and determines whether there are two chunks 33 that are provided respectively by at least two different parity groups 31 with a quality level of “High” or “Mid” and which are not allocated to any virtual volume VVOL (SP21).
For instance, in the example of
Among the two chunks 33, one chunk 33 is a chunk 33 for reading and writing data from the host computer 2, and the other chunk 33 is a backup chunk 33 for backing up data.
If the controller 11 obtains a negative result in the determination at step SP21, it notifies an access request error to the host computer 2 (SP22). The controller 11 thereafter ends this high importance volume allocation processing, and returns to the chunk allocation processing (
Meanwhile, if the controller 11 obtains a positive result in the determination at step SP21, it selects the foregoing chunk 33 for reading and writing data and the chunk 33 for backing up data.
For instance, in the example of
If there are a plurality of candidate chunks 33, the chunks 33 may be selected by any method. In the ensuing explanation, let it be assumed that a chunk 33 with the smallest chunk ID among the candidate chunks 33 is selected. Accordingly, in the example of
The controller 11 allocates the two selected chunks 33 to the data blocks 34 corresponding to the access destination designated in the access request in the virtual volume VVOL associated with the logical unit LU designated in the access request (SP26).
Specifically, the controller 11 changes the virtual volume allocation status information stored in the virtual volume allocation status column 53F of the respectively entries, among the respective entries of the pool management table 53 (
The controller 11 additionally registers information concerning these chunks 33 in the allocated chunk management table 52 (
The controller 11 changes the numerical value stored in the allocated capacity column 51E of the entry corresponding to the virtual volume VVOL of the virtual volume management table 51 (
According to the foregoing processing, the virtual volume management table 51, the allocated chunk management table 52 and the pool management table 53 will respectively change from the status of
Meanwhile, if the controller 11 obtains a positive result in the determination at step SP20, it refers to the allocated chunk management table 52, and acquires the parity group ID of the parity group 31 providing the chunk 33 to the virtual volume VVOL associated with the logical unit LU of the access destination designated in the access request (SP23).
Since a “High” importance virtual volume VVOL is allocated with a chunk 33 to be used for reading and writing data and a chunk 33 for backing up data, at step SP23, the controller 11 acquires the parity group ID of each parity group 31 respectively providing the two chunks 33.
For example, if the allocated chunk management table 52 is in the status shown in
The controller 11 thereafter refers to the pool management table 53, and determines whether there is a chunk 33 that has not yet been allocated to any virtual volume VVOL in the two parity groups 31 in which the parity group ID was acquired at step SP23 (SP24).
For instance, in the example of
If the controller 11 obtains a positive result in the determination at step SP24, it allocates the two unallocated chunks 33 provided respectively by the two parity groups 31 detected at step SP23 to the target virtual volume VVOL (SP26), thereafter ends this high importance volume allocation processing, and returns to the chunk allocation processing (
Contrarily, if the controller 11 obtains a negative result in the determination at step SP24, it boots the virtual volume migration program 45 (
The controller 11 thereafter ends this high importance volume allocation processing, and returns to the chunk allocation processing.
When two chunks 33 are allocated to the data block 34 designated in the access request in the virtual volume VVOL designated in the access request as described above, at step SP3 of the access request reception processing in
The specific processing contents of the controller 11 at step SP25 of the high importance volume allocation processing are now shown in
When the controller 11 proceeds to step SP25 of the high importance volume allocation processing, it starts the virtual volume migration processing, foremost refers to the real volume management table 50 (
Subsequently, the controller 11 changes the status of the migration source virtual volume VVOL and the migration destination real volume RVOL to the migration status (SP31), and thereafter migrates the data stored in the migration source virtual volume VVOL from the migration source virtual volume VVOL to the migration destination real volume RVOL (SP32).
Subsequently, the controller 11 deletes the migration source virtual volume VVOL by erasing the entry corresponding to the migration source virtual volume VVOL in the virtual volume management table 51 (SP33). The controller 11 thereafter ends this virtual volume migration processing and returns to the high importance volume allocation processing (
(1-4-2-3) Mid Priority Volume Allocation Processing
Meanwhile,
The mid importance volume allocation processing differs from the high importance volume allocation processing explained with reference to
Specifically, the controller 11 starts the mid importance volume allocation processing upon proceeding to step SP12 of the chunk allocation processing, foremost refers to the virtual volume management table 51, and determines whether a chunk 33 has already been allocated to the virtual volume VVOL of the access destination designated in the access request (SP40).
If the controller 11 obtains a negative result in this determination, it refers to the pool management table 53, and determines whether there is a chunk 33 that is provided by a parity group 31 with a quality level of “High” or “Mid” and which is not allocated to any virtual volume VVOL (SP41).
If the controller 11 obtains a negative result in the determination at step SP41, it notifies an access request error to the host computer 2 (SP42). The controller 11 thereafter ends this mid importance volume allocation processing, and returns to the chunk allocation processing (
Meanwhile, if the controller 11 obtains a positive result in the determination at step SP41, it selects one chunk 33 that satisfies the conditions at step SP41. For instance, in the example of
The controller 11 allocates the selected chunk 33 to the data block 34 designated in the access request in the virtual volume VVOL designated in the access request (SP46).
Specifically, the controller 11 changes the virtual volume allocation status information stored in the virtual volume allocation status column 53F of the entry, among the respective entries of the pool management table 53, corresponding the chunk 33 selected as described above from “Unallocated” to “Allocated,” and additionally stores the volume ID of the virtual volume VVOL of the allocation destination in the virtual volume allocation status column 53F.
The controller 11 additionally registers information concerning the chunks 3 in the allocated chunk management table 52. Specifically, the controller 11 secures one new entry in the allocated chunk management table 52, and stores the chunk ID of the chunk 33 allocated to the virtual volume VVOL in the allocated chunk column 52D of that entry. Further, the controller 11 respectively stores the parity group ID of the parity group 31 providing the corresponding chunk 33 and the pool 10 of the pool 32 to which that parity group 31 belongs in the parity group ID column 52E and the pool column 52B of that entry The controller 11 further stores the volume ID of the virtual volume VVOL and the range (LBA) from the volume top of the data block 34 allocated with the chunk 33 in the virtual volume VVOL in the volume ID column 52A and the allocated LBA column 52C of that entry.
The controller 11 changes the numerical value stored in the allocated capacity column 51E of the entry corresponding to the virtual volume VVOL of the virtual volume management table 51 to the capacity of the chunk 33 allocated to that virtual volume VVOL.
The controller 11 thereafter ends this mid importance volume allocation processing, and returns to the chunk allocation processing.
Meanwhile, if the controller 11 obtains a positive result in the determination at step SP40, it refers to the allocated chunk management table 52, and acquires the parity group ID of the parity group 31 providing the chunk 33 which has been allocated to the virtual volume VVOL associated with the logical unit LU designated in the access request (SP43).
For example, if the allocated chunk management table 52 is in the status shown in
The controller 11 thereafter refers to the pool management table 53, and determines whether there is a chunk 33 that has not yet been allocated to any virtual volume VVOL in the parity group 31 in which the parity group ID was acquired at step SP43 (SP44).
For instance, in the example of
If the controller 11 obtains a positive result in the determination at step SP44, it allocates the chunk 33 provided respectively by the parity group 31 detected at step SP43 to the target virtual volume VVOL (SP46), thereafter ends this mid importance volume allocation processing, and returns to the chunk allocation processing (
Contrarily, if the controller 11 obtains a negative result in the determination at step SP44, it boots the virtual volume migration program 45 (
(1-4-24) Low Priority Volume Allocation Processing
Meanwhile,
In other words, the controller 11 starts the low importance volume allocation processing upon proceeding to step SP13 of the chunk allocation processing, foremost refers to the virtual volume management table 51, and determines whether a chunk 33 has already been allocated to the virtual volume VVOL associated with the logical unit LU designated in the access request (SP50).
If the controller 11 obtains a negative result in this determination, it refers to the pool management table 53, and determines whether there is a chunk 33 that is provided by a parity group 31 with a quality level of “Mid” or “Los” and which is not allocated to any virtual volume VVOL (SP51).
If the controller 11 obtains a negative result in the determination at step SP51, it notifies an access request error to the host computer 2 (SP52). The controller 11 thereafter ends this low importance volume allocation processing, and returns to the chunk allocation processing (
Meanwhile, if the controller 11 obtains a positive result in the determination at step SP51, it selects one chunk 33 that satisfies the conditions at step SP51, and allocates the selected chunk 33 to the data block 34 corresponding to the access destination designated in the access request in the virtual volume VVOL associated with the logical unit LU designated in the access request (SP57). Since the processing contents at step SP57 are the same as the processing contents at step SP47 of the mid importance volume allocation processing explained with reference to
Meanwhile, if the controller 11 obtains a positive result in the determination at step SP50, it refers to the allocated chunk management table 52, and acquires the parity group ID of the parity group 31 providing the chunk 33 which has been allocated to the virtual volume VVOL associated with the logical unit LU designated in the access request (SP53).
Subsequently, the controller 11 refers to the pool management table 53, and determines whether there is a chunk 33 that is provided by a parity group 31 with a quality level of “Mid” or “Low” and which is not allocated to any virtual volume VVOL (SP54).
If the controller 11 obtains a negative result in this determination, it proceeds to step SP52. Contrarily, if the controller obtains a positive result in this determination, it refers to the pool management table 53, is determines whether there is a chunk 33 that is not allocated to any virtual volume VVOL and which is provided by a parity group 31 that is different from the parity group 31 assigned with the parity group ID acquired at step SP53 (SP55).
If the controller 11 obtains a positive result in this determination, it proceeds to step SP57. Contrarily, if the controller 11 obtains a negative result in this determination, it determines whether the setting permits the allocation to the virtual volume VVOL of another chunk 33 provided to the same parity group 31 as the parity group 31 already providing the chunk 33 allocated to the virtual volume VVOL associated with the logical unit LU designated in the access request (SP56). This setting is configured in advance by the system administrator.
If the controller 11 obtains a negative result in this determination, it proceeds to step SP52. Contrarily, if the controller 11 obtains a positive result in this determination, it selects a chunk 33 that is not allocated to any virtual volume VVOL among the chunks 33 provided by a parity group 31 that is different from the parity group 31 of the parity group ID detected at step SP53, and allocates this chunk 33 to the data block 34 corresponding to the access destination designated according to the address request of the virtual volume VVOL associated with the logical unit LU designated in the address request (SP57). The controller 11 thereafter ends this low importance volume allocation processing, and returns to the chunk allocation processing.
(14-3) Pool Remaining Capacity Monitoring Processing
Incidentally, if chunks 33 are dynamically allocated sequentially to the virtual volume VVOL based on the foregoing chunk allocation processing, there may eventually be a case where a chunk 33 cannot be allocated to a virtual volume VVOL with the importance of “High” and “Mid” stipulated to be allocated with a chunk 33 provided by the same parity group 31.
Thus, the storage apparatus 4 of this embodiment is loaded with a pool remaining capacity monitoring function for monitoring the remaining capacity of the pool volumes PLVOL respectively configured from the respective parity groups 31, and, at the stage where the remaining capacity (number of chunks unallocated to the virtual volume VVOL) of the pool volume PLVOL with a quality level of “High” or “Mid” becomes smaller than a predetermined threshold value, replacing the chunk 33 provided by a “Mid” quality level parity group 31 allocated to the “Low” quality level virtual volume VVOL with the chunk 33 provided by the “Low” quality level parity group 31.
As means for realizing the pool remaining capacity monitoring function, the memory 13 of the storage apparatus 4 stores, as shown in
Among the above, the pool remaining capacity monitoring table 55 is a table for the controller 11 to manage the remaining capacity of the respective pool volumes PLVOL and, as shown in
The pool ID column 55A stores a pool ID of each pool 32 (
Meanwhile, the parity group ID column 55D stores the parity group ID of each parity group 31 respectively configuring the pool volume PLVOL belonging to that pool 32, and the quality level column 55E stores the quality level set in the corresponding parity group 31.
The virtual capacity column 55F stores the capacity of the pool volume PLVOL configured from the corresponding parity group 31, and the allocated capacity column 55G and the remaining capacity column 55H respectively store the total capacity of the chunk 33 already allocated to one of the virtual volumes VVOL among the capacities of the respective pool volumes PLVOL and the remaining capacity of the pool volume PLVOL.
The allocation destination virtual volume column 55I stores the volume ID and the importance of the virtual volume VVOL if a chunk 33 provided by the pool volume PLVOL configured from the corresponding parity group 31 is already allocated to one of the virtual volumes VVOL.
Accordingly, the example of
Specifically, when the controller 11 starts the pool remaining capacity monitoring processing, it foremost creates the pool remaining capacity monitoring table 55 explained with reference to
Subsequently, the controller 11 selects one allocation destination virtual volume column 55I of the pool remaining capacity monitoring table 55 (SP61), and determines whether there the importance of the virtual volume VVOL associated with the allocation destination virtual volume column 55I is “High” or “Mid” based on the importance stored in the allocation destination virtual volume column 55I (SP62).
If the controller 11 obtains a negative result in this determination, it proceeds to step SP66. Contrarily, it the controller 11 obtains a positive result in this determination, it calculates the capacity of the chunks 33 unallocated to the virtual volume VVOL (i.e., remaining capacity of the virtual volume VVOL; hereinafter referred to as the “unallocated capacity”) by referring to the virtual capacity column 51C and the allocated capacity column 51E of the corresponding entry of the virtual volume management table 51.
For instance, in the examples of
Subsequently, the controller 11 refers to the unallocated capacity column 55H corresponding to the allocation destination virtual volume column 55I selected at step SP61 in the pool remaining capacity monitoring table 55, and determines whether the remaining capacity of the parity group 31 providing the chunk 33 to the virtual volume VVOL is less than the remaining capacity of the virtual volume VVOL calculated at step SP63 (SP64).
For instance, in the foregoing example, since the unallocated capacity of the virtual volume VVOL calculated at step SP63 is 8GB and the remaining capacity of the parity group 31 providing the chunk 33 to the virtual volume VVOL is “4GB,” this means that the unallocated capacity of the virtual volume VVOL calculated at step SP63 is greater than the remaining capacity of the parity group 31 providing the chunk 33 to the virtual volume VVOL.
If the controller 11 obtains a negative result in this determination, it proceeds to step SP66. Contrarily, if the controller 11 obtains a positive result in this determination, it executes the chunk rearrangement processing described later with reference to
Subsequently, the controller 11 determines whether the same processing has been performed regarding all allocation destination virtual volume columns 551 of the pool remaining capacity monitoring table 55 (SP66). If the controller 11 obtains a negative result in this determination, it returns to step SP61, and thereafter repeats the same processing (SP61 to SP66-SP61).
If the controller 11 obtains a positive result at step SP66 as a result of the same processing being performed regarding all allocation destination virtual volume columns 551 of the pool remaining capacity monitoring table 55, it ends this pool remaining capacity monitoring processing.
The specific processing contents of the controller 11 regarding the chunk arrangement processing to be performed at step SP65 of the pool remaining capacity monitoring processing are now explained with reference to
As shown in
Incidentally, if a chunk 33 provided by a parity group 31 with a “Mid” quality level is allocated to a “Low” importance-virtual volume VVOL, as shown in
Moreover, as shown in
Thus, in this embodiment, as means for performing the foregoing processing (hereinafter referred to as the “chunk rearrangement processing”), the memory 13 of the storage apparatus 4 stores the chunk rearrangement program 47 (
When such a pool volume PLVOL exists, the controller 11 reallocates the chunk of that pool volume PLVOL to the “High” or “Mid” importance virtual volume VVOL, and migrates the data stored in the respective chunks 33 allocated to the virtual volume VVOL before the foregoing reallocation to each of the new chunks 33 after the reallocation (SP71). The controller 11 thereafter ends this chunk rearrangement processing, and returns to the pool remaining capacity monitoring processing.
Contrarily, if it was not possible to detect a pool volume PLVOL that satisfies the foregoing conditions at step SP70, the controller 11 refers to the allocated chunk management table 52 (
Subsequently, the controller 11 refers to the pool management table 53 and searches for a pool volume PLVOL with chunks 33 capable of reallocating a chunk 33 to the target “High” importance virtual volume VVOL (SP73). The target of search is the pool volumes PLVOL having a remaining capacity that is greater than the capacity of the “High” importance virtual volume VVOL and configured from a parity group 31 with a quality level of “High” or “Mid.”
If the controller 11 detects a pool volume PLVOL that satisfies the foregoing conditions as a result of the search, it performs the reallocation processing of the chunk 33 (SP71), thereafter ends this chunk rearrangement processing, and returns to the pool remaining capacity monitoring processing.
Contrarily, if the controller 11 was unable to detect a pool volume PLVOL that satisfied the foregoing conditions at step SP73, it displays a corresponding warning message on the management computer 5 by notifying a warning to the management computer 5 (SP74). The controller 11 thereafter ends this chunk rearrangement processing, and returns to the pool remaining capacity monitoring processing.
Incidentally, in substitute for notifying a warning to the management computer 5 at step SP74, the virtual volume migration processing explained with reference to
(1-44) Failed Volume Recovery Processing
The failed volume recovery processing is now explained. With the computer system 1 of this embodiment, since the data stored in the “High” importance virtual volume VVOL is duplicated and retained, even if a failure occurs in that virtual volume VVOL and becomes unrecoverable, that virtual volume VVOL can be recovered by using the duplicated data.
Specifically, if any volume becomes unrecoverable due to a failure, the controller 11 foremost identifies the parity group (parity group subject to a failure; hereinafter referred to as the “failed parity group”) 31 providing the chunk 33 to the volume that became unrecoverable due to a failure (hereinafter referred to as the “failed volume”) based on the failure information notified to the controller 11 from the hard disk device 30 (
Subsequently, the controller 11 refers to the parity group management table 54, and determines whether the attribute of the volume provided by the failed parity group 31 is a real volume RVOL (SP81). If the controller 11 obtains a positive result in the determination at step SP81, since this means that it is impossible to recover that failed volume, the controller 11 ends this failed volume recovery processing.
Contrarily, if the controller 11 obtains a negative result in the determination at step SP81, it refers to the pool management table 53 (
Then, based on the findings at step SP82, the controller 11 determines whether the failed volume is a “High” importance virtual volume VVOL, and whether there is a chunk 33 storing the same data as the data stored in the chunk 33 provided by that failed parity group 31 (SP83). Specifically, the controller 11 determines whether the allocation status of each chunk 33 provided by that failed parity group 31 to the failed volume is “Duplicated.”
If the controller 11 obtains a negative result in the determination at step SP83, this means that it is impossible to recover the failed volume. Consequently, in this case, the controller 11 ends this failed volume recovery processing.
Contrarily, if the controller 11 obtains a positive result in the determination at step SP83, this means that the failed volume can be recovered using the data stored in the other chunk 33 that is not subject to a failure. Consequently, in this case, the controller 11 executes the recovery processing for recovering the failed volume (hereinafter referred to as the “high importance volume recovery processing”) (SP84), and thereafter ends this failed volume recovery processing.
Subsequently, the controller 11 refers to the virtual volume management table 51 (
If the controller 11 was unable to detect such a parity group 31, it performs the virtual volume migration processing explained with reference to
Contrarily, if the controller 11 was able to detect the foregoing parity group 31, it reallocates to the failed volume a chunk 33 that is unallocated to the parity group 31, and copies the data stored in the chunk 33 allocated prior to the reallocation to the reallocated chunk 33 (SP94).
Specifically, the controller 11 changes the allocation status information stored in the virtual volume allocation status column 53F of the pool management table 53 (
Further, the controller 1 reads the data stored in the chunk 33 before the reallocation from the backup chunk 33 storing the same data as the foregoing chunk 33, and stores this data in the chunk 33 after the reallocation.
The controller 11 thereafter ends this high importance volume recovery processing, and returns to the failed volume recovery processing.
As described above, with the computer system 1 according to this embodiment, since a chunk 33 provided by the same parity group 31 is allocated to a “High” or “Mid” importance virtual volume VVOL, and a chunk 33 provided by a plurality of parity groups 31 is allocated to a “Low” importance virtual volume VVOL, influence of the failure that occurred in the parity group 31 can be stochastically reduced. Consequently, it is possible to improve the maintainability of important data in the storage apparatus loaded with the AOU function.
In addition, with the computer system 1 of this embodiment, since a chunk 33 provided by a parity group 31 with a quality level of “High” or “Mid,” which does not fail easily, is allocated to a “High” or “Mid” importance virtual volume VVOL, it is possible to further improve the maintainability of important data in the storage apparatus loaded with the AOU function.
In other words, with the computer system 100 of this embodiment, upon creating a virtual volume VVOL, the system administrator is able to designate, in addition to the importance of that virtual volume VVOL, the performance to be requested to that virtual volume VVOL (hereinafter referred to as the “virtual volume VVOL performance requirement”) and the RAID level to be requested to the parity group 3 providing the chunk 33 to that virtual volume VVOL (hereinafter referred to as the “virtual volume VVOL reliability requirement”).
The controller 102 (
Specifically, the controller 102 allocates the chunk 33 of the same parity group 31 as with the first embodiment to a “High” importance virtual volume VVOL, and further duplicates the data. The controller 11 allocates the chunk 33 of the same parity group 31 to a “Mid” importance virtual volume VVOL. Moreover, the controller 102 allocates the chunk 33 of a plurality of parity groups 31 to a “Low” importance virtual volume VVOL so that the data is distributed to a plurality of parity groups 31.
Here, as the chunk 33 to be allocated to the virtual volume VVOL, the controller 102 selects a chunk 33 of the parity group configured from high performance hard disk devices 30 (
As means for performing this kind of control, in the case of this embodiment, as shown in
In other words, the virtual volume management table 103 according to this embodiment, as shown in
Accordingly, the example of
The virtual pool table 104, as shown in
The virtual volume creation screen 112 includes, in addition to the storage apparatus name input field 61, the allocation destination PID input field 62, the allocation destination LUN input field 63, the capacity input field 64, the data migration threshold value input field 65 and the importance input field 66, a performance requirement field 113 for inputting the request performance of the virtual volume VVOL to be created and a reliability requirement field 114 for inputting the virtual volume VVOL reliability requirement.
By inputting the necessary information in the storage apparatus name input field 61, the allocation destination PID input field 62, the allocation destination LUN input field 63, the capacity input field 64, the data migration threshold value input field 65, the importance input field 66, the performance requirement field 113 and the reliability requirement field 114, and thereafter clicking the Create button 67, the system administrator is able to send various types of information set on the virtual volume creation screen 112 as the virtual volume creation request from the management computer 110 to the creation destination storage apparatus 101 of the virtual volume VVOL.
The controller 102 of the storage apparatus 101 that received this virtual volume creation request creates, as in the first embodiment, the virtual volume VVOL designated by the system administrator in the storage apparatus 101 based on the various types of information contained in the virtual volume creation request. Here, the controller 102 stores the created virtual volume VVOL performance requirement and reliability requirement in the performance requirement column 103G and the reliability requirement column 104G of the virtual volume management table 103 (
In this case, the processing contents at step SP100, step SP101 and step SP104 to step SP108 of the high importance volume allocation processing are the same as step SP20 to step SP26 of the high importance volume allocation processing according to the first embodiment explained with reference to
Nevertheless, with the high importance volume allocation processing of the present embodiment, if the controller 11 obtains a positive result in the determination at step SP101, it determines whether at least two parity groups 31 among the respective parity groups 31 having an unallocated chunk 33 that has not been allocated to any virtual volume VVOL satisfy the performance requirement stored in the performance requirement column 103G of the corresponding entry (entry corresponding to the virtual volume VVOL to which the chuck 33 is to be allocated) of the virtual volume management table 103 (
If the controller 102 obtains a negative result in this determination, it notifies an error to the host computer 2 (SP104). Contrarily, if the controller 102 obtains a positive result in this determination, it determines whether at least two parity groups 31 among the respective parity groups 31 satisfying the performance requirement satisfy the reliability requirement stored in the reliability requirement column 103H of the corresponding entry (entry corresponding to the virtual volume VVOL to which the chuck 33 is to be allocated) of the virtual volume management table 103 (SP103).
If the controller 102 obtains a negative result in this determination, it notifies an error to the host computer 2 (SP104). Contrarily, if the controller 102 obtains a positive result in this determination, it allocates, one by one, the unallocated chunks 33 provided respectively by the two parity groups 31 satisfying the performance requirement and the reliability requirement to the data block 34 (
Meanwhile,
In this case, step SP110, step SP111 and step SP114 to step SP118 of the mid importance volume allocation processing are the same as step SP40 to step SP46 of the mid importance volume allocation processing according to the first embodiment explained with reference to
Nevertheless, with the mid importance volume allocation processing of the present embodiment, if the controller 102 obtains a positive result in the determination at step SP111, it determines whether a parity group 31 having an unallocated chunk 33 that has not been allocated to any virtual volume VVOL satisfies the performance requirement stored in the performance requirement column 103G of the corresponding entry (entry corresponding to the virtual volume VVOL to which the chuck 33 is to be allocated) of the virtual volume management table 103 (
If the controller 102 obtains a negative result in this determination, it notifies an error to the host computer 2 (SP114). Contrarily, if the controller 102 obtains a positive result in this determination, it determines whether a parity group 31 satisfying the performance requirement satisfies the reliability requirement stored in the reliability requirement column 103H of the corresponding entry (entry corresponding to the virtual volume VVOL to which the chuck 33 is to be allocated) of the virtual volume management table 103 (SP113).
If the controller 102 obtains a negative result in this determination, it notifies an error to the host computer 2 (SP114). Contrarily, if the controller 102 obtains a positive result in this determination, it allocates the unallocated chunk 33 provided by the parity group 31 satisfying the performance requirement and the reliability requirement to that virtual volume VVOL (SP118).
Meanwhile,
In this case, step SP120, step SP121 and step SP124 to step SP129 of the low importance volume allocation processing are the same as step SP50 to step SP57 of the low importance volume allocation processing according to the first embodiment explained with reference to
Nevertheless, with the low importance volume allocation processing of the present embodiment, if the controller 102 obtains a positive result in the determination at step SP121, it determines whether a parity group 31 having an unallocated chunk 33 that has not been allocated to any virtual volume VVOL satisfies the performance requirement stored in the performance requirement column 103G of the corresponding entry (entry corresponding to the virtual volume VVOL to which the chuck 33 is to be allocated) of the virtual volume management table 103 (
If the controller 102 obtains a negative result in this determination, it notifies an error to the host computer 2 (SP124). Contrarily, if the controller 102 obtains a positive result in this determination, it determines whether a parity group 31 satisfying the performance requirement satisfies the reliability requirement stored in the reliability requirement column 103H of the corresponding entry (entry corresponding to the virtual volume VVOL to which the chuck 33 is to be allocated) of the virtual volume management table 103 (SP133).
If the controller 102 obtains a negative result in this determination, it notifies an error to the host computer 2 (SP124). Contrarily, if the controller 102 obtains a positive result in this determination, it allocates the unallocated chunk 33 provided by the parity group 31 satisfying the performance requirement and the reliability requirement to that virtual volume VVOL (SP129),
According to the foregoing processing, the controller 102 is able to allocate a chunk 33 that satisfies the performance requirement and the reliability requirement designated by the system administrator to the virtual volume VVOL.
As described above, with the computer system 100 of the present embodiment, since it is also possible to designate the performance and reliability of to be requested to the virtual volume VVOL, in addition to the effect yielded in the first embodiment, it is possible to provide an AOU function capable of configuring a more detailed setting according to the users' needs, and consequently possible to further improve the usability of the computer system 100.
Specifically, with the computer system 200 according to this embodiment, when a creation request of a “High” or Mid” importance virtual volume VVOL is sent from the management computer 5 to the storage apparatus 201, the controller 202 of the storage apparatus 201 previously stores chunks 33 in the same capacity as the capacity of the virtual volume VVOL from the two parity groups 31 both having a remaining capacity that is greater than the capacity of that virtual volume VVOL.
The controller 202 associates each of the secured chunks 33 in advance with each of the data blocks 34 of the virtual volume VVOL, and thereafter allocates the associated chunk 33 to the virtual volume VVOL when a write request to the virtual volume VVOL is issued from the host computer 2.
Specifically, when the controller 202 creates the requested virtual volume VVOL according to the volume creation request from the management computer 5, it starts the chunk pre-allocation processing, and foremost determines the importance of the created virtual volume VVOL based on the volume creation request of the virtual volume VVOL received previously from the management computer 5 (SP130).
If the importance of the virtual volume VVOL is “High,” the controller 202 determines whether there are at least two parity groups 31 with a quality level of “High” and which have a remaining capacity that is greater than the capacity of the created virtual volume VVOL (SP131).
If the controller 202 obtains a negative result in this determination, it sends an error notice to the management computer 5 in response to the volume creation request of the created virtual volume VVOL (SP132). Consequently, in accordance with the error notice, the management computer 5 displays a warning such as “A virtual volume in the designated capacity and importance cannot be created.” In substitute for the warning, the controller 202 may display a message such as “A virtual volume can be created if it can be distributed to a separate parity group as a low importance virtual volume” on the management computer 5. The controller 202 thereafter ends this chunk pre-allocation processing.
Contrarily, if the controller 202 obtains a positive result in the determination at step SP131, it allocates the chunks 33 of two different parity groups 31 (one chunk per parity group 31) to all data blocks 34 of the created virtual volume NOL (SP133). The controller 202 thereafter ends this chunk pre-allocation processing.
Meanwhile, if the importance of the created virtual volume VVOL is “Mid,” the controller 202 determines whether there is a parity group with a quality level of “High” or “Mid” and with a remaining capacity that is greater than the capacity of the created virtual volume VVOL (SP134).
If the controller 202 obtains a negative result in this determination, it proceeds to step SP132. Contrarily, if the controller 202 obtains a positive result in this determination, it allocates the chunks 33 of the parity groups 31 (one chunk at a time) detected at step SP134 to all data blocks 34 of the created virtual volume VVOL (SP135). The controller 202 thereafter ends this chunk pre-allocation processing.
Accordingly, with the computer system 200 of this embodiment, since chunks 33 are allocated to the respective data blocks 34 (
Although the first to third embodiments described above explained cases of applying the present invention to the computer systems 1, 100, 200 configured as shown in
Moreover, although the first to third embodiments explained a case of setting the importance of the virtual volume VVOL to the three levels of “High,” “Mid” and “Low,” the present invention is not limited to the foregoing configuration, and the importance may be set to two levels or four levels or more.
Similarly, although the first to third embodiments described a case of setting the quality level of the parity group to the three levels of “High,” “Mid” and “Low,” the present invention is not limited to the foregoing configuration, and the quality level may be set to two levels or four levels or more.
In addition, although the foregoing embodiments described a case of configuring the management unit for managing the importance set to each of the virtual volumes with the controllers 11, 102, 202 of the storage apparatus 4 and the virtual volume control program 40, configuring the storage area allocation unit for dynamically allocating a storage area (chunk 33) to the virtual volume VVOL with the controllers 11, 102, 202 and the chunk allocation program 41, the high importance volume allocation programs 42, 120, the mid importance volume allocation programs 43, 121 and the low importance volume allocation programs 43, 122, and configuring the control unit for controlling the reading and writing of data from the host apparatus (host computer 2) from and into the storage area (chunk 33) allocated to the virtual volume VVOL from the controllers 11, 102, 202, the present invention is not limited to the foregoing configuration, and various other configurations may be broadly applied to the configuration of the management unit, the storage area allocation unit and the control unit.
The present invention can be broadly applied to storage apparatuses loaded with the AOU function.
Number | Date | Country | Kind |
---|---|---|---|
2008-134939 | May 2008 | JP | national |