WO2012081074A1 - 計算機システム、及びその管理方法、並びに、プログラム - Google Patents
計算機システム、及びその管理方法、並びに、プログラム Download PDFInfo
- Publication number
- WO2012081074A1 WO2012081074A1 PCT/JP2010/072377 JP2010072377W WO2012081074A1 WO 2012081074 A1 WO2012081074 A1 WO 2012081074A1 JP 2010072377 W JP2010072377 W JP 2010072377W WO 2012081074 A1 WO2012081074 A1 WO 2012081074A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- application
- virtual volume
- capacity
- allocated
- information
- Prior art date
Links
- 238000007726 management method Methods 0.000 title claims description 147
- 238000003860 storage Methods 0.000 claims abstract description 166
- 230000008859 change Effects 0.000 claims abstract description 25
- 238000000034 method Methods 0.000 claims description 70
- 238000012545 processing Methods 0.000 claims description 58
- 230000008569 process Effects 0.000 claims description 55
- 230000004044 response Effects 0.000 claims description 9
- 238000005516 engineering process Methods 0.000 abstract description 5
- 238000012544 monitoring process Methods 0.000 abstract description 4
- 238000004364 calculation method Methods 0.000 description 14
- 238000012217 deletion Methods 0.000 description 14
- 230000037430 deletion Effects 0.000 description 14
- 238000013508 migration Methods 0.000 description 14
- 230000005012 migration Effects 0.000 description 14
- 238000013507 mapping Methods 0.000 description 12
- 230000008707 rearrangement Effects 0.000 description 12
- 238000010586 diagram Methods 0.000 description 10
- 230000006870 function Effects 0.000 description 8
- 238000013500 data storage Methods 0.000 description 5
- 238000007796 conventional method Methods 0.000 description 4
- 230000014509 gene expression Effects 0.000 description 4
- 239000000470 constituent Substances 0.000 description 3
- 238000007476 Maximum Likelihood Methods 0.000 description 2
- BNPSSFBOAGDEEL-UHFFFAOYSA-N albuterol sulfate Chemical compound OS(O)(=O)=O.CC(C)(C)NCC(O)C1=CC=C(O)C(CO)=C1.CC(C)(C)NCC(O)C1=CC=C(O)C(CO)=C1 BNPSSFBOAGDEEL-UHFFFAOYSA-N 0.000 description 2
- 238000004891 communication Methods 0.000 description 2
- 230000004913 activation Effects 0.000 description 1
- 230000002776 aggregation Effects 0.000 description 1
- 238000004220 aggregation Methods 0.000 description 1
- 238000013480 data collection Methods 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000010365 information processing Effects 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 239000002699 waste material Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0604—Improving or facilitating administration, e.g. storage management
- G06F3/0607—Improving or facilitating administration, e.g. storage management by facilitating the process of upgrading existing storage systems, e.g. for improving compatibility between host and storage device
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/0644—Management of space entities, e.g. partitions, extents, pools
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0653—Monitoring storage devices or systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0662—Virtualisation aspects
- G06F3/0665—Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/067—Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0689—Disk arrays, e.g. RAID, JBOD
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2206/00—Indexing scheme related to dedicated interfaces for computers
- G06F2206/10—Indexing scheme related to storage interfaces for computers, indexing schema related to group G06F3/06
- G06F2206/1008—Graphical user interface [GUI]
Definitions
- the present invention relates to a computer system, a management method thereof, and a program, for example, to a technique for grasping the capacity of a storage pool composed of a plurality of storage areas of one or more media (storage devices).
- Thin Provisioning has been attracting attention as a technology to reduce storage management costs.
- Thin Provisioning is a technology in which a storage allocates a virtual volume to a host and allocates a disk capacity in the storage to the virtual volume dynamically and in stages according to an I / O request from the host.
- the disks can be increased in stages based on the storage usage status (specifically, the used disk size) of the host without purchasing the disks in advance for all the volumes allocated to the host.
- a pool composed of multiple disks is built inside the storage, a virtual volume assigned to the host is created from this pool, and I / O requests to the virtual volume from the host computer are made.
- Thin Provisioning has been expanded to create a pool with a combination of disks with different physical characteristics (for example, SSD and SATA disk), and data with high I / O frequency is placed on a high-speed disk (for example, SSD). Can be placed on a low speed disk (eg, SATA). In this case, it is necessary to monitor the free capacity of the pool as in the case of Thin Provisioning.
- a high-speed disk for example, SSD
- SATA low speed disk
- the conventional method does not take into account changes in the external environment. In other words, since the conventional method predicts the future consumption trend based only on the capacity consumption trend of the past pool, it cannot predict the change in the pool capacity consumption trend due to the configuration change such as volume allocation from the existing pool to the new application. .
- the present invention has been made in view of such circumstances, and a pool that can appropriately predict the timing of pool capacity depletion even when there is a change in the external environment such as addition of a new application or change in characteristics of an existing application. It provides capacity monitoring technology.
- the consumption of each medium that makes up the pool is predicted, and the prediction of the capacity depletion timing is re-established. calculate.
- the I / O consumption tendency for each application using the virtual volume is calculated for each medium from the past consumption tendency stored in the storage.
- the computer system has a storage subsystem that provides a storage area of one or more physical storage devices as a virtual volume to a host computer, and a management computer that manages the storage subsystem. Then, in response to the input instruction regarding the allocation of the virtual volume to be used by the application, the management computer acquires information on the past consumption volume trend of the virtual volume used by the application whose application type is the same or similar. Based on the information on the consumption capacity trend, the consumption capacity in the virtual volume to be allocated is predicted.
- the pool capacity depletion timing can be appropriately predicted even when there is a change in the external environment such as addition of a new application or change in characteristics of an existing application.
- FIG. 1 It is a figure which shows schematic structure of the computer system by embodiment of this invention. It is a figure which shows the internal structure of a host computer. It is a figure which shows the internal structure of a storage subsystem. It is a figure which shows the structural example of a RAID group management table. It is a figure which shows the structural example of a real area management table. It is a figure which shows the structural example of a virtual volume (VVOL) management table. It is a figure which shows the structural example of a hierarchy definition table. It is a figure which shows the structural example of a pool-virtual volume (VVOL) correspondence management table. It is a figure which shows the internal structure of a management computer.
- VVOL virtual volume management table
- aaa table the information does not necessarily have to be expressed by a data structure of a table, and data structures such as lists, DBs, queues, etc. It may be expressed in other ways. Therefore, “aaa table”, “aaa list”, “aaaDB”, “aaa queue”, etc. may be referred to as “aaa information” to indicate that they are not dependent on the data structure.
- program “engine”, and “agent” will be described as the subject, but the program and the like are executed by the processor to perform processing determined by using the memory and the communication port (communication control device). The description may be based on the processor. Further, the processing disclosed with the program as the subject may be processing performed by a computer such as a management server or an information processing apparatus. Part or all of the program may be realized by dedicated hardware, or may be modularized. Various programs may be installed in each computer by a program distribution server or a storage medium.
- FIG. 1 is a diagram showing a schematic configuration of a computer system 100 according to an embodiment of the present invention.
- the computer system 100 includes a host computer 101, a storage subsystem 102, and a management system 107.
- the storage subsystem 102 and the host computer 101 are connected by a storage area network 105.
- the management system 107, the storage subsystem 102, and the host computer 101 are connected by a management network 106.
- the management system 107 includes a management computer 103 and a Web browsing computer 104.
- the management computer 103 and the Web browsing computer 104 may be the same computer, or a plurality of computers may each realize an equivalent function.
- the management system 107 transmits a control request to the storage subsystem 102 via the management network 106.
- the host computer 101 transmits an access request to the management system 107 via the management network 106.
- the storage subsystem 102 receives a control request from the management system 107 via the management network 106, and executes processing according to the request.
- a plurality of host computers 101, storage subsystems 102, and management systems 107 included in the computer system 100 may be installed.
- FIG. 2 is a diagram showing an internal configuration of the host computer 101.
- the host computer 101 includes a SAN port 203 for realizing connection with the storage area network 105, a LAN port 205 for realizing connection with the management network 106, a memory 202, a memory 202 and a SAN port 203, And a CPU 201 connected to the LAN port 205.
- the SAN port 203 is connected to the storage area network 105.
- the LAN port is connected to the management network 106.
- the memory 202 stores one or more application programs 204. Each application program 204 is executed by the CPU 201 and transmits an access request to the storage subsystem 102 via the LAN port 205 and the management network 105.
- FIG. 3 is a diagram showing an internal configuration of the storage subsystem 102.
- the storage subsystem 102 includes a plurality of physical storage devices 305 having different physical characteristics such as disk rotation speed, and a controller 312, which are connected to each other via a circuit such as an internal bus.
- a plurality of physical storage devices 305 of the same type they may have a RAID configuration.
- a plurality of physical storage devices 305 having a RAID configuration constitute a RAID group 306.
- the controller 312 includes at least one SAN port 302 for connection to the storage area network 105, at least one LAN port 303 for connection to the management network 106, a memory 304, and a CPU 301 connected thereto.
- the SAN port 302 is a port connected to the storage area network 105.
- the SAN port 302 receives an access request from the host computer 101.
- the LAN port 303 is a port connected to the management network 106.
- the LAN port 303 receives a control request from the management system 107.
- the memory 304 includes a storage control program 307, a RAID group management table 308, a real area management table 309, a hierarchy management table 310, a VVOL management table 311, a storage information acquisition agent 313, and a pool-virtual volume correspondence management table. 314 are stored.
- the storage information acquisition agent 313 is a program that acquires, from the storage subsystem 102, information on the allocated capacity for each Tier for each VOL from the controller 312 in the storage subsystem 102. Information to be acquired will be described later.
- the storage control program 307 is executed by the CPU 301 to perform an access control process, a data write process, and a rearrangement process that allow access to a virtual volume, which will be described later, only for the specified management system 107.
- the storage control program 307 executes data write processing as follows. That is, first, when the storage control program 307 receives a data write request from the host computer 101, the storage control program 307 specifies a virtual area to which data is written (hereinafter, write destination virtual area) based on the access destination information included in the data write request. To do.
- write destination virtual area a virtual area to which data is written
- the storage control program 307 determines whether a real area is allocated to the write destination virtual area. Specifically, it is determined whether or not the write destination virtual area is registered in the VVOL management table 311.
- the storage control program 307 When the real area is assigned to the write destination virtual area, the storage control program 307 writes the write target data to the real area assigned to the write destination virtual area. When the real area is not assigned to the write destination virtual area, the storage control program 307 determines whether there is an unallocated real area assigned to the write destination virtual area. Specifically, the storage control program 307 determines whether there is a real area whose allocation status 504 in the real area management table 309 is “unallocated”.
- the storage control program 307 allocates an unallocated real area to the write destination virtual area and writes the write target data in the real area.
- the storage control program 307 sends an error to the host computer 101.
- the storage control program 307 determines whether the write destination virtual area is a component of the pool. If the pool components match, the value of the set of pool ID 2302 that is the identifier of the pool and VVOL ID 2301 that is the identifier of the virtual volume is written in the correspondence management table 2301 between the pool and the virtual volume.
- the storage control program 307 updates the value of the access count 604 corresponding to the write source virtual area.
- the storage control program 307 constructs a RAID group from a plurality of physical storage devices as shown in FIG. 4 described later.
- the storage control program 307 allocates a virtual volume designated by the host computer 101
- the storage control program 307 does not allocate a physical disk corresponding to the volume size to the host computer 101, but dynamically allocates a physical disk according to the volume usage status. Assign.
- this volume is referred to as a virtual volume (also referred to as “VVOL”).
- the storage control program 307 first divides each RAID group into a fixed size (for example, 1000 blocks). Hereinafter, the divided unit is referred to as a segment. Further, as shown in FIG. 5 described later, the storage control program 307 grasps the allocation status of each segment, and uses an unallocated segment when allocating a new segment to a certain virtual volume.
- the relocation process executed by the storage control program 307 will be described later.
- FIG. 4 is a diagram showing a configuration example of the RAID group management table 308 that the storage subsystem 102 has.
- the RAID group management table 308 has information regarding the performance of the RAID group 306.
- the RAID group management table includes a RAID group ID 401 that represents an identifier of the RAID group, a device type 402 that represents the type of the physical storage device that constitutes the RAID group, a RAID level 403 that represents the RAID level and combination of the RAID group, A PDEV_ID 404 representing an identifier of a physical storage device constituting the RAID group is included as a configuration item. Note that other types of information may be included instead of or in addition to at least one of the information 401 to 404.
- FIG. 5 is a diagram illustrating a configuration example of the real area management table 309 included in the storage subsystem 102.
- the real area management table 309 includes information on whether or not the real area of each RAID group 306 has been allocated to the virtual volume.
- the real area management table 309 includes a RAID group ID 501 that represents an identifier of a RAID group having a real area, a real area ID 502 that represents an identifier of the real area, and an RG_LBA range 503 that represents the LBA range of the RAID group corresponding to the real area. And an allocation status 504 indicating whether or not the real area has been allocated as a configuration item.
- FIG. 6 is a diagram illustrating a configuration example of the VVOL management table 311 included in the storage subsystem 102.
- the VVOL management table 311 has information regarding each virtual area in the virtual volume and a real area allocated to the virtual area.
- the VVOL management table 311 includes a VVOL ID 601 indicating a virtual volume identifier, a VVOL LBA range 602 indicating an LBA range corresponding to the virtual area in the virtual volume, and a real area allocated to the virtual area in the virtual volume.
- a real area ID 603 representing the number of accesses
- a number of accesses 604 representing the number of accesses from the host computer 101 to the virtual area in the virtual volume (the total number of I / Os within a certain period)
- a rearrangement process described later (FIG. 17).
- a relocation determination result 605 representing an identifier of the hierarchy determined to be allocated to the virtual area in the virtual volume is included as a configuration item.
- VVOL_ID 601 is not an identifier specified by the host computer 101 but information indicating an identifier recognized inside the storage subsystem 102.
- the access number 604 has a value of the number of accesses to the virtual area, and the storage subsystem 102 resets the value of the access number 604 to 0 every certain period, for example, 24 hours.
- the rearrangement determination result 605 stores the result of the storage control program 307 monitoring the allowable access number of Tier and determining based on the value of the allowable access number range 703 of the hierarchy management table 310 shown in FIG.
- the rearrangement determination result 605 in FIG. 6 is after the rearrangement determination is performed, the determination result information in a state where the rearrangement process is not performed is illustrated. Therefore, it should be noted that the hierarchy information indicated by the relocation determination result 605 does not match the hierarchy to which the device to which the area indicated by the real area ID 603 belongs belongs. Immediately after the rearrangement process is executed, the information of the two matches.
- FIG. 7 is a diagram showing a configuration example of the tier definition table 310 that the storage subsystem 102 has.
- the hierarchy definition table 310 has information regarding the performance of the hierarchy and the range of the permitted number of accesses.
- the tier definition table 310 includes, for each tier, a tier ID 701 that represents a tier identifier, a performance requirement 702 that represents a tier performance requirement, and an allowable IOPS that represents a range of permissible access count per unit time corresponding to the tier.
- a range 703 is included as a configuration item.
- the tier performance requirement 702 is defined by, for example, the type of physical storage device and the RAID level of the RAID group.
- Each tier 701 identified by a tier ID has a physical storage device or / and a real area belonging to a RAID group that satisfies the performance requirement 702 as an element.
- the tier definition table 310 is set in the tier management table 310 of the memory 304 of the LAN port 303 of the storage subsystem 102 via the management network in response to a request from the management computer 103 or the host computer 101.
- FIG. 8 is a diagram showing a configuration example of a pool-virtual volume (VVOL) correspondence management table 314 that manages the correspondence between pools and virtual volumes.
- VVOL pool-virtual volume
- the pool-virtual volume correspondence management table 314 includes a pool ID 3141 and a VVOL_ID 3142 as configuration items.
- the pool-virtual volume correspondence management table 314 shows which virtual volume each pool is composed of.
- the pool A is composed of virtual volumes (VVOL) A and B. This information is acquired by the storage control program 307 and used for necessary processing.
- VVOL virtual volumes
- FIG. 9 is a block diagram showing the internal configuration of the management computer 103.
- the management computer 103 has a LAN port 802 for connecting to the management network 106, a CPU 801 for executing the configuration management program 804, and a memory 803 used by the CPU 801, which are mutually connected via a circuit such as an internal bus. It is connected to the.
- the memory 803 includes an application information acquisition engine 804, a pool capacity prediction engine 805, a page allocation prediction engine 806 for a new VOL, a page allocation prediction engine 807 for an existing VOL, a result display engine 808, and a Tier definition.
- An acquisition engine 809 and a storage information acquisition engine 810 are stored.
- “engine” means a program that issues a request and acquires desired information, and may be read as “program” unless otherwise specified.
- the management computer 103 also has a storage device 811, a display device 813, and an input device 814.
- the storage device 811 has a data storage DB 812.
- a keyboard and a pointer device can be considered as examples of the input device 400 included in the management computer 50, but other devices may be used. Further, instead of or in addition to the display device 401, another output device (for example, a printer) may be provided.
- a serial interface or an Ethernet interface is used as an input / output device
- a display computer having a display, a keyboard, or a pointer device is connected to the interface, and display information is used as a display computer.
- the input and display on the input / output device may be substituted by transmitting or receiving input information from the display computer to display on the display computer or accepting input.
- a set of one or more computers that manage the computer system 100 and display the display information of the present invention may be referred to as a management system.
- the management computer 103 displays the display information
- the management computer 103 is the management system 107
- the combination of the management computer 103 and the Web browsing computer (display computer) 104 is also the management system 107.
- a plurality of computers may realize processing equivalent to that of the management computer.
- the plurality of computers (if the display computer performs the display, display
- the management system 107 includes a computer.
- the application information acquisition engine 804 acquires the correspondence relationship between the VOL scheduled to be assigned by the user input on the application information input screen 1301 (see FIG. 14) and the application, and the storage device 811 of the management computer 103. Are stored in the application / volume mapping table 901 existing in the data storage DB.
- the mapping table 901 is included in the data storage DB 812.
- the application information acquisition engine 804 acquires information on a newly added application name, application type, and virtual volume input from the input screen 1301, and stores them in the mapping table 901 (see FIG. 10).
- the mapping table 901 includes an application name 902, an application type 903, and a virtual VOL_ID 904 as configuration items. By checking this table, it is possible to grasp what application is assigned to which virtual volume.
- a volume (VOL) to be allocated may be allocated to the host computer 101 by extending the processing of the application information acquisition engine 804.
- a VOL may be assigned immediately after an assignment instruction is input from the user, or a reservation may be made such that a VOL scheduled to be assigned is assigned after a designated period instructed by the user.
- Tier Definition Acquisition Engine 809 acquires information input by the user using the hierarchy management table setting screen 1401 (see FIG. 15), and the LAN port 802 of the management computer 103, the management network 106, The data is stored in the hierarchy management table 310 in the memory 304 of the storage subsystem 102 via the LAN port 303 of the storage subsystem 102.
- the Tier definition acquisition engine 809 cooperates with the storage control program 307 of the storage subsystem 102, for example, with respect to the hierarchy management table 310, the hierarchy ID 1402 is changed to the hierarchy ID 701, the device type 1403 and the RAID level. 1404 is stored in the performance requirement 702, and the allowable access number range 1405 is stored in the allowable access number range 703.
- the storage information acquisition engine 810 is periodically executed by the CPU 801 of the management computer 103. At the time of execution, the storage information acquisition engine 810 acquires the allocated capacity for each Tier for each VVOL from the storage information acquisition agent 313 in the memory 304 of the storage subsystem 102. The storage information acquisition engine 810 stores the acquired information in the virtual volume capacity information table 1001 in the data storage DB 812 via the LAN port 303, the management network 106, the LAN port 802, and the storage device 811.
- the storage information acquisition engine 810 stores the VVOL_ID 601 of the VOL management table 311 in the VVOLID 1004 of the virtual volume capacity information table 1001.
- the storage information acquisition engine 810 stores the VVOL total capacity in the VVOL capacity 1005, information on each VVOL Tier usage amount in the Tier 1 usage amount 1006, Tier 2 usage amount 1007, and Tier 3 usage amount 1008, and the time of data collection. Stored in the collection time 1002 respectively.
- the storage information acquisition engine 810 acquires the pool name to which the VVOL belongs from the pool ID 3141 of the pool-virtual volume correspondence management table 314 and stores it in the pool ID 1003.
- the pool capacity prediction engine 805 is an engine that predicts the capacity of a pool after adding an application and VVOL, or assigning a page to an existing VVOL, and increasing. Specifically, the page allocation prediction engine 806 for the new VOL and the page allocation prediction engine 807 for the existing VOL are activated, and the page allocation prediction engine 806 for the new VOL and the page allocation prediction engine for the existing VOL are started. The values calculated in 807 are summed, and the result is stored in the pool capacity prediction table 1101 (see FIG. 12). In this embodiment, capacity prediction is performed for each Tier instead of conventional capacity prediction in units of Pools.
- (V) Page Allocation Prediction Engine to New VOL Page Allocation Prediction Engine 806 to New VOL has been introduced in the past from the information of application name 1307, application type 1308, and prediction period 1309 on the application information input screen 1301.
- Information on applications that are the same, the same type, or similar in consumption trend of volumes used by applications (hereinafter referred to as “similar applications”) is specified from the application-volume mapping table 901.
- the page allocation prediction engine 806 for the new VOL acquires from the virtual volume capacity information table 1001 the capacity consumption trend of the past VVOL for the period specified in the measurement period 1309 from the beginning of introduction.
- the page allocation prediction engine 806 for the new VOL calculates the usage rate of each tier from the VVOL capacity consumption tendency of the similar application and returns the calculated value to the pool capacity prediction engine 805.
- a method for calculating the utilization rate of each Tier will be described later with reference to FIG.
- the Page Allocation Prediction Engine 807 for the existing VOL for each pool managed by the storage subsystem 102, records history information on the number of allocated pages for each tier, as virtual volume capacity information
- the pool capacity consumption after the prediction period 1309 specified on the application information input screen 1301 is predicted using the maximum likelihood estimation method (for example, the least square method).
- the predicted calculation result is returned to the pool capacity prediction engine 805. The calculation method will be described later with reference to FIGS.
- (Vii) Result Display Engine As the result display engine 808, the pool capacity prediction engine is activated. Data is acquired from the pool capacity prediction table 1101, and a pool capacity prediction result report screen 1501 is output to the display device 813.
- the storage subsystem 102 periodically collects pool and virtual volume configuration information and capacity information provided by the storage subsystem 102, and inputs for performing tier management specified by the user. And a process of rearranging the Tier based on the information.
- Pool is composed of multiple levels.
- a hierarchy is a set of real areas having the same performance.
- the hierarchy is defined by, for example, a specific value representing performance, and includes a real area having the same performance as the performance represented by that value.
- the hierarchy has a high and low concept compared to other hierarchies.
- the height of the hierarchy depends on the high performance of the hierarchy.
- the “performance” referred to here is, for example, access performance, and includes response time, data transfer speed, IOPS (number of access requests processed per unit time), and the like.
- An example of the access request is a write request or a read request.
- Each layer consists of two or more real areas. Therefore, it can be said that the pool is composed of a plurality of real areas.
- the real area is a part of the storage area of the physical storage device and / or RAID group.
- the performance of the hierarchy depends on the performance of the real area constituting the hierarchy.
- the performance of the real area depends on, for example, the type of physical storage device having the real area, the RAID level of the RAID group, and / or the number of storage devices participating in the RAID group. Examples of physical storage device types include SSD, SAS-HDD, and SATA-HDD.
- the virtual volume is composed of a plurality of virtual areas (virtual storage areas). One or less real area is allocated to each virtual area. Note that a real area may not be assigned to a virtual area.
- the storage subsystem 102 receives a write request for such a virtual area (unallocated virtual area) from the host computer, the storage subsystem 102 assigns a real area (unallocated real area) that is not allocated to any virtual area, Allocate to the virtual area.
- the management computer 103 predicts the capacity consumption trend of the VVOL used by the application based on the information of the application to be added specified by the user and the information of the VVOL, and executes a process of reporting (outputting) the prediction result. .
- FIG. 13 is a diagram for explaining an overall outline of processing in the present system.
- the pool prediction engine 806 activates the page allocation prediction engine 806 for the new VOL and the page allocation prediction engine 807 for the existing VOL. Both engines 896 and 807 execute their respective processes, and provide execution results to the pool capacity prediction engine 805.
- the pool capacity prediction engine 805 that has received the execution result stores the pool capacity prediction result in the pool capacity prediction table 1101 and activates the result display engine 808.
- the activated result display engine 808 acquires a corresponding pool capacity prediction result from the pool capacity prediction table 1101 and displays it on the pool capacity prediction result report screen 1501 (see FIG. 16).
- the storage information acquisition engine 810 periodically polls the data in the storage subsystem 102 to acquire the capacity of each virtual volume, and stores the capacity information in the virtual volume capacity information table 1001. (See FIG. 11).
- the management computer 103 periodically instructs the storage subsystem 102 to execute the Tier relocation processing periodically. For example, the allocation status of the real area to the virtual area in the virtual volume is reviewed every hour or 30 minutes.
- the management computer 103 determines, for each virtual area in the virtual volume, whether the number of accesses to the virtual area exceeds the access number range corresponding to the tier having the real area allocated to the virtual area. To do. As a result of the above determination, the management system replaces a virtual area that is determined to be out of range with respect to the virtual area instead of the real area allocated to the virtual area (hereinafter, the migration source real area). A real area in the hierarchy corresponding to the access number range in which the number of accesses can be accommodated (hereinafter, the real area of the migration destination) is allocated. Specifically, the management computer 103 instructs the storage subsystem 102 to migrate the migration source real area data to the migration destination real area.
- the number of accesses to the virtual area means the number of access requests for which all or part of the target virtual area is designated as an address range and the processing is completed.
- FIG. 17 is a flowchart for explaining details of the rearrangement process.
- the rearrangement process is a process performed on a virtual volume registered in the VVOL ID 601 of the VVOL management table 311 (hereinafter, the target VVOL in the description of FIG. 17).
- the management computer 103 requests the storage control program 307 of the storage subsystem 102 to execute relocation processing at regular time intervals (for example, every 30 minutes or every hour).
- the storage control program 307 acquires the value of the access number 604 of each VVOL ID 601 registered in the VVOL management table 311 and matches the value of the access number 604 of each virtual area with the allowable access number range 703 of the hierarchy management table 310.
- the corresponding hierarchy ID 701 is specified.
- the recorded hierarchy ID may be the same as or different from the hierarchy ID of the hierarchy including the real area assigned to the virtual area.
- the storage control program 307 executes steps 1703 to 1708 for all virtual areas acquired in step 1701.
- Whether the storage control program 307 matches the ID of the tier (referred to as “target region placement source tier”) corresponding to the real region currently assigned to the target virtual region and the value of the relocation determination result identified in step 1701. Determine whether or not.
- the storage control program 307 specifies the ID 501 of the RAID group including the real area based on the ID 603 of the real area allocated to the target virtual area, and the device type 402 or / or the corresponding to the RAID group.
- the hierarchy ID 701 corresponding to the performance requirement 702 to which the RAID level 403 conforms is specified. It is determined whether or not the identified hierarchy ID 701 matches the value of the rearrangement determination result identified in step 1701.
- step 1703 If the target area placement source hierarchy is a hierarchy to be placed (Yes in step 1703), data migration of the target virtual area is unnecessary, and the process for the target virtual area ends. On the other hand, if the target area arrangement source hierarchy is not a hierarchy to be arranged (No in step 1703), the process proceeds to step 1704.
- the storage control program 307 has an unallocated real area in the tier (referred to as “target area placement destination tier”) indicated by the tier ID of the relocation determination result identified in step 1701 based on the real area management table 309. It is determined whether or not to do.
- step 1704 If there is a vacancy in the hierarchy to be arranged (Yes in step 1704), the process proceeds to step 1706. If there is no vacancy in the hierarchy to be arranged (No in step 1704), the process proceeds to step 1705.
- the storage control program 307 replaces the real area currently allocated to the target virtual area (referred to as “data migration source real area”) with an unallocated real area (“data migration destination real area” in the target area allocation destination hierarchy). "). Specifically, the storage control program 307 updates the value of the allocation status 309 corresponding to the data migration source real area in the real area management table 309 to unallocated, and sets the allocation status 309 corresponding to the data migration destination real area. Update value to assigned.
- the real area and the virtual area are managed so as to be separated by the same capacity, so that it is not necessary to consider the capacity of the migration source and the migration destination.
- the storage control program 307 updates the value of the real area ID 603 corresponding to the target virtual area in the VVOL management table 311 to the ID of the data migration destination real area. In addition, the storage control program 307 migrates data from the data migration source real area to the data migration destination real area.
- step 1706 may affect the performance of other virtual volumes.
- all unallocated real areas in the high performance tier may be used up.
- an unallocated real area in the hierarchy cannot be allocated to the virtual area in the virtual volume on which the rearrangement process is performed thereafter. Therefore, when there is a virtual area that is determined to be allocated with a real area in the hierarchy, another virtual area to which the real area in the hierarchy is assigned as in the processing of steps 1707 and 1708 described later.
- the area, the allocation status, and the data are exchanged, or an actual area of another layer with similar performance is allocated, which may affect the performance.
- the real area that is not allocated is not allocated to the virtual area of the target VVOL, but the target is always replaced only with another virtual area in the target VVOL.
- a method for realizing the optimization of the real area allocation state to the virtual area in the VVOL can be considered.
- the storage control program 307 determines whether or not to use an unallocated real area in the reallocation process, for example, based on the number or / and ratio of the unallocated real area in each tier.
- the storage control program 307 determines that the number of real areas in the target area allocation destination tier is the number of unallocated real areas in the target area allocation destination tier even if there is an unallocated real area in the processing of step 1704. If it is less than 10%, the processing shifts to step 1705 instead of step 1706.
- the storage control program 307 determines whether there is a real area assigned to the target virtual area and a real area where data can be exchanged. Specifically, the storage control program 307 determines the hierarchy of the relocation determination result identified in step 1701 corresponding to the virtual area to which the real area is allocated among the allocated real areas in the target area allocation destination hierarchy. It is determined whether or not there is an ID whose ID matches the hierarchical ID of the target area arrangement source hierarchy.
- step 1705 If there is a real area that can be replaced (Yes in step 1705), the process proceeds to step 1707. If there is no real area that can be replaced (No in step 1705), the process proceeds to step 1708. To do.
- the storage control program 307 executes the real area allocated to the target virtual area (hereinafter referred to as “target real area 1” in the description of step 1707) and the allocated real area (hereinafter referred to as step 1707) included in the target area placement destination hierarchy.
- target real area 1 the real area allocated to the target virtual area
- step 1707 the allocated real area included in the target area placement destination hierarchy.
- the allocation status to the virtual area is exchanged with “target real area 2”.
- the storage control program 307 stores the ID of the target real area 2 at the location where the ID of the target real area 1 is stored in the real area ID 603 of the VVOL management table 311, and the ID of the target real area 2
- the ID of the target real area 1 is stored in the place where “is stored.
- the storage control program 307 exchanges data between the target real area 1 and the target real area 2.
- the storage control program 307 realizes data exchange by performing the following processing.
- the cache memory area in the following processing may be an unallocated real area that the storage subsystem 102 has.
- Procedure 1 The storage control program 307 writes the data in the target real area 1 in the cache memory area.
- Procedure 2 The storage control program 307 writes the data in the target real area 2 in the cache memory area.
- Procedure 3 The storage control program 307 writes the data of the target real area 1 from the cache memory area to the target real area 2.
- Procedure 4 The storage control program 307 writes the data of the target real area 2 from the cache memory area to the target real area 1.
- the storage control program 307 migrates the data in the real area assigned to the target virtual area to the unallocated real area in the tier whose performance is closest to the target tier. In addition, the storage control program 307 updates the VVOL management table 311 and the real area management table 309.
- FIG. 18 is a flowchart for explaining an overview of overall processing executed by the management computer 103 in this embodiment.
- Step 1801 On the application information input screen 1301 (see FIG. 14), the user (administrator) displays a Host identifier 1302, a Storage identifier 1303, a Pool ID 1304, a VVOL ID 1305, a VVOL LSIZE 1306, a VVOL LSIZE 1307, an application name 1307, an application type 1308, and a prediction.
- the application information acquisition engine 804 acquires the input information.
- the pool capacity prediction process may be executed immediately when the information of a newly added application or an application that changes the usage mode (used volume) is input and the execution button 1310 is pressed. The pool capacity prediction process may be executed after this period.
- the application may not only be newly added or changed, but may be deleted to predict the pool capacity after deletion.
- processing associated with application information input (S1801) when an application is added and deleted will be described.
- the storage information acquisition engine 810 adds rows corresponding to the pool ID 1003 and VVOLID 1004 of the virtual volume capacity information table 1001 from the VVOLID 1304 and POOLID 1305.
- the management computer 103 Based on the VVOLID 1304, the management computer 103 “assigns” the assignment status 504 of the real area management table 309 corresponding to the VVOLID 2004 to the storage control program 307 in the storage subsystem 102 via the management network 106. To change to "". More specifically, the storage control program 307 that has received the instruction acquires the VVOLBA range 602 and the real area ID 603 in which the VVOL ID 601 and the VVOL ID 2004 in the VVOL management table 311 match, and acquires the real area ID 502 and the RGLBA in the real area management table 309. The allocation state 504 in which the range 503 matches the VVOLBA range 602 and the real area ID 603 is changed to “allocation”.
- an application deletion screen 2001 is created as shown in FIG. 23, an application name 2002 to be deleted, an application type 2003, a VVOLID 2004, and a POOLID 2005 are input, and an execution 2006 is dropped.
- the application information acquisition engine 804 deletes the row corresponding to the application name 902, application type 903, and VVOLID 904 in the application / volume mapping table 901 from the application name 2002, application type 2003, and VVOLID 2004 input on the application deletion screen 2001. To do.
- the storage information acquisition engine 810 deletes all the rows corresponding to the pool ID 1003 and VVOLID 1004 in the virtual volume capacity information table 1001 from the VVOLID 2004 and POOLID 2005.
- the management computer 103 sets the allocation status 504 of the real area management table 309 corresponding to the VVOLID 2004 to the storage control program 307 in the storage subsystem 102 via the management network 106. Instruct to change to "allocation". More specifically, the control program 307 that has received the instruction acquires the VVOLBA range 602 and the real area ID 603 in which the VVOL ID 601 and the VVOL ID 2004 in the VVOL management table 311 match, and the real area ID 502 and the RGLBA range in the real area management table 309. 503 changes the allocation status 504 matching the VVOLBA range 602 and the real area ID 603 to “unallocated”.
- the application information acquisition engine 804 stores information on the application name 1307, application type 1308, and VVOLID 1305 acquired from the application information input screen 1301 in the data storage DB 812 application / volume mapping table 901 of the storage device 811.
- Step 1603 The application information acquisition engine 804 inputs the information of the VVOLSIZE 1306, the prediction period 1309, the application type 1308, and the POOLID 1304 acquired in step 1601, and instructs the pool capacity prediction engine 805 to execute the prediction process.
- the pool capacity prediction engine 805 starts the page allocation prediction engine 806 for the new VOL and the page allocation prediction engine 807 for the existing VOL in order to obtain input parameters necessary for predicting the capacity consumption trend of the VVOL used by the application. To do.
- the pool capacity prediction engine 805 passes the VVOLSIZE 1306, the prediction period 1309, and the application type 1308 as parameters when starting the page allocation prediction engine 806 for the new VOL, so that the page allocation prediction engine 806 for the new VOL allocates The capacity consumption amount of each Tier after the prediction period 1309 for the scheduled VVOLSIZE 1305 is acquired. Specific processing contents will be described later.
- the page allocation amount prediction engine 807 for the existing VOL predicts the influence on the existing pool due to the addition of the VVOL with respect to the pool constituting the VVOL to be allocated.
- the page allocation prediction engine 807 for the existing VOL acquires the predicted capacity consumption of each Tier in the pool after the prediction period 1309 in the POOLID 1304. Specific processing contents will be described later.
- the pool capacity prediction engine 805 adds up the results obtained from the prediction engines 806 and 807 and stores them in the pool capacity prediction table 1101. Specifically, the pool capacity prediction engine 805 uses the page capacity prediction engine for the new VOL as the predicted capacity consumption of each Tier of the pool after the prediction period 1309 calculated by the page allocation prediction engine 807 for the existing VOL. The result predicted in 806 is added, and the calculation result is stored in the capacity consumption 1105 after one month.
- the pool capacity prediction engine 805 stores the current capacity consumption of each Tier in the pool calculated in step 2212 of the page allocation amount prediction engine 807 for the existing VOL in the current capacity consumption 1104.
- the pool capacity prediction engine 805 stores the VVOL VSIZE 1306 of the allocated VVOL in the VVOL capacity 1103.
- Step 1805 The pool capacity prediction engine 805 activates the result display engine 808.
- the result display engine 808 outputs the data of the pool capacity prediction table 1101 to the pool capacity prediction result report screen 1301.
- a billing setting screen 2101 for each Tier is created.
- cost inputs 2102 to 2104 for each tier are performed, and the execution 2105 is pressed.
- the pool capacity prediction engine 805 stores the information input on the charging setting screen 2101 for each Tier in the charging management table 2201 for each Tier (see FIG. 25). Specifically, the pool capacity prediction engine 805 stores the cost inputs 2102 to 2104 for each tier in the charge management table 2201 for each tier.
- the pool capacity prediction engine 805 executes the processing of step 1804, acquires data of each tier from the capacity consumption 1105 one month after the pool capacity prediction table 1101, and performs charge management for each tier. A value multiplied by the data of Cost 2203 of the table 2201 is stored in the pool capacity prediction table 1101.
- the pool capacity prediction engine 805 causes the result display engine 808 to output the data of the pool capacity prediction table 1101 to the pool capacity prediction result report screen 2301.
- the screen drawing result in this case is displayed as shown in FIG.
- the difference between FIG. 26 and FIG. 16 is that the predicted cost 2302 is displayed.
- the cost for device purchase when the capacity is insufficient is displayed.
- the cost based on the consumed capacity may be displayed.
- FIG. 19 is a flowchart for explaining the details of the processing of the Page allocation prediction engine (hereinafter also referred to as “new allocation prediction engine”) 806 to a new VOL when an application is added.
- the new allocation amount prediction engine 806 acquires the VVOL ID 904 from the application / volume mapping table 901 from the application type of the VVOL scheduled to be allocated. That is, an existing application similar to the type of application to be added is identified.
- “similar” is a concept including “same”. For example, when the application to be added is a search engine, if the same search engine already exists, it is selected, but if there is another search engine that is not the same, it is selected. When there are a plurality of similar types of applications, any one of the applications may be selected and predicted using the initial trend of the introduction, or a plurality of applications may be selected and their initial You may make it average a trend.
- Step 1902 The new allocation amount prediction engine 806 executes the processing of Steps 1903 to 1906 for all the lists of VVOLIDs 904 for similar usage acquired in Step 1901. If the process has been executed for all the lists, the process proceeds to step 1907.
- Step 1903 The new allocation amount prediction engine 806 assumes from the virtual volume capacity information table 1001 as the operation start time the oldest time at which collection of the currently used VVOL for similar usage is started. Note that in the virtual volume capacity information table 1001, the operation start time can be arbitrarily set unless information for a predetermined period retroactive to the latest time is used. If the initial usage of the similar type of application is too specific compared to the planned operation of a new application that has been added, select when the usage state of the similar application is stable and predict You may make it use for a process.
- Step 1904 The new allocation amount prediction engine 806 acquires from the virtual volume capacity information table 1001 data from the time (operation start time) acquired in step 1903 to the period (for example, one month) that the user wants to predict.
- Step 1905 The new allocation amount prediction engine 806 executes Tier 0 usage amount 1006 ⁇ VVOL capacity 1005, Tier 1 usage amount 1007 ⁇ VVOL capacity 1005, Tier 2 usage amount 1008 ⁇ VVOL capacity 1005 for each execution result of step 1904. For each Tier, the consumption ratio with respect to the allocated capacity of the VVOL is calculated.
- Step 1906 The new allocation amount prediction engine 806 estimates the value at which the consumption ratio with respect to the VVOL allocation capacity of each Tier calculated in step 1905 in a similar application is the maximum as the safety factor. If it is calculated, it is stored as a set of predicted usage candidates of Tier usage amounts 1006 to 1008 and VVOL capacity 1005. That is, in step 1906, finally, a process of finding the Tier usage amount and the VVOL capacity with the maximum capacity consumption within the specified period from the operation start time is performed.
- Step 1907 The new allocation amount prediction engine 806 calculates the consumption ratio with respect to the allocated capacity of the VVOL for each Tier for the candidate group after verifying all the VVOLs of similar usages to be processed. In this process, an operation equivalent to step 1905 is executed for a candidate combination (Tier usage amount 1006 and VVOL capacity 1005) that takes the maximum value. If the calculation result is held, it is not necessary to perform the same calculation again, but here it is assumed that the calculation result is not held.
- Step 1908 The new allocation amount prediction engine 806 multiplies the value calculated in step 1907 by the VVOL scheduled for new allocation specified by the user. In this way, the predicted capacity consumption of each Tier after the specified period for the VVOL specified by the user can be calculated.
- Step 1909 The new allocation amount prediction engine 806 returns the value calculated in step 1908 to the pool capacity prediction engine 805 as a predicted value of the pool capacity consumed by the added application.
- FIG. 20 is a flowchart for explaining the processing outline of the page allocation prediction engine 807 for an existing VOL.
- a page allocation prediction engine (hereinafter also referred to as an “existing allocation prediction engine”) 807 for an existing VOL, the value calculated by the predicted capacity consumption calculation processing (step 2001) of each tier of the pool, The value calculated by the capacity consumption calculation process (step 2002) of each Tier is returned to the pool capacity prediction engine 805. Details of steps 2001 and 2002 will be described below.
- FIG. 21 is a flowchart for explaining the details of the predicted capacity consumption calculation process (step 2001) of each tier of the pool.
- Step 2101 The existing allocation prediction engine 807 acquires a list of all VVOLs of the POOLID 1304 input from the application information input screen 1301. The processing from S2103 to S2105 is executed for the acquired VVOL.
- Step 2102 The existing allocation prediction engine 807 determines whether the processing (S2103 to S2105) has been executed for all the VVOLIDs 1004 acquired in step 2101. If the process is complete, the process moves to step 2106.
- the existing allocation prediction engine 807 acquires history data for each VVOL. Here, all the past data is acquired, but the range (period) of data to be acquired is specified by the user (administrator), and the data during the specified period may be used or fixed. You may make it use the data of a period.
- the existing allocation prediction engine 807 performs maximum likelihood estimation (for example, using the least squares method) of the usage amount of each Tier for the data acquired in Step 2103 every collection time 1002, and uses the usage amount of each Tier of the VVOL.
- maximum likelihood estimation for example, using the least squares method
- a relational expression indicating an increasing tendency of is calculated.
- Step 1808 The existing allocation prediction engine 807 calculates the capacity consumption prediction of each Tier of the VVOL by multiplying the relational expression calculated in Step 2104 by the prediction period 1309 specified by the user input on the application information input screen 1301. . That is, based on past statistical data, the capacity consumption after the lapse of the specified period is predicted.
- Step 1809 The existing allocation prediction engine 807 calculates the predicted capacity consumption of each Tier in the pool by adding the predicted values of the capacity consumption of each Tier in each VVOL calculated in Step 2105.
- FIG. 22 is a flowchart for explaining the details of the capacity consumption calculation process (step 2002) for each Tier in the pool.
- Step 2201 The existing allocation prediction engine 807 determines whether or not the processing in step 2202 has been completed for all the VVOLIDs 1004 acquired in step 2101. If the process of S2202 is completed, the process proceeds to step 2203.
- Step 2202 The existing allocation prediction engine 807 acquires the consumption amount of each Tier of the VVOL at the current time. If there is no current data in a strict sense, the latest data may be used.
- the existing allocation prediction engine 807 adds up the capacity consumption (current capacity) of each Tier in each VVOL calculated in Step 2202 and calculates the capacity consumption of each Tier in the pool.
- the characteristic may change as it is used. More specifically, although a certain business application usually has a small access amount, there are cases where the access amount increases during a specific period such as the end of the fiscal year or the end of the period, and an access amount close to OLTP occurs.
- step 1801 the user (administrator) changes the application type 1308 (FIG. 14) and inputs the remaining capacity of the allocated virtual volume to VVOLLSIZE 1307.
- Information similar to 1802 is input to the application information input screen 1301 and the execution 1310 is dropped. Thereafter, the same processing as that executed by the management computer 103 in this embodiment is executed.
- the above-described process of newly adding an application can be applied. This makes it possible to predict the capacity consumption after the application characteristics are changed.
- each allocated logical volume is grouped using the LVM (Logical Volume Manager) function provided by the OS on the server, etc.
- LVM Logical Volume Manager
- the idea of the present invention is applied (expanded), and the future consumption is predicted from the sum of the capacity consumption of each logical volume allocated to the application, thereby reducing the capacity consumption of the LVM environment.
- a volume allocated to an application may be a VVOL cut out from a different pool. Therefore, in such a case, in order to predict the consumed capacity of the entire group, it is necessary to predict the capacity not only from one pool but also from each corresponding pool. In order to apply the present invention to this environment, it is necessary to expand the information input screen and the processing of step 1908 as follows.
- step S1908 the page allocation amount prediction engine 806 for a new VOL changes the sum of all virtual volume capacities constituting the LVM with respect to the VVOL capacity to be allocated. More specifically, S1908 is assumed to be “the ratio of each Tier calculated in Step 1907 ⁇ the total sum of each VVOL value input to VVOLIZE1 1307 of the application information input screen 1301”.
- ⁇ Summary> when a new application addition is instructed, or when a change in the allocation of a virtual volume used by an existing application is instructed, a new application or allocation is responded to the instruction.
- Information on past consumption capacity trends for example, consumption capacity trends within a predetermined period from the beginning of application introduction
- an application of the same or similar application type is acquired.
- the consumption capacity in the virtual volume to be allocated is predicted. By doing so, it becomes possible to grasp the depletion timing of the capacity (for example, the capacity allocated to the pool) accompanying the addition of an application or a change in volume allocation.
- the reason for acquiring the information on the consumption capacity trend from the beginning of the application is that it is possible to more accurately grasp the tendency of the consumption capacity accompanying the addition or allocation change.
- one or more physical storage devices constitute a hierarchy.
- the virtual volume is configured using one or more hierarchies and is associated with a pool associated with a target that is directly accessed by the host computer.
- the consumed capacity (utilization amount) is managed for each tier (see FIG. 11).
- information on the past usage amount of the allocation area in one or more tiers constituting the virtual volume is used.
- the timing of depletion of the consumed capacity of the pool can be grasped more accurately. In other words, it is possible to cope with the extended operation of ThinThProvisioning.
- the maximum capacity estimation method for example, the least square method
- the predicted consumption capacity of the existing application and the predicted consumption capacity in the virtual volume scheduled to be allocated to the newly added application are added together and output (displayed or printed out).
- the future cost will be presented. Thereby, the user (administrator) can efficiently operate the system while considering the cost.
- the total predicted consumption capacity is calculated except for the application to be deleted.
- the consumption capacity is predicted using the page allocation prediction engine 807 for the existing VOL. In this way, it is possible to determine how effective the capacity securing accompanying the application deletion is. Further, if data remains in the high-performance Tier 1 after the application is deleted, resources are wasted, but such a situation can be avoided.
- the present invention is not limited to the embodiments as they are, and can be embodied by modifying the constituent elements without departing from the scope of the invention in the implementation stage.
- Various inventions can be formed by appropriately combining a plurality of constituent elements disclosed in the embodiments. For example, some components may be deleted from all the components shown in the embodiment. Furthermore, constituent elements over different embodiments may be appropriately combined.
- each configuration, function, processing unit, processing unit, and the like shown in the embodiment may be realized by hardware by designing a part or all of them with, for example, an integrated circuit.
- each of the above-described configurations, functions, etc. may be realized by software by the processor interpreting and executing a program that realizes each function.
- Information such as programs, tables, and files for realizing each function is stored in a recording or storage device such as a memory, hard disk, SSD (Solid State Drive), or a recording or storage medium such as an IC card, SD card, or DVD. be able to.
- control lines and information lines indicate what is considered necessary for the explanation, and not all control lines and information lines on the product are necessarily shown. All the components may be connected to each other.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Human Computer Interaction (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Debugging And Monitoring (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
Description
図1は、本発明の実施形態による計算機システム100の概略構成を示す図である。計算機システム100は、ホスト計算機101と、ストレージサブシステム102と、管理システム107と、を有している。ストレージサブシステム102とホスト計算機101とは、ストレージエリアネットワーク105によって接続されている。また、管理システム107とストレージサブシステム102及びホスト計算機101とは、管理用ネットワーク106によって接続されている。
図2は、ホスト計算機101の内部構成を示す図である。ホスト計算機101は、ストレージエリアネットワーク105との接続を実現するためのSANポート203と、管理用ネットワーク106との接続を実現するためのLANポート205と、メモリ202と、メモリ202およびSANポート203、LANポート205に接続されたCPU201と、を有する。
図3は、ストレージサブシステム102の内部構成を示す図である。ストレージサブシステム102は、ディスク回転数等の物理特性の異なる複数の物理記憶デバイス305と、コントローラ312を有し、これらは内部バス等の回路を介して相互に接続されている。同種の物理記憶デバイス305が複数ある場合、それらはRAID構成を組んでいてもよい。RAID構成を組んでいる複数の物理記憶デバイス305は、RAIDグループ306を構成する。
ストレージ制御プログラム307は、後述する図4に示すように、複数の物理記憶デバイスからRAIDグループを構築する。ストレージ制御プログラム307は、ホスト計算機101から指定された仮想ボリュームを割当てる際、ボリュームサイズに対応した物理ディスクを当該ホスト計算機101に割当てるわけではなく、ボリュームの利用状況に応じて動的に物理ディスクを割当てる。以降では、このボリュームを仮想ボリューム(「VVOL」ともいう)と呼ぶこととする。
図4は、ストレージサブシステム102が有するRAIDグループ管理表308の構成例を示す図である。RAIDグループ管理表308は、RAIDグループ306の性能に関する情報を有する。
図5は、ストレージサブシステム102が有する実領域管理表309の構成例を示す図である。実領域管理表309は、各RAIDグループ306が持つ実領域が、仮想ボリュームに割当済か否かの情報を有する。
図6は、ストレージサブシステム102が有するVVOL管理表311の構成例を示す図である。VVOL管理表311は、仮想ボリューム内の各仮想領域と、その仮想領域に割り当てられている実領域に関する情報を有する。
図7は、ストレージサブシステム102が有する階層定義表310の構成例を示す図である。階層定義表310は、階層の性能及び許容するアクセス数の範囲に関する情報を有する。
図8は、プールと仮想ボリュームとの対応関係を管理する、プール-仮想ボリューム(VVOL)対応管理表314の構成例を示す図である。
図9は、管理計算機103の内部構成を示すブロック図である。管理計算機103は、管理用ネットワーク106に接続するためのLANポート802と、構成管理プログラム804を実行するCPU801と、CPU801が用いるメモリ803とを有し、これらは内部バス等の回路を介して相互に接続されている。
アプリケーション情報取得エンジン804は、アプリケーション情報入力画面1301(図14参照)で入力したユーザが割当て予定のVOLとアプリケーションとの対応関係を取得し、管理計算機103の記憶装置811のデータ格納用DBに存在するアプリケーションとボリュームとのマッピングテーブル901に格納する。なお、マッピングテーブル901は、データ格納用DB812の中に含まれている。
Tier定義取得エンジン809は、階層管理表設定画面1401(図15参照)を用いてユーザが入力した情報を取得し、管理計算機103のLANポート802と管理用ネットワーク106とストレージサブシステム102のLANポート303を介してストレージサブシステム102のメモリ304内の階層管理表310に格納する。
ストレージ情報取得エンジン810は、定期的に管理計算機103のCPU801で実行される。実行時、ストレージ情報取得エンジン810は、ストレージサブシステム102のメモリ304のストレージ情報取得エージェント313から各VVOLについてTier毎の割当て容量を取得する。そして、ストレージ情報取得エンジン810は、取得した情報を、LANポート303と管理用ネットワーク106とLANポート802と記憶装置811を介して、データ格納用DB812内の仮想ボリューム容量情報テーブル1001へ格納する。
プール容量予測エンジン805は、アプリケーション及びVVOLの追加または、既存のVVOLへのPage割当て、増加後のプールの容量を予測するエンジンである。具体的には、新規VOLへのPage割当て量予測エンジン806と既存VOLへのPage割当て量予測エンジン807を起動し、新規VOLへのPage割当て量予測エンジン806と既存VOLへのPage割当て量予測エンジン807が算出した値を合計した上で結果をプール容量予測テーブル1101(図12参照)に格納する。なお、本実施形態では、従来のPool単位での容量予測ではなく、各Tierについて容量予測を行うようにしている。
新規VOLへのPage割当て量予測エンジン806は、アプリケーション情報入力画面1301のアプリケーション名1307とアプリケーションタイプ1308と予測期間1309の情報から、過去に導入済みの同一、同種或いはアプリケーションの利用するボリュームの消費傾向が類似するアプリケーション(以下、「類似等するアプリケーション」ということとする)の情報をアプリケーションとボリュームとのマッピングテーブル901から特定する。そして、新規VOLへのPage割当て量予測エンジン806は、導入当初から測期間1309で指定した期間分の過去のVVOLの容量消費傾向を仮想ボリューム容量情報テーブル1001から取得する。さらに、新規VOLへのPage割当て量予測エンジン806は、上記類似等するアプリケーションのVVOLの容量消費傾向から、各Tierの利用率を算出しプール容量予測エンジン805に算出した値を返す。なお、各Tierの利用率の算出方法については、図19を用いて後述する。
既存VOLへのPage割当て量予測エンジン807は、ストレージサブシステム102が管理する各プールについて、Tier毎の割当て済みPage数の履歴情報を仮想ボリューム容量情報テーブル1001から取得し、最尤推定法(例えば、最小二乗法)を用いて、アプリケーション情報入力画面1301で指定した予測期間1309後のプールの容量消費量を予測する。予測した算出結果をプール容量予測エンジン805に返す。なお、算出方法については、図20乃至22を用いて後述する。
結果表示エンジン808は、プール容量予測エンジンが起動する。プール容量予測テーブル1101から、データを取得し、表示装置813にプール容量予測結果レポート画面1501を出力する。
本実施形態によるストレージサブシステム102は、定期的に、ストレージサブシステム102が提供するプールと仮想ボリュームの構成情報と容量情報を収集する処理と、ユーザが指定するTierの階層管理を行うための入力情報を基にTierを再配置する処理と、を実行する。
管理システム107に表示されるアプリケーション情報入力画面1301から追加或いは、ボリュームの対応を変更するアプリケーションについての情報が入力されると、アプリケーション情報取得エンジン804は、その入力情報をアプリケーションとボリュームとのマッピングテーブル901に格納する。
ストレージ情報取得エンジン810は、定期的にストレージサブシステム102内のデータをポーリングして各仮想ボリュームの容量を取得し、当該容量の情報を仮想ボリューム容量情報テーブル1001に格納する(図11参照)。
管理システム107に表示される階層管理表設定画面1401(図15参照)を用いて設定された階層の情報が入力されると、階層定義取得エンジン809は、ストレージサブシステム102の階層管理表310に格納する。
管理計算機103は、定期的にTierの再配置処理の実行をストレージサブシステム102に定期的に指示する。例えば、1時間や30分毎に、当該仮想ボリューム内の仮想領域に対する実領域の割当状況を見直す。
図17は、再配置処理の詳細を説明するためのフローチャートである。再配置処理は、VVOL管理表311のVVOLID601登録されている仮想ボリューム(以下、図17の説明において対象VVOL)に対して行う処理である。
管理計算機103は、一定時間毎(例えば30分毎や1時間毎)に、ストレージサブシステム102のストレージ制御プログラム307へ再配置処理の実行を要求する。
ストレージ制御プログラム307は、VVOL管理表311に登録される各VVOLID601のアクセス数604の値を取得し、各仮想領域のアクセス数604の値と階層管理表310の許容アクセス数範囲703とを突き合わせることで、現配置箇所が妥当かを判断した上で該当する階層ID701を特定する。この結果、記録された階層IDは、当該仮想領域に割り当てられている実領域を含む階層の階層IDと同じであることもあれば異なることもある。
次に、ストレージ制御プログラム307は、ステップ1701で取得したすべての仮想領域に対してステップ1703~1708の処理を実行する。
ストレージ制御プログラム307は、現在対象仮想領域に割り当てられている実領域に対応する階層(「対象領域配置元階層」という)のIDとステップ1701で特定した再配置判定結果の値とが一致するか否かを判定する。具体的には、ストレージ制御プログラム307は、対象仮想領域に割り当てられている実領域のID603を基に、その実領域を含むRAIDグループのID501を特定し、そのRAIDグループに対応するデバイス種別402または/およびRAIDレベル403が適合する性能要件702に対応する階層ID701を特定する。特定した階層ID701と、ステップ1701で特定した再配置判定結果の値が一致するか否かを判定する。
ストレージ制御プログラム307は、実領域管理表309を基にステップ1701で特定した再配置判定結果の階層IDによって示される階層(「対象領域配置先階層」という)内に、未割当の実領域が存在するか否かを判定する。
ストレージ制御プログラム307は、対象仮想領域に現在割り当てられている実領域(「データ移行元実領域」という)に代えて、対象領域配置先階層内の未割当の実領域(「データ移行先実領域」という)を割り当てる。具体的には、ストレージ制御プログラム307は、実領域管理表309の、データ移行元実領域に対応する割り当て状況309の値を未割当に更新し、データ移行先実領域に対応する割り当て状況309の値を割当済みに更新する。なお、本実施形態では、例えば、実領域と仮想領域は同じ容量で区切られるように管理され、移行元と移行先の容量を考慮する必要がないようになっている。
ストレージ制御プログラム307は、対象仮想領域に割り当てられている実領域と、データを入れ替え可能な実領域が存在するか否かを判定する。具体的には、ストレージ制御プログラム307は、対象領域配置先階層内の割当済の実領域の中で、その実領域が割り当てられている仮想領域に対応するステップ1701で特定した再配置判定結果の階層IDが、対象領域配置元階層の階層IDと一致するものが存在するか否かを判定する。
ストレージ制御プログラム307は、対象仮想領域に割り当てられている実領域(以下、ステップ1707の説明において「対象実領域1」という)と、対象領域配置先階層が有する割当済実領域(以下、ステップ1707の説明において「対象実領域2」という)との間で、仮想領域への割り当て状況を入れ替える。具体的には、ストレージ制御プログラム307は、VVOL管理表311の実領域ID603において、対象実領域1のIDが格納されている箇所に対象実領域2のIDを格納し、対象実領域2のIDが格納されている箇所に対象実領域1のIDを格納する。また、ストレージ制御プログラム307は、対象実領域1と対象実領域2の間のデータの入れ替えを行う。例えば、ストレージ制御プログラム307は、下記の処理を行うことによりデータの入れ替えを実現する。なお、下記処理におけるキャッシュメモリ領域は、ストレージサブシステム102が有する未割当実領域でもよい。
ストレージ制御プログラム307は、対象階層に性能が最も近い階層内の未割当の実領域に、対象仮想領域に割り当てられている実領域内のデータを移行する。また、ストレージ制御プログラム307は、VVOL管理表311と実領域管理表309を更新する。
図18は、本実施形態における管理計算機103が実行する全体的処理の概要について説明するためのフローチャートである。
ユーザ(管理者)がアプリケーション情報入力画面1301(図14参照)にHost識別子1302と、Storage識別子1303と、PoolID1304と、VVOLID1305と、VVOLSIZE1306と、VVOLSIZE1307と、アプリケーション名1307と、アプリケーションタイプ1308と、予測期間1309の情報を入力し、実行1310を投下すると、アプリケーション情報取得エンジン804が入力された情報を取得する。なお、新規追加アプリケーション、或いは使用態様(使用ボリューム)を変更するアプリケーションの情報が入力され、実行ボタン1310が押下されると即時にプール容量予測処理を実行するようにしても良いが、ユーザの指定した期間後にプール容量予測処理を実行するようにしても良い。この場合、割当て予定の仮想ボリュームは、他のユーザが利用できないように予約する必要がある。また、上述のように、アプリケーションは新規追加や変更だけでなく、削除をして削除後のプール容量を予測するようにしても良い。以下、アプリケーションを追加する場合と削除する場合のアプリケーション情報入力(S1801)に付随する処理について説明する。
アプリケーション情報の入力画面は図14に示したとおりである。また、アプリケーションを追加した場合には、マッピングテーブル901と、仮想ボリューム容量情報テーブル1001に情報が追加される。つまり、アプリケーション情報取得エンジン804は、アプリケーション追加画面1301に入力されたアプリケーション名1302とアプリケーションタイプ1303とVVOLID1304から、アプリケーションとボリュームとのマッピングテーブル901のアプリケーション名902とアプリケーションタイプ903とVVOLID904に該当する行を追加する。
上述したように、アプリケーションの新規追加に加えて、本実施形態では、アプリケーション削除に伴う割当て済み仮想ボリュームの削除も可能である。割当て済み仮想ボリュームを削除することで、対象プールの各Tier利用量の精度向上及び無駄な領域の解放が見込まれる。
アプリケーション情報取得エンジン804は、アプリケーション情報入力画面1301から取得したアプリケーション名1307、アプリケーションタイプ1308、VVOLID1305の情報を記憶装置811のデータ格納用DB812内アプリケーションとボリュームとのマッピングテーブル901へ格納する。
アプリケーション情報取得エンジン804は、ステップ1601で取得したVVOLSIZE1306と予測期間1309とアプリケーションタイプ1308とPOOLID1304の情報を入力に、プール容量予測エンジン805に予測処理実行を指示する。
プール容量予測エンジン805は、アプリケーションが利用するVVOLの容量消費傾向の予測に必要な入力パラメータを得るため、新規VOLへのPage割当て量予測エンジン806と既存VOLへのPage割当て量予測エンジン807を起動する。
プール容量予測エンジン805は、結果表示エンジン808を起動する。結果表示エンジン808は、プール容量予測テーブル1101のデータをプール容量予測結果レポート画面1301に出力する。
図19は、アプリケーション追加時における、新規VOLへのPage割当て量予測エンジン(以下、「新規割当て量予測エンジン」ということもある)806の処理の詳細を説明するためのフローチャートである。
割当て予定のVVOLと類似する使用傾向が見られるVVOLを検索するため、新規割当て量予測エンジン806は、割当て予定のVVOLのアプリケーションタイプから、VVOL ID904をアプリケーションとボリュームとのマッピングテーブル901より取得する。つまり、追加するアプリケーションのタイプと類似する既存のアプリケーションが特定される。ここで、「類似」とは、「同一」も含む概念である。例えば、追加されるアプリケーションが、検索エンジンである場合には、同一の検索エンジンが既にあればそれが選択されるが、同一ではないが他の検索エンジンがあればそれが選択される。複数の類似タイプのアプリケーションがある場合には、何れか1つのアプリケーションを選択してその導入当初の動向を用いて予測するようにしても良いし、複数のアプリケーションを選択し、それらの導入当初の動向を平均するようにしても良い。
新規割当て量予測エンジン806は、ステップ1901で取得した類似使用用途のVVOLID904の一覧全てに対してステップ1903ないし1906の処理を実行する。一覧全てに対して処理が実行された場合は、処理はステップ1907に移行する。
新規割当て量予測エンジン806は、仮想ボリューム容量情報テーブル1001から、現在対象とする類似使用用途のVVOLについて収集を開始した最も古い時刻を運用開始時刻として仮定する。なお、仮想ボリューム容量情報テーブル1001において、最新時刻から遡った所定期間の情報を用いるのでなければ、運用開始時刻は任意に設定することができる。当該類似タイプのアプリケーションの導入当初の使用状況が追加された新規のアプリケーション等の運用予定と比べてあまりにも特異な場合には、類似のアプリケーションの使用状態が安定している時期を選択して予測処理に用いるようにしても良い。
新規割当て量予測エンジン806は、ステップ1903で取得した時刻(運用開始時刻)からユーザが指定した予測したい期間(例えば、1ヶ月)までのデータを、仮想ボリューム容量情報テーブル1001から取得する。
新規割当て量予測エンジン806は、ステップ1904の実行結果1件ずつに対して、Tier0利用量1006÷VVOL容量1005、Tier1利用量1007÷VVOL容量1005、Tier2利用量1008÷VVOL容量1005を実行し、各Tierについて、VVOLの割当て容量に対する消費比率を算出する。
新規割当て量予測エンジン806は、類似するアプリケーションの中においてステップ1905で算出した各TierのVVOL割当て容量に対する消費比率が、最大となる値を安全係数として見積もるために、現在の中で最大の値が算出されれば、予測値の候補として、Tierの利用量1006~1008と、VVOL容量1005の組として保持する。即ち、ステップ1906では、最終的に、運用開始時刻からの指定期間内における容量消費量が最大のTier利用量とVVOL容量を見つけ出す処理が行われている。
新規割当て量予測エンジン806は、対象とする類似用途のVVOL全てについて検証後、候補の組について、各Tierについて、VVOLの割当て容量に対する消費比率を算出する。この処理は、最大値を取る候補の組み合わせ(Tier利用量1006とVVOL容量1005)に対して、ステップ1905と同等の演算を実行するものである。演算結果が保持されていれば、再度同じ演算を行う必要はないが、ここでは保持されない場合を想定している。
新規割当て量予測エンジン806は、ステップ1907で算出した値とユーザの指定する新規割当て予定のVVOLを乗算する。このようにすることで、ユーザの指定したVVOLに対する指定期間後の各Tierの予測容量消費量が算出できる。
新規割当て量予測エンジン806は、ステップ1908で算出した値を追加されたアプリケーションによって消費されるプール容量の予測値として、プール容量予測エンジン805に返す。
図20は、既存VOLへのPage割当て量予測エンジン807の処理概要について説明するためのフローチャートである。既存VOLへのPage割当て量予測エンジン(以下、「既存割当て予測エンジン」ということもある)807は、プールの各Tierの予測容量消費量算出処理(ステップ2001)によって算出された値と、プールの各Tierの容量消費量算出処理(ステップ2002)によって算出された値を、プール容量予測エンジン805に返す。以下、ステップ2001及び2002の詳細について説明する。
図21は、プールの各Tierの予測容量消費量算出処理(ステップ2001)の詳細を説明するためのフローチャートである。
既存割当て予測エンジン807は、アプリケーション情報入力画面1301から入力されたPOOLID1304の全VVOL一覧を取得する。この取得したVVOLに対してS2103からS2105の処理が実行される。
既存割当て予測エンジン807は、ステップ2101で取得したVVOLID1004の全てに対して処理(S2103乃至S2105)を実行したか否か判断する。処理が完了していれば、処理はステップ2106に移行する。
既存割当て予測エンジン807は、VVOL毎に履歴データを取得する。ここでは、過去全てのデータを取得するようにするが、ユーザ(管理者)によって取得すべきデータの範囲(期間)が指定され、その指定期間中のデータを用いるようにしても良いし、固定期間のデータを用いるようにしても良い。
既存割当て予測エンジン807は、ステップ2103で取得したデータに対して収集時間1002毎に各Tierの利用量の最尤推定(例えば、最小二乗法等を用いる)を行い、VVOLの各Tierの利用量の増加傾向を示す関係式を算出する。
既存割当て予測エンジン807は、ステップ2104で算出した関係式に対してアプリケーション情報入力画面1301で入力したユーザの指定した予測期間1309を乗算することでVVOLの各Tierの容量消費量の予測を算出する。つまり、過去の統計的データに基づいて、指定期間経過後の容量消費量を予測する。
既存割当て予測エンジン807は、ステップ2105で算出したVVOL毎の各Tierの容量消費量の予測値を合算し、プールの各Tierの予測容量消費量を算出する。
図22は、プールの各Tierの容量消費量算出処理(ステップ2002)の詳細を説明するためのフローチャートである。
既存割当て予測エンジン807は、ステップ2101で取得したVVOLID1004の全てに対して、ステップ2202の処理が完了したか否か判断する。S2202の処理が完了していれば、処理はステップ2203に移行する。
既存割当て予測エンジン807は、現時点でのVVOLの各Tierの消費量を取得する。厳密な意味での現時点のデータがなければ、最新のデータでも良い。
既存割当て予測エンジン807は、ステップ2202で算出したVVOL毎の各Tierの容量消費量(現時点の容量)を合算し、プールの各Tierの容量消費量を算出する。
(i)アプリケーションの特性変更に伴うボリューム消費量の再予測
上記実施形態では、主にアプリケーション追加に伴う新規仮想ボリュームの割当てを想定しているが、本発明を拡充し既存アプリケーションの特性変化に応じた容量消費量の再予測も可能である。ここで「特性変更」とは、例えば、当初OLTPに割り当てられた仮想ボリューム(VVOL)が別のアプリケーションに割り当てられたような場合等、一度アプリケーションに割り当てた仮想ボリュームの利用態様が変わる場合を意味する。
アプリケーションによっては、サーバ上のOSが提供するLVM(Logical Volume Manager)機能等を利用して、各割当論理ボリュームをグルーピングし、1つの仮想ボリュームとしてアプリケーションに見せて割り当てる環境も存在する。このような環境において、本発明の思想を適用(拡張)し、アプリケーションに割り当てられている個々の論理ボリュームの容量消費量の総和から将来の消費量を予測することでLVM環境の容量消費量を予測できるようになる。つまり、LVM機能においては、1つのグループ(複数のVVOLで構成される)をアプリケーションに割り当てているが、その1つのグループの容量消費予測は、それぞれの構成VVOLの容量消費予測を合算して表すことが可能である。LVM機能を実現する環境では、アプリケーションに割り当てられているボリュームは、異なるプールから切り出されたVVOLである可能性もある。そこで、このような場合にグループ全体の消費容量を予測するには、1つのプールだけからではなく、それぞれの該当プールからも容量を予測する必要があるのである。そして、この環境に本発明を適用するためには、以下のように、情報入力画面とステップ1908の処理を拡張する必要がある。
本実施形態では、新規にアプリケーションの追加が指示された場合、或いは、既存のプリケーションが使用する仮想ボリュームの割り当ての変更が指示された場合、当該指示に応答して、新規のアプリケーション、或いは割り当て変更対象のアプリケーションと、アプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向(例えば、アプリケーション導入当初から所定期間内における消費容量の傾向)に関する情報を取得する。そして、取得した消費容量動向に関する情報に基づいて、割当て予定の仮想ボリュームおける消費容量を予測する。このようにすることにより、アプリケーションの追加又はボリュームの割り当て変更に伴う容量(例えば、プールに割り当てられている容量)の枯渇タイミングを把握することができるようになる。アプリケーション導入当初からの消費容量傾向の情報を取得するのは、追加或いは割り当て変更に伴う消費容量の傾向をより正確に把握することができるからである。
101 ホスト計算機
102 ストレージサブシステム
103 管理計算機
104 Webブラウズ用計算機
105 ストレージエリアネットワーク
106 管理用ネットワーク
107 管理システム
Claims (15)
- 1つ以上の物理記憶デバイスを有するストレージサブシステムと、前記ストレージサブシステムを管理する管理システムと、を有し、
前記ストレージサブシステムは、前記物理記憶デバイスの記憶領域を、仮想ボリュームとしてホスト計算機に提供し、
前記管理システムは、アプリケーションが使用すべき前記仮想ボリュームの割り当てについての入力指示に応答して、前記アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得し、当該消費容量動向に関する情報に基づいて、前記割当て予定の仮想ボリュームおける消費容量を予測することを特徴とする計算機システム。 - 請求項1において、
前記入力指示は、新規にアプリケーションの追加の指示、或いは、既存のアプリケーションに割り当てられる前記仮想ボリュームに変更の指示を含み、
前記管理システムは、前記入力指示に応答して、前記割当て予定の仮想ボリュームにおける消費容量を予測する処理を実行することを特徴とする計算機システム。 - 請求項2において、
前記管理システムは、前記新規追加のアプリケーションと同一又は類似のタイプのアプリケーション、或いは前記仮想ボリューム割り当て変更の既存アプリケーションの運用開始から所定期間における前記消費容量動向に関する情報を取得し、前記割当て予定の仮想ボリュームにおける消費容量を予測することを特徴とする計算機システム。 - 請求項3において、
前記1つ以上の物理記憶デバイスは、1つ以上の階層を構成し、
前記仮想ボリュームは、前記1つ以上の階層を用いて構成され、かつ、前記ホスト計算機が直接アクセスするターゲットと関連付けられたプールと対応付けられ、
前記管理システムは、前記割当て予定の仮想ボリュームにおける消費容量を予測する際に、当該仮想ボリュームを構成する前記1つ以上の階層における割当て領域の過去の利用量に関する情報を用いることを特徴とする計算機システム。 - 請求項4において、
前記管理システムは、さらに、前記仮想ボリュームの割り当てが不変の全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関する情報を取得し、当該全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測し、前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量を併せて出力することを特徴とする計算機システム。 - 請求項5において、
前記システムは、前記1つ以上の階層のコストに関するコスト設定情報、及び前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量に基づいて、前記1つ以上の階層における予測コストを出力することを特徴とする計算機システム。 - 請求項1において、
前記管理システムは、アプリケーションの削除と当該削除対象のアプリケーションに割り当てられた前記仮想ボリュームの削除についての入力指示に応答して、当該削除対象のアプリケーションが使用する前記仮想ボリュームの割り当てを解放し、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関する情報を取得し、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測し、当該予測消費量を出力することを特徴とする計算機システム。 - 1つ以上の物理記憶デバイスの記憶領域を仮想ボリュームとしてホスト計算機に提供するストレージサブシステムと、前記ストレージサブシステムを管理する管理システムと、を有する計算機システムの管理方法であって、
前記管理システムのプロセッサが、アプリケーションが使用すべき前記仮想ボリュームの割り当てについて指示された場合、前記アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得する工程と、
前記プロセッサが、前記消費容量動向に関する情報に基づいて、前記割当て予定の仮想ボリュームおける消費容量を予測する工程と、
を有することを特徴とする管理方法。 - 請求項8において、
前記指示は、新規にアプリケーションの追加の指示、或いは、既存のアプリケーションに割り当てられる前記仮想ボリュームに変更の指示を含み、
前記プロセッサは、前記入力指示に応答して、前記割当て予定の仮想ボリュームにおける消費容量を予測する処理を実行することを特徴とする管理方法。 - 請求項9において、
前記プロセッサは、前記新規追加のアプリケーションと同一又は類似のタイプのアプリケーション、或いは前記仮想ボリューム割り当て変更の既存アプリケーションの運用開始から所定期間における前記消費容量動向に関する情報を取得し、前記割当て予定の仮想ボリュームにおける消費容量を予測することを特徴とする管理方法。 - 請求項10において、
前記1つ以上の物理記憶デバイスは、1つ以上の階層を構成し、
前記仮想ボリュームは、前記1つ以上の階層を用いて構成され、かつ、前記ホスト計算機が直接アクセスするターゲットと関連付けられたプールと対応付けられ、
前記プロセッサは、前記割当て予定の仮想ボリュームにおける消費容量を予測する際に、当該仮想ボリュームを構成する前記1つ以上の階層における割当て領域の過去の利用量に関する情報を用いることを特徴とする管理方法。 - 請求項11において、
さらに、前記プロセッサが、前記仮想ボリュームの割り当てが不変の全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関するデータを取得する工程と、
前記プロセッサが、当該全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測し、前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量を併せて出力する工程と、
を有することを特徴とする管理方法。 - 請求項12において、
さらに、前記プロセッサが、前記1つ以上の階層のコストに関するコスト設定情報、及び前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量に基づいて、前記1つ以上の階層における予測コストを出力する工程を有することを特徴とする管理方法。 - 請求項8において、
さらに、前記プロセッサが、アプリケーションの削除と当該削除対象のアプリケーションに割り当てられた前記仮想ボリュームの削除について指示された場合、当該削除対象のアプリケーションが使用する前記仮想ボリュームの割り当てを解放する工程と、
前記プロセッサが、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関する情報を取得する工程と、
前記プロセッサが、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測する工程と、
前記プロセッサが、前記予測消費量を出力する工程と、
を有することを特徴とする管理方法。 - 1つ以上の物理記憶デバイスの記憶領域を仮想ボリュームとしてホスト計算機に提供するストレージサブシステムと、前記ストレージサブシステムを管理する管理システムと、を有する計算機システムにおいて、前記管理システムのプロセッサに、
アプリケーションが使用すべき前記仮想ボリュームの割り当てについての入力指示に応答して、前記アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得する処理と、
前記消費容量動向に関する情報に基づいて、前記割当て予定の仮想ボリュームおける消費容量を予測する処理と、
を実行させるためのプログラム。
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2012548557A JP5395962B2 (ja) | 2010-12-13 | 2010-12-13 | 計算機システム、及びその管理方法、並びに、プログラム |
US13/061,894 US20120151174A1 (en) | 2010-12-13 | 2010-12-13 | Computer system, management method of the computer system, and program |
GB1303105.9A GB2496807B (en) | 2010-12-13 | 2010-12-13 | Computer system, management method of the computer system, and program |
PCT/JP2010/072377 WO2012081074A1 (ja) | 2010-12-13 | 2010-12-13 | 計算機システム、及びその管理方法、並びに、プログラム |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/JP2010/072377 WO2012081074A1 (ja) | 2010-12-13 | 2010-12-13 | 計算機システム、及びその管理方法、並びに、プログラム |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2012081074A1 true WO2012081074A1 (ja) | 2012-06-21 |
Family
ID=46200607
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2010/072377 WO2012081074A1 (ja) | 2010-12-13 | 2010-12-13 | 計算機システム、及びその管理方法、並びに、プログラム |
Country Status (4)
Country | Link |
---|---|
US (1) | US20120151174A1 (ja) |
JP (1) | JP5395962B2 (ja) |
GB (1) | GB2496807B (ja) |
WO (1) | WO2012081074A1 (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2015063859A1 (ja) * | 2013-10-29 | 2015-05-07 | 株式会社日立製作所 | 計算機システム及び制御方法 |
Families Citing this family (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP5492731B2 (ja) * | 2010-10-06 | 2014-05-14 | 株式会社日立製作所 | 仮想計算機のボリューム割当て方法およびその方法を用いた計算機システム |
CN103080894A (zh) * | 2010-12-28 | 2013-05-01 | 株式会社日立制作所 | 存储系统、存储系统的管理方法和程序 |
US9639402B2 (en) * | 2011-08-05 | 2017-05-02 | Oracle International Corporation | Systems and methods for automatic hardware provisioning based on application characteristics |
US20130262811A1 (en) * | 2012-03-27 | 2013-10-03 | Hitachi, Ltd. | Method and apparatus of memory management by storage system |
US8904144B1 (en) * | 2012-05-24 | 2014-12-02 | Netapp, Inc. | Methods and systems for determining at risk index for storage capacity |
JP2017004114A (ja) * | 2015-06-05 | 2017-01-05 | キヤノン株式会社 | 画像形成装置及びアプリケーションの削除方法 |
US10228856B2 (en) * | 2016-01-28 | 2019-03-12 | Hewlett Packard Enterprise Development Lp | Storage space management in a thin provisioned virtual environment |
JP6878369B2 (ja) * | 2018-09-03 | 2021-05-26 | 株式会社日立製作所 | ボリューム配置管理装置、ボリューム配置管理方法、及びボリューム配置管理プログラム |
US11683666B2 (en) * | 2019-06-18 | 2023-06-20 | Nokia Technologies Oy | Data transmission |
US11163476B2 (en) * | 2019-10-04 | 2021-11-02 | International Business Machines Corporation | Dynamic rebalancing of free space between storage pools |
US20220057947A1 (en) * | 2020-08-20 | 2022-02-24 | Portworx, Inc. | Application aware provisioning for distributed systems |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2008097502A (ja) * | 2006-10-16 | 2008-04-24 | Hitachi Ltd | 容量監視方法及び計算機システム |
JP2008112276A (ja) * | 2006-10-30 | 2008-05-15 | Hitachi Ltd | 再配置システムおよび再配置方法 |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4124331B2 (ja) * | 2002-09-17 | 2008-07-23 | 株式会社日立製作所 | Dbms向け仮想ボリューム作成・管理方法 |
JP5037881B2 (ja) * | 2006-04-18 | 2012-10-03 | 株式会社日立製作所 | ストレージシステム及びその制御方法 |
EP2184681A1 (en) * | 2008-10-31 | 2010-05-12 | HSBC Holdings plc | Capacity control |
US8261018B2 (en) * | 2009-05-25 | 2012-09-04 | Hewlett-Packard Development Company, L.P. | Managing data storage systems |
US20110153978A1 (en) * | 2009-12-21 | 2011-06-23 | International Business Machines Corporation | Predictive Page Allocation for Virtual Memory System |
-
2010
- 2010-12-13 WO PCT/JP2010/072377 patent/WO2012081074A1/ja active Application Filing
- 2010-12-13 JP JP2012548557A patent/JP5395962B2/ja not_active Expired - Fee Related
- 2010-12-13 US US13/061,894 patent/US20120151174A1/en not_active Abandoned
- 2010-12-13 GB GB1303105.9A patent/GB2496807B/en not_active Expired - Fee Related
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2008097502A (ja) * | 2006-10-16 | 2008-04-24 | Hitachi Ltd | 容量監視方法及び計算機システム |
JP2008112276A (ja) * | 2006-10-30 | 2008-05-15 | Hitachi Ltd | 再配置システムおよび再配置方法 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2015063859A1 (ja) * | 2013-10-29 | 2015-05-07 | 株式会社日立製作所 | 計算機システム及び制御方法 |
Also Published As
Publication number | Publication date |
---|---|
GB201303105D0 (en) | 2013-04-10 |
JP5395962B2 (ja) | 2014-01-22 |
JPWO2012081074A1 (ja) | 2014-05-22 |
GB2496807B (en) | 2019-11-06 |
GB2496807A (en) | 2013-05-22 |
US20120151174A1 (en) | 2012-06-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5395962B2 (ja) | 計算機システム、及びその管理方法、並びに、プログラム | |
US8122116B2 (en) | Storage management method and management server | |
JP5439581B2 (ja) | ストレージシステム、ストレージ装置、ストレージシステムの記憶領域の最適化方法 | |
US9182926B2 (en) | Management system calculating storage capacity to be installed/removed | |
JP5502232B2 (ja) | ストレージシステム、及びその制御方法 | |
US8346934B2 (en) | Method for executing migration between virtual servers and server system used for the same | |
JP5451875B2 (ja) | 計算機システム及びその記憶制御方法 | |
JP5363595B2 (ja) | 仮想ボリューム内のデータの再配置を行うストレージシステム及び方法 | |
JP5668151B2 (ja) | 計算機システムの管理装置及び管理方法 | |
JP5185445B2 (ja) | ストレージシステム及びストレージシステムにおける使用容量管理方法 | |
US20110320754A1 (en) | Management system for storage system and method for managing storage system | |
JP5706531B2 (ja) | 計算機システム、及び情報管理方法 | |
JP5073259B2 (ja) | 仮想化システム及び領域割当て制御方法 | |
JP4733461B2 (ja) | 計算機システム、管理計算機及び論理記憶領域の管理方法 | |
WO2013159619A1 (en) | Reducing power consumption by migration of data within tiered storage system | |
JP2010122814A (ja) | ストレージシステム及びストレージシステムの運用方法 | |
JP2015520876A (ja) | 情報記憶システム及び情報記憶システムの制御方法 | |
JP2015517147A (ja) | 空間節約(spacesavings:空き容量節約)を達成するように処理をスケジューリングするためのシステム、方法及びコンピュータープログラム製品 | |
JP2013114624A (ja) | ストレージシステム及びプール容量縮小の制御方法 | |
JP4335597B2 (ja) | ストレージ管理システム | |
WO2012039062A1 (ja) | ストレージ装置における複数の記憶デバイスを複数の階層に振り分ける方法及びシステム | |
US20140058717A1 (en) | Simulation system for simulating i/o performance of volume and simulation method | |
JPWO2015107626A1 (ja) | 計算機システムおよびその階層記憶の制御方法 | |
JP2015111460A (ja) | 管理計算機、計算機システム、及び管理方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
WWE | Wipo information: entry into national phase |
Ref document number: 13061894 Country of ref document: US |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 10860808 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2012548557 Country of ref document: JP Kind code of ref document: A |
|
ENP | Entry into the national phase |
Ref document number: 1303105 Country of ref document: GB Kind code of ref document: A Free format text: PCT FILING DATE = 20101213 |
|
WWE | Wipo information: entry into national phase |
Ref document number: 1303105.9 Country of ref document: GB |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 10860808 Country of ref document: EP Kind code of ref document: A1 |