This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2013-124158, filed on Jun. 12, 2013, the entire contents of which are incorporated herein by reference.
The embodiment discussed herein is related to a storage system and an operation management method of a storage system.
Conventionally, in storage systems, automated storage tiering (AST) is performed by using storages each having different performance. Examples of the storages having different performance include hard disk drives (HDDs) and solid state drives (SSDs). Furthermore, for HDDs, there are devices having different access performance. The AST automatically relocates data to storages having different performance when an information processing system is running. Consequently, by dynamically changing data locations using the AST when the information processing system is running, the storage systems can follow the change in the performance state occurring during the operation of the system.
The AST monitors an access to a volume present in a pool constituted by hierarchizing storages having different performance and relocates data among subpools in accordance with a hierarchical policy that is set by an administrator of the storage system. The pool mentioned here is, for example, a single virtual disk constituted by multiple HDDs or SSDs. Furthermore, the subpool mentioned here is obtained by dividing the pool on the basis of its performance. The pool that includes multiple subpools as multiple tiers is referred to as a tier pool (or, a hierarchical pool). Furthermore, the hierarchical policy mentioned here is information that is used to define a policy related to relocation of data, such as the timing, the relationship between the access frequency of data and a subpool in which data is to be located.
The operation management device 93 manages the operation of the storage device 92 and has a function of the AST. By allocating frequently accessed data to the high performance SSD and by allocating less frequently accessed data to the low performance and low price near line disk, the AST can improve the performance of the system while reducing the cost. Furthermore, with the AST, because the location of data is dynamically changed during the operation of the system, the layout design is not needed. Consequently, it is possible to implement the reduction of the workload imposed on an administrator of the storage system and the reduction of the management cost.
Furthermore, there is a storage system that moves a data block, in which the access frequency of data exceeds the upper limit that is specified in advance, to a storage device in a high performance group and that moves a data block, in which the data access frequency below the lower limit that is specified in advance, to a storage device in a low performance group (for example, see Japanese Laid-open Patent Publication No. 2003-108317). Furthermore, there is a conventional technology that compares, in a storage device having two or more storage media, the use frequency of each piece of data with the reference use frequency and that moves, if the use frequency of the data is low, the data to a storage medium in which the access time is longer (for example, see Japanese Laid-open Patent Publication No. 3-48321).
The administrator of the storage system sets the reference of relocation of data by specifying the value of Input/Output per second (IOPS) by using the hierarchical policy. For example, the administrator of the storage system specifies the reference of the relocation of data by using a hierarchical policy such as relocating the data to the SSD, if data with 501 IOPS or more is present.
The AST relocates data on the basis of the IOPS value specified by the hierarchical policy. Consequently, there is a problem in that a high performance subpool is not used even when a free space is present in the high performance subpool. For example, in the hierarchical policy in which, if data with IOPS value that is equal to or greater than 501 is present, data is relocated to an SSD, if no data with 501 IOPS or more is present, the SSD is not used. Furthermore, if the number of pieces of data with 501 IOPS is small, a free space is not used even if the free space is present in the SSD.
According to an aspect of an embodiment, a storage system includes an allocating unit that sequentially allocates, by giving priority to a high performance storage from among multiple storages each having different performance, one of the storages to data in the order the access frequency of the data is high; a identifying unit that identifies, as the target for relocation from among pieces of data to each of which a storage is allocated by the allocating unit, data to which a storage that is different from the storage that currently stores the data is allocated; and a control unit that relocates the data identified, by the identifying unit, as the target for the relocation.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
Preferred embodiments of the present invention will be explained with reference to accompanying drawings. The present invention is not limited to the embodiment. Furthermore, in the following, a storage, such as a HDD, an SSD, or the like is referred to as a “disk”.
In the following, the configuration of a storage system according to an embodiment will be described first.
The storage device 2 includes SSDs and HDDs and provides a tier pool. The operation management device 3 manages the operation of the storage device 2 and has an AST function. The operation terminal 4 is a device that is used by an administrator of the storage system 1 (hereinafter, simply referred to as an “administrator”) to interact with the operation management device 3.
The CMs 21 are devices each of which controls the storage device 2 on the basis of the request from a server 7 and are duplexed. The DE 22 is a structure on which SSDs and HDDs are mounted. The DE 22 includes multiple disks 6 and provides a tier pool that includes three subpools, i.e., a low performance subpool, a medium performance subpool, and a high performance subpool.
Each of the subpools includes multiple redundant arrays of inexpensive disks (RAID) groups. For example, the low performance subpool includes a RAID group #0 and a RAID group #1 and the medium performance subpool includes a RAID group #2 and a RAID group #3. Furthermore, the high performance subpool includes a RAID group #4 and a RAID group #5. Furthermore, each of the RAID groups includes the multiple disks 6.
In the following, the functional configuration of the operation management device 3 will be described.
The storage management unit 31 manages the storage device 2. Specifically, the storage management unit 31 manages a hierarchical policy, manages a tier pool, manages a volume, and identifies a relocation block on the basis of the hierarchical policy. The block mentioned here is a unit of relocated data and is, for example, data with 1.3 gigabytes (GB) in size.
The automated storage tiering unit 32 performs the AST on the basis of the instruction from the storage management unit 31. Specifically, the automated storage tiering unit 32 acquires performance information, such as IOPS values, from the storage device 2; notifies the start of the tiering control of the storage device 2; and requests relocation. Furthermore, the automated storage tiering unit 32 requests the storage device 2 to create a tier pool, a volume, and the like.
The performance information storing unit 33 stores therein performance information, such as IOPS values acquired by the automated storage tiering unit 32 from the storage device 2. Furthermore, the information stored in the performance information storing unit 33 is used when the storage management unit 31 identifies a relocation block. The performance information storing unit 33 will be described in detail later.
The evaluation result storing unit 34 stores therein the result obtained by the storage management unit 31 analyzing and evaluating the performance information stored in the performance information storing unit 33. The evaluation result storing unit 34 will be described in detail later.
In the following, the functional configuration of the storage management unit 31 will be described.
The policy management unit 41 receives an instruction to create a hierarchical policy received from the operation terminal 4, registers the hierarchical policy in the policy management table 42, and instructs the operation terminal 4 to display the information on the registered hierarchical policy.
The policy management table 42 stores therein information on the hierarchical policy that is registered by the policy management unit 41.
The hierarchical policy name is the name that is used to identify a hierarchical policy. The execution mode indicates the mode for performing the relocation, such as “auto” in which relocation is automatically performed, “semi-auto” in which relocation is semi-automatically performed on the basis of the interaction with an administrator, and “manual” in which relocation is performed due to an instruction from an administrator. The evaluation target data type indicates the type of evaluation data that is used to evaluate the relocation target. An example of the evaluation target data type includes “iops” that indicates an IOPS value.
The evaluation reference indicates the reference that is used to evaluate evaluation data specified by the evaluation target data type. Examples of the evaluation reference includes “peak” in which evaluation is performed by using the peak value as the reference and “average” in which evaluation is performed by using the average value as the reference. The evaluation intervals indicate the unit of intervals for evaluating evaluation data. The item of “day” indicates that a unit is a day and the item of “time” indicates that a unit is an hour.
The evaluation period indicates the intervals of evaluation to be performed and a unit thereof is specified by the evaluation intervals. For example, if the evaluation interval is indicated by “day” and if the evaluation period is “7”, evaluation is performed every “7 days”. The evaluation target time zone indicates, by using the start time and the end time, the time zone for the data that is to be evaluated. The evaluation-and-relocation execution time indicates the time at which evaluation and relocation is performed. The relocation stop time indicates the time at which relocation is stopped.
The low level range indicates the range of the IOPS values of data that is to be located in a low performance subpool; the medium level range indicates the range of the IOPS values of data that is to be located in a medium performance subpool; and the high level range indicates the IOPS values of data that is to be located in a high performance subpool.
For example, in a hierarchical policy with the hierarchical policy name of “Policy_Auto—01”, the evaluation is automatically performed by using the IOPS value; the evaluation is performed by taking the peak value as a reference, and the evaluation is performed every “7 days”. The start time of data in the evaluation target time zone is 6:00 and the end time is 20:00. Evaluation and relocation is performed at 1:00 and stops after 24 hours have elapsed. The data with the IOPS value of “100” or less is stored in a low performance subpool; the data with the IOPS value between “101” and “500” is stored in a medium performance subpool, the data with the IOPS value of “501” or more is stored in a high performance subpool.
A description will be given here by referring back to
Furthermore, when a tier pool is created, the pool management unit 43 determines whether one of the disks 6 is specified. If one of the disks 6 is not specified, the pool management unit 43 instructs the storage device 2 via the automated storage tiering unit 32 to create a tier pool with an amount specified by an administrator. Because the pool management unit 43 instructs the storage device 2 to create a tier pool with a specified amount, the administrator can easily create a tier pool without being aware of the installation status of the disks 6.
Furthermore, on the basis of an instruction from the administrator, the pool management unit 43 creates a tier pool constituted by a single subpool and then registers the created tier pool in the pool management table 44. Because the pool management unit 43 registers the hierarchical policy constituted by a single subpool in the pool management table 44, the administrator can acquire the information that is used to compare with a case in which the AST operation is performed.
The pool management table 44 stores therein information on a tier pool registered by the pool management unit 43.
The tier pool name indicates the name that is used to identify a tier pool. The hierarchical policy name indicates a policy used for a tier pool. The device IP address indicates the IP address of the storage device 2 that provides a tier pool. The warning threshold indicates a threshold used to output a warning when a value exceeds the warning threshold and a unit of the warning threshold is %. The attention threshold indicates a threshold for outputting an attention note when a value exceeds the attention threshold and a unit of the attention threshold is %. The encryption indicates whether data stored in a tier pool is to be encrypted. The handling CM number indicates a number used for the CM 21 that handles the management of the tier pool. The handling CM will be described in detail later.
The low performance subpool information indicates information on a low performance subpool included in a tier pool. The medium performance subpool information indicates information on a medium performance subpool included in a tier pool. Furthermore, the high performance subpool information indicates information on a high performance subpool included in a tier pool.
Items of the information on the subpool include the subpool name, the RAID level, disk information, and a handling CM. The subpool name is the name used to identify a subpool. The RAID level indicates the RAID level of a subpool and includes, for example, “RAID5”, “RAID1+0”, or the like. The disk information indicates a RAID group number of disks constituting a subpool and a number used in the group. The handling CM indicates a number used for the CM 21 that handles a subpool.
A description will be given here by referring back to
The analyzing unit 47 analyzes and evaluates the performance information stored in the performance information storing unit 33 and stores the evaluation result in the evaluation result storing unit 34.
The performance information storing unit 33 stores performance information collected at one time in a file named “IOPS-PK_ii_YYYYMMDD@HHMM-yyyymmdd@hhmm.CSV”. In this file, the symbol “ii” indicates the intervals of performance monitoring represented by minutes. Furthermore, “YYYYMMDD” indicates the start date of the acquisition of performance information and “HHMM” indicates the start time of the acquisition of the performance information. Furthermore, “yyyymmdd” indicates the end date of the performance information and “hhmm” indicates the end time of the acquisition of performance information.
The information on “VolNo” is a volume number used to identify a volume. The information on “UpgradeToHigh” indicates a percentage of blocks evaluated to be migrated into a subpool which is a higher level hierarchy and whose tier level is high. The information on “UpgradeToMiddle” indicates a percentage of blocks evaluated to be migrated into a subpool which is a higher level hierarchy and whose tier level is medium. The information on “DowngradeToMiddle” indicates a percentage of blocks evaluated to be migrated into a subpool, which is a lower level hierarchy and whose tier level is medium. The information on “DowngradeToLow” indicates a percentage of blocks evaluated to be migrated into a subpool which is a lower level hierarchy and whose tier level is low.
The information on “KeepLow” indicates a percentage of blocks evaluated not to perform migration and whose tier level is low. The information on “KeepMiddle” indicates a percentage of blocks evaluated not to perform migration and whose tier level is medium. The information on “KeepHigh” indicates a percentage of blocks evaluated not to perform migration and whose tier level is high. The Status is the status of relocation execution of a volume.
Furthermore, the analyzing unit 47 creates, on the basis of the evaluation results, an access list in which blocks are listed in the order the access frequency of a block is high.
The allocating unit 48 allocates, on the basis of the hierarchical policy and information on a volume, the relocation destination for a block and then writes the relocation destination into the access list 55.
The allocating unit 48 includes a policy determining unit 48a, a first allocating unit 48b, a second allocating unit 48c, and a third allocating unit 48d. The policy determining unit 48a determines an allocation method of a block on the basis of information on a hierarchical policy stored in the policy management table 42 and information on a volume. Examples of the allocation method includes allocation performed on the basis of the specified capacity, allocation performed on the basis of the specified percentage, allocation performed on the basis of the specified single subpool, and allocation performed on the basis of the specified IOPS value.
The first allocating unit 48b performs allocation on the basis of the specified capacity. Specifically, the first allocating unit 48b sequentially allocates blocks to subpools, in the order the access frequency of a block is high, by giving priority to a high performance subpool within the capacity of each subpool. Because the first allocating unit 48b performs the allocation on the basis of the specified capacity, the storage system 1 can always use high performance subpool without waste. Furthermore, when any value is not specified in the low level range, in the medium level range, and in the high level range in the policy management table 42, the policy determining unit 48a determines that allocation has been performed on the basis of the specified capacity. The information indicating whether allocation has been performed on the basis of the specified capacity is registered in the policy management table 42 by the policy management unit 41 when the policy management unit 41 creates a hierarchical policy.
The second allocating unit 48c performs allocation on the basis of the specified percentage in volume units. Specifically, on the basis of the specified percentage and the specified access frequency with respect to the specified volume, the second allocating unit 48c allocates blocks to the low performance subpool, the medium performance subpool, and the high performance subpool.
The third allocating unit 48d performs allocation on the basis of the specified IOPS value. Specifically, similarly to the conventional method, the third allocating unit 48d allocates a block to a subpool on the basis of an IOPS value specified by a hierarchical policy.
If only a single subpool is specified, relocation is not performed. An administrator allocates all blocks to a single subpool, thereby obtaining information used to compare with a case in which an AST operation is performed.
The relocation identifying unit 49 creates a relocation list by selecting a block, from the access list 55, in which the relocation source and the relocation destination differ.
The number of blocks registered in the relocation list 56 is 64. When the number of blocks registered in the relocation list 56 becomes 64, the relocation identifying unit 49 requests the relocation instructing unit 50 to relocate the blocks and clears the relocation list 56. Then, the relocation identifying unit 49 repeatedly creates the relocation list 56, requests the relocation, and clears the relocation list 56 until a relocation source and a relocation destination is not present in the access list 55.
Furthermore, for the blocks included in an adjacent subpool with the capacity of 5% in the access list 55, the relocation identifying unit 49 does not use the blocks as the target for the relocation to the adjacent subpool.
In
As described above, for the blocks included in 5% of the capacity of the adjacent subpool in the access list 55, the relocation identifying unit 49 does not use the blocks as the target for the relocation to the adjacent subpool. Consequently, the storage device 2 can prevent less efficient relocation, such as a case in which a block whose IOPS value is similar to that of the block stored in the adjacent subpool is moved to the adjacent subpool. In this example, 5% is used; however, the relocation identifying unit 49 may also use an arbitrary percentage instead of 5%.
On the basis of the request from the relocation identifying unit 49, the relocation instructing unit 50 instructs the automated storage tiering unit 32 to relocate the blocks registered in the relocation list 56. Furthermore, the relocation instructing unit 50 receives information related to the relocation from the automated storage tiering unit 32 and then instructs the operation terminal 4 to display the information related to the relocation.
On the basis of the instruction from the operation terminal 4, the relocation checking unit 51 instructs the automated storage tiering unit 32 to acquire progress information on the relocation. When the progress information is received, the relocation checking unit 51 sends the progress information to the terminal device and instructs the terminal device to display the relocation result.
The communication unit 52 communicates with the automated storage tiering unit 32 and the inter device communicating unit 53 communicates with the operation terminal 4 and the storage device 2 via the LAN 5.
In the following, the functional configuration of the automated storage tiering unit 32 will be described.
On the basis of the instruction from the pool management unit 43, the allocation state checking unit 61 checks with the storage device 2 about the allocation state of the disks 6 and sends, as a response, the information related to the allocation state of the disks 6 to the pool management unit 43.
On the basis of the instruction from the pool management unit 43, the pool creation requesting unit 62 requests the storage device 2 to create a tier pool and sends, as a response, the information related to the created tier pool to the pool management unit 43.
On the basis of the instruction from the volume management unit 45, the volume creation requesting unit 63 requests the storage device 2 to create a volume and sends, as a response, the information related to the created volume to the volume management unit 45.
On the basis of the instruction to start the tiering control received from the operation terminal 4, the start notifying unit 64 notifies the storage device 2 that the tiering control is started. The performance information acquiring unit 65 requests, at intervals of, for example, 5 minutes, the storage device 2 to acquire performance information and acquires the performance information from the storage device 2. Furthermore, the performance information acquiring unit 65 stores the acquired performance information in the performance information storing unit 33. The performance information storing unit 33 accumulates the performance information within an evaluation period specified by a hierarchical policy. The evaluation period mentioned here is, for example, one hour, one day, or the like. For the tier pool for a single tier, the performance information acquiring unit 65 automatically acquires performance information and the performance information storing unit 33 stores the performance information for up to seven days.
On the basis of the instruction about relocation from the relocation instructing unit 50, the relocation requesting unit 66 requests the storage device 2 to perform the relocation; receives information, such as a RAID group at the relocation destination, from the storage device 2; and sends, as a response, to the relocation instructing unit 50.
On the basis of the instruction about the progress check received from the relocation checking unit 51, the progress information acquiring unit 67 requests the storage device 2 to send the progress information on the relocation and sends, to the relocation checking unit 51 as a response, the progress information received from the storage device 2.
The communication unit 68 communicates with the storage management unit 31 and the inter device communicating unit 69 communicates with the storage device 2 and the operation terminal 4 via the LAN 5.
In the following, the functional configuration of the CM 21 will be described.
On the basis of the instruction to check the disk allocation state received from the allocation state checking unit 61, the disk information responding unit 81 sends allocation information on a disk to the allocation state checking unit 61 as a response.
On the basis of the creation request for a tier pool received from the pool creation requesting unit 62, the pool creating unit 82 creates a tier pool and sends the information related to the created tier pool to the pool creation requesting unit 62 as a response.
On the basis of the creation request for a volume received from the volume creation requesting unit 63, the volume creating unit 83 creates a volume and sends the information related to the created volume to the volume creation requesting unit 63 as a response.
On the basis of the acquisition request for the performance information received from the performance information acquiring unit 65, the performance information collecting unit 84 collects the performance information and sends the collected information to the performance information acquiring unit 65. An IOPS value for each block is included in the performance information.
On the basis of the relocation request received from the relocation requesting unit 66, the relocating unit 85 relocates the block specified by the relocation list 56 and sends, to the relocation requesting unit 66 as a response, the information on the target for the relocation. When the blocks are being moved among subpools, the relocating unit 85 reserves a disk space in the move destination from a RAID group handled by the same CM 21 as that handles the volume.
Consequently, when, for example, one of the CMs illustrated in
As described above, because the relocating unit 85 reserves a disk space in the move destination from the RAID group handled by the same CM 21 as that handles the volume, it is possible to suppress the degradation of the IO performance due to the use of different handling CMs 21.
The inter device communicating unit 86 communicates with the operation management device 3 via the LAN 5. For example, the inter device communicating unit 86 receives an instruction from the operation management device 3 and sends a response to the instruction to the operation management device 3.
In the following, the flow of a process performed by the storage system 1 will be described.
Then, the storage system 1 creates a tier pool on the basis of the instruction from the administrator and then registers the created tier pool in the pool management table 44 (Step S92). Then, the storage system 1 creates a volume on the basis of an instruction from the administrator and registers the volume in the volume management table 46 (Step S93).
Thereafter, business software running on the server 7 starts a business process by using the volume. Then, the storage system 1 starts the tiering control on the basis of an instruction from the administrator and then collects the performance information (Step S94).
Then, the storage system 1 executes the relocation of blocks on the basis of information on the volume, the hierarchical policy, and the performance information (Step S95). The processes at Steps S94 and S95 are executed on the basis of the hierarchical policy during the business process. When a request is received from the administrator, the storage system 1 checks the progress status of the relocation and then displays the relocation result (Step S96).
As described above, by relocating blocks on the basis of the volume information, the hierarchical policy, and the performance information, the storage system 1 can improve the IO performance.
In the following, the flow of a policy registration process will be described.
As illustrated in
As described above, by specifying a hierarchical policy, the administrator can efficiently use the storage system 1.
In the following, the flow of a tier pool registration process will be described.
As illustrated in
Then, the storage management unit 31 determines whether the handling CM 21 is specified (Step S7). If the determination result indicates that the handling CM 21 is specified, the storage management unit 31 sets the specified handling CM 21 to instruction information (Step S8). In contrast, if the handling CM 21 is not specified, the storage management unit 31 sets, to the instruction information, “Auto” indicating that the handling CM 21 can be automatically selected (Step S9).
Then, the storage management unit 31 determines whether a disk has been specified (Step S10). If a disk has not been specified, the storage management unit 31 sets the automatic disk selection to the instruction information (Step S11). Then, the storage management unit 31 sends an instruction to create a tier pool to the automated storage tiering unit 32 together with the instruction information (Step S12).
In contrast, if a disk has been specified, the storage management unit 31 sends an instruction to check a free space of the disk to the automated storage tiering unit 32 (Step S13) and the automated storage tiering unit 32 instructs the storage device 2 to check the disk allocation state (Step S14). Then, the storage device 2 sends, as a reply, the disk information related to the disk allocation state (Step S15) and the automated storage tiering unit 32 sends the disk information to the storage management unit 31. Then, the storage management unit 31 checks the specifying of the disk (Step S16) and instructs to the operation terminal 4 to display the information on the selected target disk. Then, the operation terminal 4 displays the information on the target disk and allows the administrator to select a disk (Step S17). Then, the storage management unit 31 specifies the selected target disk (Step S18) and sends, to the automated storage tiering unit 32, the instruction to create a tier pool together with the instruction information (Step S19).
When the instruction to create a tier pool is received together with the instruction information, the automated storage tiering unit 32 requests the storage device 2 to create a tier pool (Step S20) and then the storage device 2 creates a tier pool (Step S21). Then, the storage device 2 sends the information on the created tier pool to the automated storage tiering unit 32. The automated storage tiering unit 32 sends the information on the tier pool to the storage management unit 31. Then, the storage management unit 31 registers, by using the information on the tier pool, the tier pool in the pool management table 44 (Step S22) and instructs the operation terminal 4 to display the information on the tier pool. Then, the operation terminal 4 displays the information on the tier pool (Step S23).
As described above, if a disk is not specified, the storage management unit 31 sets the automatic disk selection in the instruction information and instructs to create a tier pool together with the instruction information. Consequently, an administrator can easily create a tier pool.
In the following, the flow of a volume creating process will be described.
As illustrated in
Then, the storage device 2 creates a volume (Step S28) and sends the information on the created volume to the automated storage tiering unit 32. The automated storage tiering unit 32 sends the information on the volume to the storage management unit 31.
Then, the storage management unit 31 registers the information on the volume in the volume management table 46 (Step S29) and instructs the operation terminal 4 to display the information on the volume. Then, the operation terminal 4 displays the information on the volume (Step S30).
As described above, the storage management unit 31 acquires the information on the target tier pool from the pool management table 44 and instructs to create a volume together with the information on the target tier pool, thereby it is possible to create a volume on the basis of a hierarchical policy.
In the following, the flow of a performance information collecting process will be described.
As illustrated in
Then, the automated storage tiering unit 32 requests the storage device 2 to acquire performance information (Step S34) and the storage device 2 sends, as a reply, the collected performance information (Step S35). Then, the automated storage tiering unit 32 stores the performance information in the performance information storing unit 33 (Step S36). The processes at Steps S34 to S36 are periodically performed at intervals of, for example, 5 minutes.
As described above, because the automated storage tiering unit 32 stores, in the performance information storing unit 33, the performance information received from the storage device 2, the storage management unit 31 can allocate a block to each subpool by referring to the performance information storing unit 33.
In the following, the flow of a relocation process will be described.
As illustrated in
In contrast, if the allocation is not to be performed on the basis of the specified percentage, the storage management unit 31 refers to the performance information storing unit 33, sorts the blocks in the tier pool in the order of IOPS values, and creates the access list 55 (Step S43). Then, the storage management unit 31 determines whether allocation is to be performed on the basis of specifying the capacity (Step S44). If the allocation is to be performed on the basis of the specified capacity, the storage management unit 31 calculates the number of blocks that can be located by using a free space in each subpool as a reference (Step S45) and proceeds to Step S48. In contrast, if the allocation is not to be performed on the basis of the specified capacity, the storage management unit 31 identifies a relocation target block by using the IOPS value as a reference (Step S46) and checks the free space in order to determine whether the target block can be relocated (Step S47).
Then, the storage management unit 31 determines a relocation target block and information on the subpool of the relocation destination (Step S48) and then determines the relocation target on the basis of the determined information (Step S49). Then, the storage management unit 31 creates the relocation list 56 (Step S50) and instructs the automated storage tiering unit 32 to perform relocation. Thereafter, the automated storage tiering unit 32 requests the storage device 2 to perform relocation (Step S51).
Then, the CM 21 in the storage device 2 checks the CM 21 that handles the volume to be relocated (Step S52) and checks the subpool of the relocation destination (Step S53). Then, the storage device 2 determines whether a RAID group belonging to the same CM 21 that handles the volume is present in the subpool (Step S54).
If the determination result indicates that a RAID group belonging to the same CM 21 that handles the volume is not present in the subpool, the storage device 2 searches the subpool for a RAID group with the smallest allocation percentage (Step S55) and proceeds to Step S58. In contrast, a RAID group belonging to the same CM 21 that handles the volume is present in the subpool, the storage device 2 extracts RAID groups belonging to the same CM 21 that handles the volume (Step S56) and searches the extracted RAID groups for a RAID group with the smallest allocation percentage (Step S57).
Then, the storage device 2 determines that the obtained RAID group is the RAID group of the move destination (Step S58); sends, to the operation management device 3, information on the RAID group of the move destination; and moves the data to the determined RAID group (Step S59).
Furthermore, the storage management unit 31 notifies the operation terminal 4 of information on the relocation target (Step S60) and then the operation terminal 4 displays the information on the relocation target (Step S61). If the number of blocks to be relocated exceeds 64, the processes at Steps S50 to S61 are repeated for every 64 blocks. Furthermore, the relocation process is repeated on the basis of the specified hierarchical policy.
As described above, by determining the relocation target on the basis of a hierarchical policy, the storage system 1 can control relocation of a block on the basis of the policy received from an administrator.
In the following, the flow of a relocation result displaying process will be described.
As illustrated in
Then, the automated storage tiering unit 32 requests the storage device 2 to acquire the information on the relocation (Step S64) and the storage device 2 sends, to the operation management device 3 as a reply, the progress information on the relocation (Step S65). Then, the storage management unit 31 notifies the operation terminal 4 of the status of the relocation (Step S66) and the operation terminal 4 displays the relocation result (Step S67).
In this way, because the operation terminal 4 displays the relocation result, an administrator can evaluate the relocation on the basis of a hierarchical policy and volume information.
As described above, in the embodiment, the policy determining unit 48a determines an allocation method of blocks on the basis of the information on hierarchical policies stored in the policy management table 42 and the information on volumes stored in the volume management table 46. Then, on the basis of the determination performed by the policy determining unit 48a, the first allocating unit 48b performs allocation on the basis of the specified capacity. Consequently, the storage system 1 can efficiently use a high performance storage from among multiple storages each having different performance. Furthermore, on the basis of the determination performed by the policy determining unit 48a, the second allocating unit 48c performs allocation on the basis of the specified percentage for each volume. Consequently, an administrator can appropriately use a subpool for each volume and can create a tier pool suitable for business.
Furthermore, in the embodiment, on the basis of an instruction from an administrator, the pool management unit 43 creates a tier pool constituted by a single subpool and registers the created tier pool in the pool management table 44. Then, the performance information acquiring unit 65 automatically acquires the performance information on the tier pool constituted by a single subpool. Consequently, the administrator can acquire the information used to compare with a case in which the AST operation is performed.
Furthermore, in the embodiment, the CM 21 determines a RAID group of the relocation destination from the RAID group handled by the same CM 21 as that handles the volume to be relocated. Consequently, it is possible to suppress the degradation of the IO performance due to the use of the CM 21 handling a volume that is different from the CM 21 handling a RAID group.
Furthermore, in the embodiment, when the pool management unit 43 creates a tier pool, if one of the disks 6 is not specified, the pool management unit 43 instructs the storage device 2 to create a tier pool with the capacity specified by an administrator. Consequently, the administrator can easily create a tier pool without being aware of the installation status of the disks 6.
Furthermore, in the embodiment, for the blocks included in an adjacent subpool with the capacity of 5% in the access list 55, the relocation identifying unit 49 does not use the blocks as the target for the relocation to the adjacent subpool. Consequently, the storage device 2 can prevent less efficient relocation, such as a case in which a block whose IOPS value is similar to that of the block stored in the adjacent subpool is moved to the adjacent subpool.
Furthermore, in the embodiment, a description has been given of the operation management device; however, it is possible to obtain an operation management program having the same function as that performed by the operation management device described in the embodiment by implementing the configuration of the operation management device described in the embodiment by using software. And so, a computer that executes an operation management program will be described.
The main memory 210 is a memory that stores therein a program or the mid-result of a running program. The CPU 220 is a central processing unit that reads a program from the main memory 210 and executes the program. The CPU 220 includes a chip set including a memory controller.
The LAN interface 230 is an interface for connecting the computer 200 to another computer via a LAN. The HDD 240 is a disk device that stores therein a program or data. The super IO 250 is an interface for connecting an input device, such as a mouse or a keyboard. The DVI 260 is an interface for connecting a liquid crystal display device. The ODD 270 is a device that reads and writes a DVD.
The LAN interface 230 is connected to the CPU 220 by a PCI express (PCIe). The HDD 240 and the ODD 270 is connected to the CPU 220 by the serial advanced technology attachment (SATA). The super IO 250 is connected to the CPU 220 by the low pin count (LPC).
Then, the operation management program executed by the computer 200 is stored in the DVD, is read by the ODD 270 from the DVD, and is installed in the computer 200. Alternatively, the operation management program is stored in databases in another computer system that is connected via the LAN interface 230, is read from these databases, and is installed in the computer 200. Then, the installed operation management program is stored in the HDD 240, is read by the main memory 210, and is executed by the CPU 220.
In the following, a description will be given of the hardware configuration of the CM 21.
The CPU 21a is a processing unit that reads a program from the flash memory 21c and executes the program. The random access memory (RAM) 21b is a volatile memory that stores therein data. The flash memory 21c is a memory that stores therein a program used to implement the function performed by the CM 21 illustrated in
In the embodiment, a description has been given of the storage system 1 that includes the storage device 2 and the operation management device 3; however, the present invention is not limited thereto. For example, the present invention may be similarly applied to a storage system in which the function performed by the operation management device 3 is included in the storage device.
Furthermore, in the embodiment, a description has been given of a case in which a tier pool includes three subpools; however, the present invention is not limited thereto. For example, the present invention may be applied to a tier pool that includes more than 3 subpools.
Furthermore, in the embodiment, a description has been given of a case in which a HDD and an SSD are used as a disk; however, the present invention is not limited thereto. For example, the present invention may be applied in a case in which another storage is used as a disk.
According to an aspect of an embodiment of the present invention, an advantage is provided in that, from among multiple storages each having different performance, a high performance storage can be efficiently used.
All examples and conditional language recited herein are intended for pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiment of the present invention has been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2013-124158 | Jun 2013 | JP | national |