[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO2012081074A1 - 計算機システム、及びその管理方法、並びに、プログラム - Google Patents

計算機システム、及びその管理方法、並びに、プログラム Download PDF

Info

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
Application number
PCT/JP2010/072377
Other languages
English (en)
French (fr)
Inventor
直幸 松永
草間 隆人
Original Assignee
株式会社日立製作所
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 株式会社日立製作所 filed Critical 株式会社日立製作所
Priority to JP2012548557A priority Critical patent/JP5395962B2/ja
Priority to US13/061,894 priority patent/US20120151174A1/en
Priority to GB1303105.9A priority patent/GB2496807B/en
Priority to PCT/JP2010/072377 priority patent/WO2012081074A1/ja
Publication of WO2012081074A1 publication Critical patent/WO2012081074A1/ja

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • G06F3/0607Improving 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0644Management of space entities, e.g. partitions, extents, pools
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0653Monitoring storage devices or systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0662Virtualisation aspects
    • G06F3/0665Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/067Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices
    • G06F3/0689Disk arrays, e.g. RAID, JBOD
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2206/00Indexing scheme related to dedicated interfaces for computers
    • G06F2206/10Indexing scheme related to storage interfaces for computers, indexing schema related to group G06F3/06
    • G06F2206/1008Graphical 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

 新規アプリケーションの追加や既存アプリケーションの特性変更等の外部環境の変化があっても適切にプール容量枯渇のタイミングを予測することができるプール容量監視技術を提供する。本発明では、プールの容量枯渇タイミングを予測するため、アプリケーションの追加等の外部環境変化がある度にプールを構成するメディア毎の消費量を予測し、容量枯渇時期の予測を再計算する。また、仮想ボリュームを利用するアプリケーション毎のI/O消費傾向を、ストレージ内に貯めた過去の消費傾向からメディア毎に予測値を算出する。

Description

計算機システム、及びその管理方法、並びに、プログラム
 本発明は、計算機システム、及びその管理方法、並びに、プログラムに関し、例えば、1つ以上のメディア(記憶デバイス)の複数の記憶領域から構成されるストレージプールの容量を把握する技術に関するものである。
 近年の各種業務のIT化に伴い、企業が保持するデータ数は増得続けている。このような状況で、SAN(Storage Area Network)によるストレージ集約が広く利用されつつある。
 また、ストレージ管理コストを軽減する技術として、Thin Provisioningが注目を集めている。Thin Provisioningとは、ストレージがホストに対して仮想ボリュームを割り当て、かつ、ホストからのI/O要求に従って、動的かつ段階的に仮想ボリュームに対してストレージ内のディスク容量を割り当てる技術である。これにより、ホストに割り当てる全ボリュームに対して、ディスクを事前に購入することなく、ホストのストレージ利用状況(具体的には利用ディスクサイズ)を基に段階的にディスクを増強することができる。このようなThin Provisioningに関しては、ストレージ内部に複数のディスクから構成されたプールを構築し、このプールからホストに割り当てる仮想ボリュームを作成し、かつ、ホスト計算機からの当該仮想ボリュームへのI/O要求に伴いプール内のディスクを動的に割り当てる方法がある。このケースでは、プールを管理する必要がある。つまり、定期的にプールの空き容量を監視し、プールの容量枯渇によるI/Oエラーを防止する必要がある。
 さらに、Thin Provisioningを拡張し、異なる物理特性のディスクの組合せでプールを構成し(例えばSSDとSATAディスク)、I/O頻度が高いデータを高速ディスク(例えばSSD)に配置し、I/O頻度が低いデータを低速ディスク(例えばSATA)に配置することもできる。この場合にもThin Provisioningのケースと同様にプールの空き容量を監視する必要がある。
特開2003-216460号公報
 ところで、上述したThin Provisioningにおける従来のプール容量監視技術(従来方法)では、プールの容量枯渇タイミングを予測するため、過去のプールの容量消費傾向から将来の消費傾向を予測し、容量枯渇が発生する時期を予測している。
 しかしながら、上記従来方法では、外的環境の変更については考慮されていない。つまり、従来方法では、過去のプールの容量消費傾向にのみ基づいて将来の消費傾向を予測していたため、既存プールから新規アプリケーションへのボリューム割り当て等の構成変更によるプール容量消費傾向の変化を予測できない。
 また、従来方法で構成変更によるプール容量消費傾向の変化を予測する場合、新規ボリュームのプール容量消費傾向を予測可能になるまで履歴を取得する必要があり、ボリューム追加のタイミングでプール容量枯渇タイミングを把握することができない。
 本発明はこのような状況に鑑みてなされたものであり、新規アプリケーションの追加や既存アプリケーションの特性変更等の外部環境の変化があっても適切にプール容量枯渇のタイミングを予測することができるプール容量監視技術を提供するものである。
 上記課題を解決するために、プールの容量枯渇タイミングを予測するため、アプリケーションの追加等の外部環境変化がある度にプールを構成するメディア毎の消費量を予測し、容量枯渇時期の予測を再計算する。また、仮想ボリュームを利用するアプリケーション毎のI/O消費傾向を、ストレージ内に貯めた過去の消費傾向からメディア毎に予測値を算出する。
 即ち、本発明による計算機システムは、1つ以上の物理記憶デバイスの記憶領域を仮想ボリュームとしてホスト計算機に提供するストレージサブシステムと、ストレージサブシステムを管理する管理計算機と、を有している。そして、管理計算機は、アプリケーションが使用すべき仮想ボリュームの割り当てについての入力指示に応答して、アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得し、当該消費容量動向に関する情報に基づいて、割当て予定の仮想ボリュームおける消費容量を予測する。
 本発明によれば、新規アプリケーションの追加や既存アプリケーションの特性変更等の外部環境の変化があっても適切にプール容量枯渇のタイミングを予測することができるようになる。
 なお、上述した以外の課題、構成及び効果は、以下の本発明を実施するための形態および添付図面によって明らかになるものである。
本発明の実施形態による計算機システムの概略構成を示す図である。 ホスト計算機の内部構成を示す図である。 ストレージサブシステムの内部構成を示す図である。 RAIDグループ管理表の構成例を示す図である。 実領域管理表の構成例を示す図である。 仮想ボリューム(VVOL)管理表の構成例を示す図である。 階層定義表の構成例を示す図である。 プール-仮想ボリューム(VVOL)対応管理表の構成例を示す図である。 管理計算機の内部構成を示す図である。 アプリケーション名とアプリケーションタイプと仮想ボリュームIDの対応関係を示すマッピングテーブルの構成例を示す図である。 仮想ボリューム容量情報テーブルの構成例を示す図である。 プール容量予測テーブルの構成例を示す図である。 計算機システムにおける処理の全体的概要を説明するための図である。 アプリケーション情報入力画面(GUI)の構成例を示す図である。 階層管理表設定画面(GUI)の構成例を示す図である。 プール容量予測結果レポート画面の構成例を示す図である。 再配置処理を説明するためのフローチャートである。 管理計算機が実行する処理の概要について説明するためのフローチャートである。 アプリケーション追加時における、新規VOLへのPage割当て量予測エンジンの処理の詳細を説明するためのフローチャートである。 既存VOLへのPage割当て量予測エンジンの処理概要について説明するためのフローチャートである。 プールの各Tierの予測容量消費量算出処理(ステップ2001)の詳細を説明するためのフローチャートである。 プールの各Tierの容量消費量算出処理(ステップ2002)の詳細を説明するためのフローチャートである。 アプリケーション削除画面(GUI)の構成例を示す図である。 Tier毎の課金設定画面(GUI)の構成例を示す図である。 Tier毎の課金管理テーブルの構成例を示す図である。 プール容量予測結果レポート画面の構成例を示す図である。
 以下、添付図面を参照して本発明の実施形態について説明する。ただし、本実施形態は本発明を実現するための一例に過ぎず、本発明の技術的範囲を限定するものではないことに注意すべきである。また、各図において共通の構成については同一の参照番号が付されている。
 なお、以後の説明では「aaaテーブル」という表現にて本発明の情報を説明するが、これら情報は必ずしもテーブルによるデータ構造で表現されていなくても良く、リスト、DB、キュー等のデータ構造やそれ以外で表現されていても良い。そのため、データ構造に依存しないことを示すために「aaaテーブル」、「aaaリスト」、「aaaDB」、「aaaキュー」等について「aaa情報」と呼ぶことがある。
 また、各情報の内容を説明する際に、「識別情報」、「識別子」、「名」、「名前」、「ID」という表現を用いることが可能であり、これらについてはお互いに置換が可能である。
 以後の説明では「プログラム」「エンジン」「エージェント」を主語として説明を行うが、プログラム等はプロセッサによって実行されることで定められた処理をメモリ及び通信ポート(通信制御装置)を用いながら行うため、プロセッサを主語とした説明としてもよい。また、プログラムを主語として開示された処理は管理サーバ等の計算機、情報処理装置が行う処理としてもよい。プログラムの一部または全ては専用ハードウェアで実現してもよく、また、モジュール化されていても良い。各種プログラムはプログラム配布サーバや記憶メディアによって各計算機にインストールされてもよい。
 <計算機システムの構成>
 図1は、本発明の実施形態による計算機システム100の概略構成を示す図である。計算機システム100は、ホスト計算機101と、ストレージサブシステム102と、管理システム107と、を有している。ストレージサブシステム102とホスト計算機101とは、ストレージエリアネットワーク105によって接続されている。また、管理システム107とストレージサブシステム102及びホスト計算機101とは、管理用ネットワーク106によって接続されている。
 管理システム107は、管理計算機103とWebブラウズ用計算機104を含む。なお、管理計算機103とWebブラウズ用計算機104とは、同じ計算機でもよく、また、それぞれ複数の計算機で同等の機能を実現していてもよい。管理システム107は、管理用ネットワーク106を介してストレージサブシステム102に制御要求を送信する。
 ホスト計算機101は、管理用ネットワーク106を介して管理システム107にアクセス要求を送信する。
 ストレージサブシステム102は、管理システム107から管理用ネットワーク106を介して制御要求を受信し、要求に従う処理を実行する。なお、本計算機システム100に含まれるホスト計算機101、ストレージサブシステム102、及び管理システム107は、それぞれ複数設置しても良い。
 <ホスト計算機の構成>
 図2は、ホスト計算機101の内部構成を示す図である。ホスト計算機101は、ストレージエリアネットワーク105との接続を実現するためのSANポート203と、管理用ネットワーク106との接続を実現するためのLANポート205と、メモリ202と、メモリ202およびSANポート203、LANポート205に接続されたCPU201と、を有する。
 SANポート203は、ストレージエリアネットワーク105に接続されている。また、LANポートは管理用ネットワーク106に接続されている。
 メモリ202には、1つ以上のアプリケーションプログラム204が格納されている。各アプリケーションプログラム204は、CPU201によって実行され、LANポート205、および管理用ネットワーク105を介して、ストレージサブシステム102にアクセス要求を送信する。
 <ストレージサブシステムの構成>
 図3は、ストレージサブシステム102の内部構成を示す図である。ストレージサブシステム102は、ディスク回転数等の物理特性の異なる複数の物理記憶デバイス305と、コントローラ312を有し、これらは内部バス等の回路を介して相互に接続されている。同種の物理記憶デバイス305が複数ある場合、それらはRAID構成を組んでいてもよい。RAID構成を組んでいる複数の物理記憶デバイス305は、RAIDグループ306を構成する。
 コントローラ312は、ストレージエリアネットワーク105に接続するための少なくとも1つのSANポート302と、管理用ネットワーク106に接続するための少なくとも1つのLANポート303と、メモリ304と、それらに接続されたCPU301と、を有する。
 SANポート302は、ストレージエリアネットワーク105に接続されるポートである。SANポート302は、ホスト計算機101からのアクセス要求を受信する。
 LANポート303は、管理用ネットワーク106に接続されるポートである。LANポート303は、管理システム107からの制御要求を受信する。
 メモリ304には、ストレージ制御プログラム307と、RAIDグループ管理表308と、実領域管理表309と、階層管理表310と、VVOL管理表311とストレージ情報取得エージェント313と、プール-仮想ボリューム対応管理表314と、が格納されている。
 ストレージ情報取得エージェント313は、ストレージサブシステム102内コントローラ312より、ストレージサブシステム102から、各VOLについて、Tier毎の割当て容量の情報を取得するプログラムである。なお、取得する情報については後述する。
 ストレージ制御プログラム307は、CPU301で実行されることにより、指定された管理システム107に対してのみ、後述する仮想ボリュームに対してアクセス可能とするアクセス制御処理とデータ書き込み処理と再配置処理を行う。
 ストレージ制御プログラム307は次のようにデータ書き込み処理を実行する。つまり、まず、ストレージ制御プログラム307は、データ書き込み要求をホスト計算機101から受信すると、データ書き込み要求が有するアクセス先情報を基に、データを書き込む先の仮想領域(以下、書き込み先仮想領域)を特定する。
 次に、ストレージ制御プログラム307は、書き込み先仮想領域に実領域が割り当てられているか否かを判断する。具体的には、書き込み先仮想領域がVVOL管理表311に登録されているか否かを判断する。
 書き込み先仮想領域に実領域が割り当てられている場合、ストレージ制御プログラム307は、書き込み対象データを書き込み先仮想領域に割り当てられている実領域に書き込む。書き込み先仮想領域に実領域が割り当てられていない場合、ストレージ制御プログラム307は、書き込み先仮想領域に割り当てられる未割当の実領域が存在するか否かを判断する。具体的には、ストレージ制御プログラム307は、実領域管理表309の割当状況504が「未割当」である実領域が存在するか否かを判断する。
 書き込み先仮想領域に未割当の実領域が存在する場合、ストレージ制御プログラム307は、書き込み先仮想領域に未割当の実領域を割り当てて、書き込み対象データを当該実領域に書き込む。
 書き込み先仮想領域に未割当の実領域が存在しない場合、ストレージ制御プログラム307は、ホスト計算機101にエラーを送信する。
 また、ストレージ制御プログラム307は書き込み先仮想領域がプールの構成要素であるかを判断する。プールの構成要素で合った場合はプールの識別子であるプールID2302と仮想ボリュームの識別子であるVVOLID2301の組の値をプールと仮想ボリュームとの対応管理表2301に書き込む。
 最後に、ストレージ制御プログラム307は、書き込み元仮想領域に対応するアクセス数604の値を更新する。
 <仮想ボリュームの実現方法>
 ストレージ制御プログラム307は、後述する図4に示すように、複数の物理記憶デバイスからRAIDグループを構築する。ストレージ制御プログラム307は、ホスト計算機101から指定された仮想ボリュームを割当てる際、ボリュームサイズに対応した物理ディスクを当該ホスト計算機101に割当てるわけではなく、ボリュームの利用状況に応じて動的に物理ディスクを割当てる。以降では、このボリュームを仮想ボリューム(「VVOL」ともいう)と呼ぶこととする。
 上述の仮想ボリュームを実現する方法として、ストレージ制御プログラム307は、まず、各RAIDグループを固定サイズ(例えば1000ブロック)に分割する。以降では分割した単位をセグメントと呼ぶ。また、ストレージ制御プログラム307は、後述する図5に示すように、各セグメントの割当て状況を把握し、ある仮想ボリュームに新規セグメントを割当てる際に、未割当セグメントを利用する。
 なお、ストレージ制御プログラム307が実行する再配置処理については、後述する。
 <RAIDグループ管理表308>
 図4は、ストレージサブシステム102が有するRAIDグループ管理表308の構成例を示す図である。RAIDグループ管理表308は、RAIDグループ306の性能に関する情報を有する。
 例えば、RAIDグループ管理表は、RAIDグループの識別子を表すRAIDグループID401と、RAIDグループを構成する物理記憶デバイスの種類を表すデバイス種別402と、RAIDグループのRAIDレベルおよびコンビネーションを表すRAIDレベル403と、RAIDグループを構成する物理記憶デバイスの識別子を表すPDEV_ID404と、を構成項目として含んでいる。なお、情報401~404のうちの少なくとも1つに代えてまたは加えて、他種の情報が含まれていてもよい。
 <実領域管理表309>
 図5は、ストレージサブシステム102が有する実領域管理表309の構成例を示す図である。実領域管理表309は、各RAIDグループ306が持つ実領域が、仮想ボリュームに割当済か否かの情報を有する。
 例えば、実領域管理表309は、実領域を持つRAIDグループの識別子を表すRAIDグループID501と、実領域の識別子を表す実領域ID502と、実領域に対応するRAIDグループのLBA範囲を表すRG_LBA範囲503と、実領域が割当済か否かを表す割当状況504と、を構成項目として含んでいる。
 <VVOL(仮想ボリューム)管理表311>
 図6は、ストレージサブシステム102が有するVVOL管理表311の構成例を示す図である。VVOL管理表311は、仮想ボリューム内の各仮想領域と、その仮想領域に割り当てられている実領域に関する情報を有する。
 例えば、VVOL管理表311は、仮想ボリュームの識別子を表すVVOL ID601と、仮想ボリューム内の仮想領域に対応するLBA範囲を表すVVOL LBA範囲602と、仮想ボリューム内の仮想領域に割り当てられている実領域を表す実領域ID603と、仮想ボリューム内の仮想領域に対する、ホスト計算機101からのアクセス数(一定期間内での累計のI/O数)を表すアクセス数604と、後述する再配置処理(図17参照)において仮想ボリューム内の仮想領域にその階層内の実領域を割り当てるべきであると判定された当該階層の識別子を表す再配置判定結果605を構成項目として含んでいる。
 上記VVOL管理表311において、VVOL_ID601は、ホスト計算機101から指定される識別子ではなく、ストレージサブシステム102の内部で認識される識別子を示す情報である。アクセス数604は、当該仮想領域に対するアクセス回数の値を持っており、ストレージサブシステム102は一定期間、例えば24時間ごとに、アクセス数604の値を0にリセットする。また、再配置判定結果605には、ストレージ制御プログラム307がTierの許容アクセス数を監視し、図7に示す階層管理表310の許容アクセス数範囲703の値に基づいて判定した結果を格納する。
 なお、図6における再配置判定結果605は、再配置判定を実行した後であるが、再配置処理は実行していない状態での判定結果の情報を示している。従って、再配置判定結果605が示す階層の情報と、実領域ID603が示す領域が属するデバイスが属する階層が合致していないことに注意すべきである。再配置処理を実行した直後は、両者の情報は合致したものとなっている。
 <階層定義表310>
 図7は、ストレージサブシステム102が有する階層定義表310の構成例を示す図である。階層定義表310は、階層の性能及び許容するアクセス数の範囲に関する情報を有する。
 例えば、階層定義表310は、階層毎に、階層の識別子を表す階層ID701と、階層の性能要件を表す性能要件702と、階層に対応した、単位時間当たりの許容アクセス数の範囲を表す許容IOPS範囲703と、を構成項目として含んでいる。階層定義表310において、階層の性能要件702は、例えば、物理記憶デバイスの種別と、RAIDグループのRAIDレベルとで定義される。
 階層IDで特定される各階層701は、性能要件702を満たす物理記憶デバイスまたは/およびRAIDグループに属する実領域を要素に持っている。
 なお、階層定義表310は、管理計算機103或いはホスト計算機101からの要求に応じて管理用ネットワークを介してストレージサブシステム102のLANポート303のメモリ304の階層管理表310に設定される。
 <プール-仮想ボリューム対応管理表314>
 図8は、プールと仮想ボリュームとの対応関係を管理する、プール-仮想ボリューム(VVOL)対応管理表314の構成例を示す図である。
 例えば、プール-仮想ボリューム対応管理表314は、プールID3141と、VVOL_ID3142と、を構成項目として含んでいる。
 プール-仮想ボリューム対応管理表314により、各プールがどの仮想ボリュームから構成されているかが分かる。例えば、プールAは、仮想ボリューム(VVOL)AとBとから構成されている。この情報は、ストレージ制御プログラム307によって取得され、必要な処理に用いられる。
 <管理計算機の構成>
 図9は、管理計算機103の内部構成を示すブロック図である。管理計算機103は、管理用ネットワーク106に接続するためのLANポート802と、構成管理プログラム804を実行するCPU801と、CPU801が用いるメモリ803とを有し、これらは内部バス等の回路を介して相互に接続されている。
 メモリ803は、アプリケーション情報取得エンジン804と、プール容量予測エンジン805と、新規VOLへのPage割当て量予測エンジン806と、既存VOLへのPage割当て量予測エンジン807と、結果表示エンジン808と、Tier定義取得エンジン809と、ストレージ情報取得エンジン810を格納している。ここで、「エンジン」とはリクエストを出して所望の情報を取得するプログラムを意味し、特に断らない限り、「プログラム」と読み替えても良い。
 また、管理計算機103は、記憶装置811と、表示装置813と、入力装置814を有している。記憶装置811はデータ格納用DB812を有している。
 なお、管理計算機50が有する入力装置400の例としてキーボードとポインタデバイスが考えられるが、これ以外の装置であっても良い。また、表示装置401に代えて、或いはそれに加えて、それ以外の出力装置(例えば、プリンタ)を設けるようにしても良い。
 入力装置及び表示装置(出力装置)の代替としてシリアルインターフェースやイーサーネットインターフェースを入出力装置とし、当該インターフェースにディスプレイ又はキーボード又はポインタデバイスを有する表示用計算機を接続し、表示用情報を表示用計算機に送信したり、入力用情報を表示用計算機から受信することで、表示用計算機で表示を行ったり、入力を受け付けることで入出力装置での入力及び表示を代替してもよい。
 以後、計算機システム100を管理し、本願発明の表示用情報を表示する1つ以上の計算機の集合を管理システムと呼ぶことがある。管理計算機103が表示用情報を表示する場合は管理計算機103が管理システム107であり、また、管理計算機103とWebブラウズ用計算機(表示用計算機)104の組み合わせも管理システム107である。また、管理処理の高速化や高信頼化のために複数の計算機で管理計算機と同等の処理を実現してもよく、この場合は当該複数の計算機(表示を表示用計算機が行う場合は表示用計算機も含め)が管理システム107である。
(i)アプリケーション情報取得エンジン
 アプリケーション情報取得エンジン804は、アプリケーション情報入力画面1301(図14参照)で入力したユーザが割当て予定のVOLとアプリケーションとの対応関係を取得し、管理計算機103の記憶装置811のデータ格納用DBに存在するアプリケーションとボリュームとのマッピングテーブル901に格納する。なお、マッピングテーブル901は、データ格納用DB812の中に含まれている。
 アプリケーション情報取得エンジン804は、入力画面1301から入力された新規に追加されるアプリケーション名と、アプリケーションタイプと、仮想ボリュームの情報を取得し、それらをマッピングテーブル901(図10参照)に格納する。
 マッピングテーブル901は、図10に示されるように、アプリケーション名902と、アプリケーションタイプ903と、仮想VOL_ID904と、を構成項目として含んでいる。このテーブルを確認することにより、どのようなアプリケーションがどの仮想ボリュームに割り当てられているか把握することができるようになっている。
 なお、アプリケーション情報取得エンジン804の処理の延長で割当て予定のボリューム(VOL)をホスト計算機101に割当ててもよい。また、ユーザからの割当て指示の入力がなされて直ぐにVOLを割り当てても良いし、割当て予定のVOLをユーザから指示された指定期間経過後に割当てるというように予約できるようにしても良い。
(ii)Tier定義取得エンジン
 Tier定義取得エンジン809は、階層管理表設定画面1401(図15参照)を用いてユーザが入力した情報を取得し、管理計算機103のLANポート802と管理用ネットワーク106とストレージサブシステム102のLANポート303を介してストレージサブシステム102のメモリ304内の階層管理表310に格納する。
 より具体的には、Tier定義取得エンジン809は、例えばストレージサブシステム102のストレージ制御プログラム307と協働して、階層管理表310に対して、階層ID1402を階層ID701に、デバイス種別1403及びRAIDレベル1404を性能要件702に、許容アクセス数範囲1405を許容アクセス数範囲703に、それぞれ格納することになる。
(iii)ストレージ情報取得エンジン
 ストレージ情報取得エンジン810は、定期的に管理計算機103のCPU801で実行される。実行時、ストレージ情報取得エンジン810は、ストレージサブシステム102のメモリ304のストレージ情報取得エージェント313から各VVOLについてTier毎の割当て容量を取得する。そして、ストレージ情報取得エンジン810は、取得した情報を、LANポート303と管理用ネットワーク106とLANポート802と記憶装置811を介して、データ格納用DB812内の仮想ボリューム容量情報テーブル1001へ格納する。
 より具体的には、ストレージ情報取得エンジン810は、仮想ボリューム容量情報テーブル1001のVVOLID1004に、VOL管理表311のVVOL_ID601を格納する。また、ストレージ情報取得エンジン810は、VVOLのトータル容量をVVOL容量1005に、VVOLの各Tier利用量の情報をTier1利用量1006、Tier2利用量1007、及びTier3利用量1008に、データ収集した時刻を収集時間1002に、それぞれ格納する。さらに、ストレージ情報取得エンジン810は、当該VVOLが属するプール名をプール-仮想ボリューム対応管理表314のプールID3141から取得してプールID1003に格納する。
(iv)プール容量予測エンジン
 プール容量予測エンジン805は、アプリケーション及びVVOLの追加または、既存のVVOLへのPage割当て、増加後のプールの容量を予測するエンジンである。具体的には、新規VOLへのPage割当て量予測エンジン806と既存VOLへのPage割当て量予測エンジン807を起動し、新規VOLへのPage割当て量予測エンジン806と既存VOLへのPage割当て量予測エンジン807が算出した値を合計した上で結果をプール容量予測テーブル1101(図12参照)に格納する。なお、本実施形態では、従来のPool単位での容量予測ではなく、各Tierについて容量予測を行うようにしている。
(v)新規VOLへのPage割当て量予測エンジン
 新規VOLへのPage割当て量予測エンジン806は、アプリケーション情報入力画面1301のアプリケーション名1307とアプリケーションタイプ1308と予測期間1309の情報から、過去に導入済みの同一、同種或いはアプリケーションの利用するボリュームの消費傾向が類似するアプリケーション(以下、「類似等するアプリケーション」ということとする)の情報をアプリケーションとボリュームとのマッピングテーブル901から特定する。そして、新規VOLへのPage割当て量予測エンジン806は、導入当初から測期間1309で指定した期間分の過去のVVOLの容量消費傾向を仮想ボリューム容量情報テーブル1001から取得する。さらに、新規VOLへのPage割当て量予測エンジン806は、上記類似等するアプリケーションのVVOLの容量消費傾向から、各Tierの利用率を算出しプール容量予測エンジン805に算出した値を返す。なお、各Tierの利用率の算出方法については、図19を用いて後述する。
(vi)既存VOLへのPage割当て量予測エンジン
 既存VOLへのPage割当て量予測エンジン807は、ストレージサブシステム102が管理する各プールについて、Tier毎の割当て済みPage数の履歴情報を仮想ボリューム容量情報テーブル1001から取得し、最尤推定法(例えば、最小二乗法)を用いて、アプリケーション情報入力画面1301で指定した予測期間1309後のプールの容量消費量を予測する。予測した算出結果をプール容量予測エンジン805に返す。なお、算出方法については、図20乃至22を用いて後述する。
(vii)結果表示エンジン
 結果表示エンジン808は、プール容量予測エンジンが起動する。プール容量予測テーブル1101から、データを取得し、表示装置813にプール容量予測結果レポート画面1501を出力する。
  <本システムにおける処理概要>
 本実施形態によるストレージサブシステム102は、定期的に、ストレージサブシステム102が提供するプールと仮想ボリュームの構成情報と容量情報を収集する処理と、ユーザが指定するTierの階層管理を行うための入力情報を基にTierを再配置する処理と、を実行する。
 プールは、複数の階層で構成されている。階層は、同じ性能を有する実領域の集合である。階層は例えば性能を表す特定の値によって定義され、その値が表す性能と同じ性能を有する実領域を内包する。階層は、他の階層と比較した高低の概念を持つ。階層の高さは、階層の性能の高さに依存する。なお、ここで言う「性能」とは、例えばアクセス性能であり、レスポンスタイム、あるいはデータ転送速度、IOPS(単位時間当たりに処理したアクセス要求の数)等が含まれる。アクセス要求の一例としてはライト要求又はリード要求がある。
 各階層は、2以上の実領域で構成されている。したがって、プールは複数の実領域で構成されていると言うことができる。また、実領域は、物理記憶デバイスまたは/およびRAIDグループの記憶領域の一部である。階層の性能は、階層を構成する実領域の性能に依存する。実領域の性能は、例えば、当該実領域を有する物理記憶デバイスの種別、RAIDグループのRAIDレベル、または/およびRAIDグループに参加する記憶デバイスの数に依存する。物理記憶デバイスの種別として、例えば、SSDと、SAS-HDD、およびSATA-HDDがある。
 仮想ボリュームは、複数の仮想領域(仮想的な記憶領域)で構成されている。各仮想領域には、それぞれ1つ以下の実領域が割り当てられている。なお、仮想領域には、実領域が割り当てられていなくてもよい。ストレージサブシステム102は、そのような仮想領域(未割当の仮想領域)に対するライト要求をホスト計算機から受けたときには、いずれの仮想領域にも割り当てられていない実領域(未割当の実領域)を、当該仮想領域に割り当てるようにする。
 一方、管理計算機103は、ユーザが指定する追加すべきアプリケーションとVVOLの情報の情報を基に、アプリケーションが利用するVVOLの容量消費傾向を予測し、予測結果をレポーティング(出力)する処理を実行する。これらついては、データ構造と処理フローを中心にシステム全体の概略は図13を用いて説明する。図13は、本システムにおける処理の全体的概要を説明するための図である。
(i)追加すべきアプリケーションの情報入力からプール要領予測結果出力までの処理
 管理システム107に表示されるアプリケーション情報入力画面1301から追加或いは、ボリュームの対応を変更するアプリケーションについての情報が入力されると、アプリケーション情報取得エンジン804は、その入力情報をアプリケーションとボリュームとのマッピングテーブル901に格納する。
 そして、プール予測エンジン806は、新規VOLへのPage割当て量予測エンジン806及び既存VOLへのPage割当て量予測エンジン807を起動する。両エンジン896及び807はそれぞれの処理を実行し、実行結果をプール容量予測エンジン805に提供する。実行結果を受け取ったプール容量予測エンジン805は、当該プール容量予測結果をプール容量予測テーブル1101に格納すると共に、結果表示エンジン808を起動する。また、起動された結果表示エンジン808は、プール容量予測テーブル1101から該当するプール容量予測結果を取得し、プール容量予測結果レポート画面1501(図16参照)に表示する。
(ii)ストレージ情報取得処理
 ストレージ情報取得エンジン810は、定期的にストレージサブシステム102内のデータをポーリングして各仮想ボリュームの容量を取得し、当該容量の情報を仮想ボリューム容量情報テーブル1001に格納する(図11参照)。
(iii)階層定義取得処理
 管理システム107に表示される階層管理表設定画面1401(図15参照)を用いて設定された階層の情報が入力されると、階層定義取得エンジン809は、ストレージサブシステム102の階層管理表310に格納する。
 <ストレージサブシステム102の定期的に実行するTier再配置処理>
 管理計算機103は、定期的にTierの再配置処理の実行をストレージサブシステム102に定期的に指示する。例えば、1時間や30分毎に、当該仮想ボリューム内の仮想領域に対する実領域の割当状況を見直す。
 管理計算機103は、当該仮想ボリューム内の各仮想領域について、仮想領域へのアクセス数が、当該仮想領域に割り当てられている実領域を有する階層に対応したアクセス数範囲を超えているか否かを判断する。管理システムは上記の判断の結果、範囲外であると判断した仮想領域に対して、当該仮想領域に割り当てられている実領域(以下、移行元の実領域)に代えて、当該仮想領域へのアクセス数が収まるアクセス数範囲に対応する階層内の実領域(以下、移行先の実領域)を割り当てる。具体的には、管理計算機103はストレージサブシステム102に、移行元の実領域のデータを移行先の実領域に移行するよう指示する。なお、ここで、仮想領域へのアクセス数とは、対象仮想領域の全てまたは一部について、アドレス範囲として指定し、処理が完了したアクセス要求数を意味する。
 <再配置処理>
 図17は、再配置処理の詳細を説明するためのフローチャートである。再配置処理は、VVOL管理表311のVVOLID601登録されている仮想ボリューム(以下、図17の説明において対象VVOL)に対して行う処理である。
 (ステップ1700の処理内容)
 管理計算機103は、一定時間毎(例えば30分毎や1時間毎)に、ストレージサブシステム102のストレージ制御プログラム307へ再配置処理の実行を要求する。
 (ステップ1701の処理内容)
 ストレージ制御プログラム307は、VVOL管理表311に登録される各VVOLID601のアクセス数604の値を取得し、各仮想領域のアクセス数604の値と階層管理表310の許容アクセス数範囲703とを突き合わせることで、現配置箇所が妥当かを判断した上で該当する階層ID701を特定する。この結果、記録された階層IDは、当該仮想領域に割り当てられている実領域を含む階層の階層IDと同じであることもあれば異なることもある。
 (繰り返し処理)
 次に、ストレージ制御プログラム307は、ステップ1701で取得したすべての仮想領域に対してステップ1703~1708の処理を実行する。
 (ステップ1703の処理内容)
 ストレージ制御プログラム307は、現在対象仮想領域に割り当てられている実領域に対応する階層(「対象領域配置元階層」という)のIDとステップ1701で特定した再配置判定結果の値とが一致するか否かを判定する。具体的には、ストレージ制御プログラム307は、対象仮想領域に割り当てられている実領域のID603を基に、その実領域を含むRAIDグループのID501を特定し、そのRAIDグループに対応するデバイス種別402または/およびRAIDレベル403が適合する性能要件702に対応する階層ID701を特定する。特定した階層ID701と、ステップ1701で特定した再配置判定結果の値が一致するか否かを判定する。
 対象領域配置元階層が配置されるべき階層の場合(ステップ1703でYesの場合)、対象の仮想領域のデータ移行は不要のため、対象の仮想領域に対する処理は終了する。一方、対象領域配置元階層が配置されるべき階層でない場合(ステップ1703でNoの場合)、処理はステップ1704に移行する。
 (ステップ1704の処理内容)
 ストレージ制御プログラム307は、実領域管理表309を基にステップ1701で特定した再配置判定結果の階層IDによって示される階層(「対象領域配置先階層」という)内に、未割当の実領域が存在するか否かを判定する。
 配置されるべき階層に空きがある場合(ステップ1704でYesの場合)、処理はステップ1706に移行し、配置されるべき階層に空きがない場合(ステップ1704でNoの場合)、処理はステップ1705に移行する。
 (ステップ1706の処理内容)
 ストレージ制御プログラム307は、対象仮想領域に現在割り当てられている実領域(「データ移行元実領域」という)に代えて、対象領域配置先階層内の未割当の実領域(「データ移行先実領域」という)を割り当てる。具体的には、ストレージ制御プログラム307は、実領域管理表309の、データ移行元実領域に対応する割り当て状況309の値を未割当に更新し、データ移行先実領域に対応する割り当て状況309の値を割当済みに更新する。なお、本実施形態では、例えば、実領域と仮想領域は同じ容量で区切られるように管理され、移行元と移行先の容量を考慮する必要がないようになっている。
 また、ストレージ制御プログラム307は、VVOL管理表311の、対象仮想領域に対応する実領域ID603の値を、データ移行先実領域のIDに更新する。また、ストレージ制御プログラム307はデータ移行元実領域からデータ移行先実領域にデータを移行する。
 なお、ステップ1706の処理を行うと、他の仮想ボリュームの性能に影響を及ぼす場合がある。例えば、ある仮想ボリュームの再配置処理において、ステップ1706の処理を行った結果、性能が高い階層内の未割当実領域を全て使い切ってしまう場合がある。この場合、この後に再配置処理を行う仮想ボリューム内の仮想領域には、当該階層内の未割当実領域を割り当てることができない。したがって、当該階層内の実領域を割り当てるべきであると判定された仮想領域が存在する場合、後述するステップ1707および1708の処理のように、当該階層内の実領域が割り当てられている他の仮想領域と割り当て状況およびデータを入れ替えたり、性能が近い他の階層の実領域を割り当てたりすることとなり、性能に影響を及ぼす場合がある。本事象に対処するためには、例えば、再配置処理において、対象VVOLの仮想領域に未割当の実領域を割り当てることは行わず、常に対象VVOL内の他の仮想領域との入れ替えのみによって、対象VVOL内仮想領域への実領域割り当て状況の最適化を実現する方法が考えられる。再配置処理において未割当の実領域を使用するか否かは、例えば、各階層内において未割当である実領域の個数または/および割合によって、ストレージ制御プログラム307が判断する。より具体的には、ストレージ制御プログラム307は、ステップ1704の処理において、対象領域配置先階層内に未割当実領域が存在したとしても、その個数が対象領域配置先階層内の全実領域数の1割よりも少ない場合は、ステップ1706の処理ではなくステップ1705の処理に移行する。
 (ステップ1705の処理内容)
 ストレージ制御プログラム307は、対象仮想領域に割り当てられている実領域と、データを入れ替え可能な実領域が存在するか否かを判定する。具体的には、ストレージ制御プログラム307は、対象領域配置先階層内の割当済の実領域の中で、その実領域が割り当てられている仮想領域に対応するステップ1701で特定した再配置判定結果の階層IDが、対象領域配置元階層の階層IDと一致するものが存在するか否かを判定する。
 入れ替え可能な実領域が存在する場合(ステップ1705でYesの場合)、処理はステップ1707に移行し、入れ替え可能な実領域が存在しない場合(ステップ1705でNoの場合)、処理はステップ1708に移行する。
 (ステップ1707の処理内容)
 ストレージ制御プログラム307は、対象仮想領域に割り当てられている実領域(以下、ステップ1707の説明において「対象実領域1」という)と、対象領域配置先階層が有する割当済実領域(以下、ステップ1707の説明において「対象実領域2」という)との間で、仮想領域への割り当て状況を入れ替える。具体的には、ストレージ制御プログラム307は、VVOL管理表311の実領域ID603において、対象実領域1のIDが格納されている箇所に対象実領域2のIDを格納し、対象実領域2のIDが格納されている箇所に対象実領域1のIDを格納する。また、ストレージ制御プログラム307は、対象実領域1と対象実領域2の間のデータの入れ替えを行う。例えば、ストレージ制御プログラム307は、下記の処理を行うことによりデータの入れ替えを実現する。なお、下記処理におけるキャッシュメモリ領域は、ストレージサブシステム102が有する未割当実領域でもよい。
 手順1:ストレージ制御プログラム307は、対象実領域1内のデータをキャッシュメモリ領域に書く。
 手順2:ストレージ制御プログラム307は、対象実領域2内のデータをキャッシュメモリ領域に書く。
 手順3:ストレージ制御プログラム307は、対象実領域1のデータをキャッシュメモリ領域から対象実領域2に書き込む。
 手順4:ストレージ制御プログラム307は、対象実領域2のデータをキャッシュメモリ領域から対象実領域1に書き込む。
 (ステップ1708の処理内容)
 ストレージ制御プログラム307は、対象階層に性能が最も近い階層内の未割当の実領域に、対象仮想領域に割り当てられている実領域内のデータを移行する。また、ストレージ制御プログラム307は、VVOL管理表311と実領域管理表309を更新する。
  <管理計算機103が実行する全体的処理の概要>
 図18は、本実施形態における管理計算機103が実行する全体的処理の概要について説明するためのフローチャートである。
 (ステップ1801)
ユーザ(管理者)がアプリケーション情報入力画面1301(図14参照)にHost識別子1302と、Storage識別子1303と、PoolID1304と、VVOLID1305と、VVOLSIZE1306と、VVOLSIZE1307と、アプリケーション名1307と、アプリケーションタイプ1308と、予測期間1309の情報を入力し、実行1310を投下すると、アプリケーション情報取得エンジン804が入力された情報を取得する。なお、新規追加アプリケーション、或いは使用態様(使用ボリューム)を変更するアプリケーションの情報が入力され、実行ボタン1310が押下されると即時にプール容量予測処理を実行するようにしても良いが、ユーザの指定した期間後にプール容量予測処理を実行するようにしても良い。この場合、割当て予定の仮想ボリュームは、他のユーザが利用できないように予約する必要がある。また、上述のように、アプリケーションは新規追加や変更だけでなく、削除をして削除後のプール容量を予測するようにしても良い。以下、アプリケーションを追加する場合と削除する場合のアプリケーション情報入力(S1801)に付随する処理について説明する。
 (i)アプリケーション追加の場合:アプリケーション追加指示に伴う仮想ボリュームの追加
 アプリケーション情報の入力画面は図14に示したとおりである。また、アプリケーションを追加した場合には、マッピングテーブル901と、仮想ボリューム容量情報テーブル1001に情報が追加される。つまり、アプリケーション情報取得エンジン804は、アプリケーション追加画面1301に入力されたアプリケーション名1302とアプリケーションタイプ1303とVVOLID1304から、アプリケーションとボリュームとのマッピングテーブル901のアプリケーション名902とアプリケーションタイプ903とVVOLID904に該当する行を追加する。
 また、ストレージ情報取得エンジン810は、VVOLID1304とPOOLID1305から、仮想ボリューム容量情報テーブル1001のプールID1003とVVOLID1004に該当する行を追加する。
 そして、管理計算機103は、VVOLID1304に基づいて、管理用ネットワーク106を経由してストレージサブシステム102内のストレージ制御プログラム307に対して、VVOLID2004に対応する実領域管理表309の割当状況504を「割当」に変更するように指示する。より具体的には、当該指示を受けたストレージ制御プログラム307は、VVOL管理表311のVVOLID601とVVOLID2004が一致するVVOLLBA範囲602と実領域ID603を取得し、実領域管理表309の実領域ID502とRGLBA範囲503がVVOLLBA範囲602と実領域ID603に一致する割当状況504を「割当」に変更する。
 (ii)アプリケーション削除の場合:アプリケーション削除に伴う仮想ボリュームの削除
 上述したように、アプリケーションの新規追加に加えて、本実施形態では、アプリケーション削除に伴う割当て済み仮想ボリュームの削除も可能である。割当て済み仮想ボリュームを削除することで、対象プールの各Tier利用量の精度向上及び無駄な領域の解放が見込まれる。
 アプリケーション削除の場合、アプリケーションに割り当てられる仮想ボリュームの削除を実現する。具体的には、図23に示すようにアプリケーション削除画面2001を作成し、削除対象のアプリケーション名2002とアプリケーションタイプ2003とVVOLID2004とPOOLID2005を入力し、実行2006を投下する。
  アプリケーション情報取得エンジン804は、アプリケーション削除画面2001に入力されたアプリケーション名2002とアプリケーションタイプ2003とVVOLID2004から、アプリケーションとボリュームとのマッピングテーブル901のアプリケーション名902とアプリケーションタイプ903とVVOLID904に該当する行を削除する。
 また、ストレージ情報取得エンジン810は、VVOLID2004とPOOLID2005から、仮想ボリューム容量情報テーブル1001のプールID1003とVVOLID1004に該当する行を全て削除する。
 そして、管理計算機103は、VVOLID2004に基づいて、管理用ネットワーク106を経由してストレージサブシステム102内のストレージ制御プログラム307に対して、VVOLID2004に対応する実領域管理表309の割当状況504を「未割当」に変更するように指示する。より具体的には、当該指示を受けた制御プログラム307は、VVOL管理表311のVVOLID601とVVOLID2004が一致するVVOLLBA範囲602と実領域ID603を取得し、実領域管理表309の実領域ID502とRGLBA範囲503が前記VVOLLBA範囲602と実領域ID603に一致する割当状況504を「未割当」に変更する。
 (ステップ1602)
 アプリケーション情報取得エンジン804は、アプリケーション情報入力画面1301から取得したアプリケーション名1307、アプリケーションタイプ1308、VVOLID1305の情報を記憶装置811のデータ格納用DB812内アプリケーションとボリュームとのマッピングテーブル901へ格納する。
 (ステップ1603)
 アプリケーション情報取得エンジン804は、ステップ1601で取得したVVOLSIZE1306と予測期間1309とアプリケーションタイプ1308とPOOLID1304の情報を入力に、プール容量予測エンジン805に予測処理実行を指示する。
 (ステップ1804)
 プール容量予測エンジン805は、アプリケーションが利用するVVOLの容量消費傾向の予測に必要な入力パラメータを得るため、新規VOLへのPage割当て量予測エンジン806と既存VOLへのPage割当て量予測エンジン807を起動する。
 プール容量予測エンジン805が、新規VOLへのPage割当て量予測エンジン806の起動時に、パラメータとしてVVOLSIZE1306と予測期間1309とアプリケーションタイプ1308を渡すことで、新規VOLへのPage割当て量予測エンジン806は、割当て予定のVVOLSIZE1305に対する予測期間1309後の各Tierの容量消費量を取得する。具体的な処理内容に関しては後述する。
 また、既存VOLへのPage割当て量予測エンジン807は、割当て予定のVVOLを構成するプールに対して、VVOL追加に伴う既存のプールへの影響を予測する。起動時にパラメータとしてPOOLID1304と予測期間1309を受け取ることで、既存VOLへのPage割当て量予測エンジン807は、POOLID1304における予測期間1309後のプールの各Tierの予測容量消費量を取得する。具体的な処理内容に関しては後述する。なお、アプリケーションの削除が管理計算機103から指示された場合には、上述のように、当該指示に応答して、削除対象のアプリケーションを削除すると共に、対応する仮想ボリュームを「未割当」に変更する。そして、削除対象のアプリケーションを除く他の全ての既存アプリケーションが全体で消費する容量を予測する。なぜなら、アプリケーション削除後はデータが高性能のTier1等に残っていることがあり、資源の無駄となる可能性があるからである。このため、アプリケーション削除が指示された場合には、新規VOLへのPage割当て量予測エンジン806による予測処理は実行されない。ただし、アプリケーションを一時的に削除(停止)するような場合には、該当する仮想ボリュームにデータを残したまま他の既存アプリケーションの消費容量を予測するようにしても良い。一時的に停止したアプリケーションを復活させた場合には、新規VOLへのPage割当て量予測エンジン806による処理を実行し、復活させて指定期間経過した後の消費容量を予測するようにしても良い。
 プール容量予測エンジン805は、各予測エンジン806及び807から得た結果を合計し、プール容量予測テーブル1101に格納する。具体的には、プール容量予測エンジン805は、既存VOLへのPage割当て量予測エンジン807で算出した予測期間1309後のプールの各Tierの予測容量消費量に、新規VOLへのPage割当て量予測エンジン806で予測した結果を加算し、算出結果を1ヶ月後の容量消費量1105に格納する。また、プール容量予測エンジン805は、既存VOLへのPage割当て量予測エンジン807のステップ2212で算出した現時点でのプールの各Tierの容量消費量を現在の容量消費量1104に格納する。また、プール容量予測エンジン805は、割り当てるVVOLのVVOLSIZE1306をVVOL容量1103に格納する。
 (ステップ1805)
 プール容量予測エンジン805は、結果表示エンジン808を起動する。結果表示エンジン808は、プール容量予測テーブル1101のデータをプール容量予測結果レポート画面1301に出力する。
 なお、Tier購入時に発生するTier毎の金額をレポートするようにしても良い。この場合、プール容量予測エンジン805と結果表示エンジン808を拡充することで、容量消費量の予測と共に、各Tierの購入に必要な金額をレポートすることが可能となる。
 図24に示されるように、各Tierのコストを設定するために、Tier毎の課金設定画面2101が作成される。Tier毎の課金設定画面2101では、Tier毎のコスト入力2102~2104を行い、実行2105が押下される。
  そして、この場合、プール容量予測エンジン805は、Tier毎の課金設定画面2101で入力した情報をTier毎の課金管理テーブル2201(図25参照)に格納する。具体的には、プール容量予測エンジン805は、Tier毎のコスト入力2102~2104をTier毎の課金管理テーブル2201に格納する。データを算出する場合、プール容量予測エンジン805は、ステップ1804の処理を実行した後、プール容量予測テーブル1101の一カ月後の容量消費量1105から各Tierのデータを取得し、Tier毎の課金管理テーブル 2201のCost2203のデータと掛け合わせた値をプール容量予測テーブル 1101に格納する。
 続いて、プール容量予測エンジン805は、ステップ1805で結果表示エンジン808がプール容量予測テーブル1101のデータをプール容量予測結果レポート画面2301に出力する。この場合の画面描画結果は図26に示されるように表示される。図26と図16との差異は、予測コスト2302が表示されることである。なお、ここでは、容量が足りない場合にデバイス購入に掛かるコストを表示しているが、消費容量で課金するシステムの場合には、消費容量によるコストを表示するようにしても良い。
 <新規VOLへのPage割当て量予測エンジン806の処理の詳細>
 図19は、アプリケーション追加時における、新規VOLへのPage割当て量予測エンジン(以下、「新規割当て量予測エンジン」ということもある)806の処理の詳細を説明するためのフローチャートである。
 (ステップ1901)
 割当て予定のVVOLと類似する使用傾向が見られるVVOLを検索するため、新規割当て量予測エンジン806は、割当て予定のVVOLのアプリケーションタイプから、VVOL ID904をアプリケーションとボリュームとのマッピングテーブル901より取得する。つまり、追加するアプリケーションのタイプと類似する既存のアプリケーションが特定される。ここで、「類似」とは、「同一」も含む概念である。例えば、追加されるアプリケーションが、検索エンジンである場合には、同一の検索エンジンが既にあればそれが選択されるが、同一ではないが他の検索エンジンがあればそれが選択される。複数の類似タイプのアプリケーションがある場合には、何れか1つのアプリケーションを選択してその導入当初の動向を用いて予測するようにしても良いし、複数のアプリケーションを選択し、それらの導入当初の動向を平均するようにしても良い。
 (ステップ1902)
 新規割当て量予測エンジン806は、ステップ1901で取得した類似使用用途のVVOLID904の一覧全てに対してステップ1903ないし1906の処理を実行する。一覧全てに対して処理が実行された場合は、処理はステップ1907に移行する。
 (ステップ1903)
 新規割当て量予測エンジン806は、仮想ボリューム容量情報テーブル1001から、現在対象とする類似使用用途のVVOLについて収集を開始した最も古い時刻を運用開始時刻として仮定する。なお、仮想ボリューム容量情報テーブル1001において、最新時刻から遡った所定期間の情報を用いるのでなければ、運用開始時刻は任意に設定することができる。当該類似タイプのアプリケーションの導入当初の使用状況が追加された新規のアプリケーション等の運用予定と比べてあまりにも特異な場合には、類似のアプリケーションの使用状態が安定している時期を選択して予測処理に用いるようにしても良い。
 (ステップ1904)
 新規割当て量予測エンジン806は、ステップ1903で取得した時刻(運用開始時刻)からユーザが指定した予測したい期間(例えば、1ヶ月)までのデータを、仮想ボリューム容量情報テーブル1001から取得する。
 (ステップ1905)
 新規割当て量予測エンジン806は、ステップ1904の実行結果1件ずつに対して、Tier0利用量1006÷VVOL容量1005、Tier1利用量1007÷VVOL容量1005、Tier2利用量1008÷VVOL容量1005を実行し、各Tierについて、VVOLの割当て容量に対する消費比率を算出する。
 (ステップ1906)
 新規割当て量予測エンジン806は、類似するアプリケーションの中においてステップ1905で算出した各TierのVVOL割当て容量に対する消費比率が、最大となる値を安全係数として見積もるために、現在の中で最大の値が算出されれば、予測値の候補として、Tierの利用量1006~1008と、VVOL容量1005の組として保持する。即ち、ステップ1906では、最終的に、運用開始時刻からの指定期間内における容量消費量が最大のTier利用量とVVOL容量を見つけ出す処理が行われている。
 (ステップ1907)
 新規割当て量予測エンジン806は、対象とする類似用途のVVOL全てについて検証後、候補の組について、各Tierについて、VVOLの割当て容量に対する消費比率を算出する。この処理は、最大値を取る候補の組み合わせ(Tier利用量1006とVVOL容量1005)に対して、ステップ1905と同等の演算を実行するものである。演算結果が保持されていれば、再度同じ演算を行う必要はないが、ここでは保持されない場合を想定している。
 (ステップ1908)
 新規割当て量予測エンジン806は、ステップ1907で算出した値とユーザの指定する新規割当て予定のVVOLを乗算する。このようにすることで、ユーザの指定したVVOLに対する指定期間後の各Tierの予測容量消費量が算出できる。
 (ステップ1909)
 新規割当て量予測エンジン806は、ステップ1908で算出した値を追加されたアプリケーションによって消費されるプール容量の予測値として、プール容量予測エンジン805に返す。
 <既存VOLへのPage割当て量予測エンジン807の処理の詳細>
 図20は、既存VOLへのPage割当て量予測エンジン807の処理概要について説明するためのフローチャートである。既存VOLへのPage割当て量予測エンジン(以下、「既存割当て予測エンジン」ということもある)807は、プールの各Tierの予測容量消費量算出処理(ステップ2001)によって算出された値と、プールの各Tierの容量消費量算出処理(ステップ2002)によって算出された値を、プール容量予測エンジン805に返す。以下、ステップ2001及び2002の詳細について説明する。
(i)プールの各Tierの予測容量消費量算出処理(S2001)の詳細
 図21は、プールの各Tierの予測容量消費量算出処理(ステップ2001)の詳細を説明するためのフローチャートである。
 (ステップ2101)
 既存割当て予測エンジン807は、アプリケーション情報入力画面1301から入力されたPOOLID1304の全VVOL一覧を取得する。この取得したVVOLに対してS2103からS2105の処理が実行される。
 (ステップ2102)
 既存割当て予測エンジン807は、ステップ2101で取得したVVOLID1004の全てに対して処理(S2103乃至S2105)を実行したか否か判断する。処理が完了していれば、処理はステップ2106に移行する。
 (ステップ2103)
 既存割当て予測エンジン807は、VVOL毎に履歴データを取得する。ここでは、過去全てのデータを取得するようにするが、ユーザ(管理者)によって取得すべきデータの範囲(期間)が指定され、その指定期間中のデータを用いるようにしても良いし、固定期間のデータを用いるようにしても良い。
 (ステップ2104)
 既存割当て予測エンジン807は、ステップ2103で取得したデータに対して収集時間1002毎に各Tierの利用量の最尤推定(例えば、最小二乗法等を用いる)を行い、VVOLの各Tierの利用量の増加傾向を示す関係式を算出する。
 (ステップ1808)
 既存割当て予測エンジン807は、ステップ2104で算出した関係式に対してアプリケーション情報入力画面1301で入力したユーザの指定した予測期間1309を乗算することでVVOLの各Tierの容量消費量の予測を算出する。つまり、過去の統計的データに基づいて、指定期間経過後の容量消費量を予測する。
 (ステップ1809)
 既存割当て予測エンジン807は、ステップ2105で算出したVVOL毎の各Tierの容量消費量の予測値を合算し、プールの各Tierの予測容量消費量を算出する。
(ii)プールの各Tierの容量消費量算出処理(S2002)の詳細
 図22は、プールの各Tierの容量消費量算出処理(ステップ2002)の詳細を説明するためのフローチャートである。
 (ステップ2201)
 既存割当て予測エンジン807は、ステップ2101で取得したVVOLID1004の全てに対して、ステップ2202の処理が完了したか否か判断する。S2202の処理が完了していれば、処理はステップ2203に移行する。
 (ステップ2202)
 既存割当て予測エンジン807は、現時点でのVVOLの各Tierの消費量を取得する。厳密な意味での現時点のデータがなければ、最新のデータでも良い。
 (ステップ1812)
 既存割当て予測エンジン807は、ステップ2202で算出したVVOL毎の各Tierの容量消費量(現時点の容量)を合算し、プールの各Tierの容量消費量を算出する。
 <変形例>
(i)アプリケーションの特性変更に伴うボリューム消費量の再予測
 上記実施形態では、主にアプリケーション追加に伴う新規仮想ボリュームの割当てを想定しているが、本発明を拡充し既存アプリケーションの特性変化に応じた容量消費量の再予測も可能である。ここで「特性変更」とは、例えば、当初OLTPに割り当てられた仮想ボリューム(VVOL)が別のアプリケーションに割り当てられたような場合等、一度アプリケーションに割り当てた仮想ボリュームの利用態様が変わる場合を意味する。
 また、別の「特性変更」の例として、アプリケーションによっては、運用するにつれてその特性が変化する場合も考えられる。より具体的には、ある業務アプリケーションは通常アクセス量は少ないが、年度末や期末等といった特定の期間においてアクセス量が増え、OLTPに近いアクセス量が発生するなどといった特性を持つ場合がある。
 本発明をこのようなケースに適用し、アプリケーション特性の変化を考慮した反復的な容量予測を実行することが可能である。具体的にはステップ1801(図18)を実行する際、ユーザ(管理者)が、アプリケーションタイプ1308(図14)を変更し、割当たっている仮想ボリュームの残容量をVVOLSIZE1307に入力した上で、ステップ1802と同様の情報をアプリケーション情報入力画面1301に入力し、実行1310を投下する。以降は本実施形態における管理計算機103が実行する処理と同じの処理が実行される。このように、既存のアプリケーションの特性を変更したときにも、上述のアプリケーションの新規追加の処理を適用することができる。これにより、アプリケーションの特性が変更した後の容量消費量が予測可能となる。
(ii)LVM環境に対するボリューム消費量の予測
 アプリケーションによっては、サーバ上のOSが提供するLVM(Logical Volume Manager)機能等を利用して、各割当論理ボリュームをグルーピングし、1つの仮想ボリュームとしてアプリケーションに見せて割り当てる環境も存在する。このような環境において、本発明の思想を適用(拡張)し、アプリケーションに割り当てられている個々の論理ボリュームの容量消費量の総和から将来の消費量を予測することでLVM環境の容量消費量を予測できるようになる。つまり、LVM機能においては、1つのグループ(複数のVVOLで構成される)をアプリケーションに割り当てているが、その1つのグループの容量消費予測は、それぞれの構成VVOLの容量消費予測を合算して表すことが可能である。LVM機能を実現する環境では、アプリケーションに割り当てられているボリュームは、異なるプールから切り出されたVVOLである可能性もある。そこで、このような場合にグループ全体の消費容量を予測するには、1つのプールだけからではなく、それぞれの該当プールからも容量を予測する必要があるのである。そして、この環境に本発明を適用するためには、以下のように、情報入力画面とステップ1908の処理を拡張する必要がある。
 まず、情報入力画面については、アプリケーションに割当たっている個々の仮想ボリュームの情報を入力可能とするため、アプリケーション情報入力画面1301のVVOLID1305と、VVOLSIZE1307に複数のボリュームの情報が入力できるようにリストを追加する。その上で、ユーザ(管理者)が、LVMを構成する全ての仮想ボリュームの情報を入力する。
 また、新規VOLへのPage割当て量予測エンジン806は、S1908において、割り当て予定のVVOL容量に関して、LVMを構成する全ての仮想ボリューム容量の総和に変更する。より具体的には、S1908を“ステップ1907で算出した各Tierの比率×アプリケーション情報入力画面1301のVVOLSIZE1307に入力した各VVOL値の総和”とする。
 以降は本実施形態における管理計算機103が実行する処理と同じの処理を実行すれば良い。
 <まとめ>
 本実施形態では、新規にアプリケーションの追加が指示された場合、或いは、既存のプリケーションが使用する仮想ボリュームの割り当ての変更が指示された場合、当該指示に応答して、新規のアプリケーション、或いは割り当て変更対象のアプリケーションと、アプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向(例えば、アプリケーション導入当初から所定期間内における消費容量の傾向)に関する情報を取得する。そして、取得した消費容量動向に関する情報に基づいて、割当て予定の仮想ボリュームおける消費容量を予測する。このようにすることにより、アプリケーションの追加又はボリュームの割り当て変更に伴う容量(例えば、プールに割り当てられている容量)の枯渇タイミングを把握することができるようになる。アプリケーション導入当初からの消費容量傾向の情報を取得するのは、追加或いは割り当て変更に伴う消費容量の傾向をより正確に把握することができるからである。
 また、ストレージサブシステムでは、1つ以上の物理記憶デバイスが階層を構成している。また、仮想ボリュームは、1つ以上の階層を用いて構成され、かつ、ホスト計算機が直接アクセスするターゲットと関連付けられたプールと対応付けられている。仮想ボリュームについては、各階層ごとに消費容量(利用量)が管理されている(図11参照)。そして、割当て予定の仮想ボリュームにおける消費容量を予測する際には、当該仮想ボリュームを構成する1つ以上の階層における割り当て領域の過去の利用量に関する情報が用いられる。このようにすることにより、異なる物理特性のディスクの組み合わせでプールを構成する場合に、より正確にプールの消費容量枯渇のタイミングを把握することができるようになる。つまり、Thin Provisioningを拡張して運用する場合にも対応することができるようになる。
 さらに、上記新規に追加されるアプリケーション等以外の、全ての既存のアプリケーション(仮想ボリュームの割り当て状況に変化がないもの)が使用する仮想ボリュームにおける過去の消費容量に関するデータを取得する。そして、このデータに基づいて、最尤推定法(例えば、最小二乗法)を用いて、これら全ての既存のアプリケーションが使用する仮想ボリュームにおける、指定予測期間後の消費容量を予測する。この既存アプリケーションの予測消費容量と、上記新規追加アプリケーション等に割当て予定の仮想ボリュームにおける予測消費容量とを合算して出力(表示やプリントアウト)する。このようにすることにより、既存のアプリケーションの消費容量の動向をも加味して、システム全体の消費容量の予測情報を提示することができ、ユーザ(管理者)は物理記憶デバイスの追加のタイミングを知ることができるようになる。
 また、予測消費容量を提示すると共に、将来に掛かるコストを提示する。これにより、ユーザ(管理者)はコスト面を考慮しつつ、システムを効率よく運用することが可能となる。
 アプリケーション削除に伴う仮想ボリュームの削除が指示された場合には、削除対象のアプリケーションを除いて全体の予測消費容量を演算する。この場合には、既存VOLへのPage割当て予測エンジン807を用いて消費容量を予測する。このようにすることにより、アプリケーション削除に伴う容量確保がどの程度効果があるか見極めることができる。また、アプリケーション削除後はデータが高性能のTier1等に残っていると資源の無駄となるが、このような事態を回避することができる。
 なお、本発明は、実施形態そのままに限定されるものではなく、実施段階では、その要旨を逸脱しない範囲で構成要素を変形して具体化できる。また、実施形態に開示されている複数の構成要素の適宜な組み合わせにより、種々の発明を形成できる。例えば、実施形態に示される全構成要素から幾つかの構成要素を削除してもよい。さらに、異なる実施形態にわたる構成要素を適宜組み合わせてもよい。
 また、実施形態で示された各構成、機能、処理部、処理手段等は、それらの一部又は全部を、例えば集積回路で設計する等によりハードウェアで実現しても良い。また、上記各構成、機能等は、プロセッサがそれぞれの機能を実現するプログラムを解釈し、実行することによりソフトウェアで実現しても良い。各機能等を実現するプログラム、テーブル、ファイル等の情報は、メモリやハードディスク、SSD(Solid State Drive)等の記録或いは記憶装置、またはICカード、SDカード、DVD等の記録或いは記憶媒体に格納することができる。
 さらに、上述の実施形態において、制御線や情報線は説明上必要と考えられるものを示しており、製品上必ずしも全ての制御線や情報線を示しているとは限らない。全ての構成が相互に接続されていても良い。
100  計算機システム
101  ホスト計算機
102  ストレージサブシステム
103  管理計算機
104  Webブラウズ用計算機
105  ストレージエリアネットワーク
106  管理用ネットワーク
107  管理システム

Claims (15)

  1.  1つ以上の物理記憶デバイスを有するストレージサブシステムと、前記ストレージサブシステムを管理する管理システムと、を有し、
     前記ストレージサブシステムは、前記物理記憶デバイスの記憶領域を、仮想ボリュームとしてホスト計算機に提供し、
     前記管理システムは、アプリケーションが使用すべき前記仮想ボリュームの割り当てについての入力指示に応答して、前記アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得し、当該消費容量動向に関する情報に基づいて、前記割当て予定の仮想ボリュームおける消費容量を予測することを特徴とする計算機システム。
  2.  請求項1において、
     前記入力指示は、新規にアプリケーションの追加の指示、或いは、既存のアプリケーションに割り当てられる前記仮想ボリュームに変更の指示を含み、
     前記管理システムは、前記入力指示に応答して、前記割当て予定の仮想ボリュームにおける消費容量を予測する処理を実行することを特徴とする計算機システム。
  3.  請求項2において、
     前記管理システムは、前記新規追加のアプリケーションと同一又は類似のタイプのアプリケーション、或いは前記仮想ボリューム割り当て変更の既存アプリケーションの運用開始から所定期間における前記消費容量動向に関する情報を取得し、前記割当て予定の仮想ボリュームにおける消費容量を予測することを特徴とする計算機システム。
  4.  請求項3において、
     前記1つ以上の物理記憶デバイスは、1つ以上の階層を構成し、
     前記仮想ボリュームは、前記1つ以上の階層を用いて構成され、かつ、前記ホスト計算機が直接アクセスするターゲットと関連付けられたプールと対応付けられ、
     前記管理システムは、前記割当て予定の仮想ボリュームにおける消費容量を予測する際に、当該仮想ボリュームを構成する前記1つ以上の階層における割当て領域の過去の利用量に関する情報を用いることを特徴とする計算機システム。
  5.  請求項4において、
     前記管理システムは、さらに、前記仮想ボリュームの割り当てが不変の全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関する情報を取得し、当該全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測し、前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量を併せて出力することを特徴とする計算機システム。
  6.  請求項5において、
     前記システムは、前記1つ以上の階層のコストに関するコスト設定情報、及び前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量に基づいて、前記1つ以上の階層における予測コストを出力することを特徴とする計算機システム。
  7.  請求項1において、
     前記管理システムは、アプリケーションの削除と当該削除対象のアプリケーションに割り当てられた前記仮想ボリュームの削除についての入力指示に応答して、当該削除対象のアプリケーションが使用する前記仮想ボリュームの割り当てを解放し、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関する情報を取得し、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測し、当該予測消費量を出力することを特徴とする計算機システム。
  8.  1つ以上の物理記憶デバイスの記憶領域を仮想ボリュームとしてホスト計算機に提供するストレージサブシステムと、前記ストレージサブシステムを管理する管理システムと、を有する計算機システムの管理方法であって、
     前記管理システムのプロセッサが、アプリケーションが使用すべき前記仮想ボリュームの割り当てについて指示された場合、前記アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得する工程と、
     前記プロセッサが、前記消費容量動向に関する情報に基づいて、前記割当て予定の仮想ボリュームおける消費容量を予測する工程と、
    を有することを特徴とする管理方法。
  9.  請求項8において、
     前記指示は、新規にアプリケーションの追加の指示、或いは、既存のアプリケーションに割り当てられる前記仮想ボリュームに変更の指示を含み、
     前記プロセッサは、前記入力指示に応答して、前記割当て予定の仮想ボリュームにおける消費容量を予測する処理を実行することを特徴とする管理方法。
  10.  請求項9において、
     前記プロセッサは、前記新規追加のアプリケーションと同一又は類似のタイプのアプリケーション、或いは前記仮想ボリューム割り当て変更の既存アプリケーションの運用開始から所定期間における前記消費容量動向に関する情報を取得し、前記割当て予定の仮想ボリュームにおける消費容量を予測することを特徴とする管理方法。
  11.  請求項10において、
     前記1つ以上の物理記憶デバイスは、1つ以上の階層を構成し、
     前記仮想ボリュームは、前記1つ以上の階層を用いて構成され、かつ、前記ホスト計算機が直接アクセスするターゲットと関連付けられたプールと対応付けられ、
     前記プロセッサは、前記割当て予定の仮想ボリュームにおける消費容量を予測する際に、当該仮想ボリュームを構成する前記1つ以上の階層における割当て領域の過去の利用量に関する情報を用いることを特徴とする管理方法。
  12.  請求項11において、
     さらに、前記プロセッサが、前記仮想ボリュームの割り当てが不変の全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関するデータを取得する工程と、
     前記プロセッサが、当該全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測し、前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量を併せて出力する工程と、
    を有することを特徴とする管理方法。
  13.  請求項12において、
     さらに、前記プロセッサが、前記1つ以上の階層のコストに関するコスト設定情報、及び前記割当て予定の仮想ボリュームにおける予測消費容量と前記既存アプリケーションの予測消費容量に基づいて、前記1つ以上の階層における予測コストを出力する工程を有することを特徴とする管理方法。
  14.  請求項8において、
     さらに、前記プロセッサが、アプリケーションの削除と当該削除対象のアプリケーションに割り当てられた前記仮想ボリュームの削除について指示された場合、当該削除対象のアプリケーションが使用する前記仮想ボリュームの割り当てを解放する工程と、
     前記プロセッサが、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける過去の消費容量に関する情報を取得する工程と、
     前記プロセッサが、前記削除対象のアプリケーションを除く全ての既存のアプリケーションが使用する前記仮想ボリュームにおける消費容量であって、指定された予測期間後の消費容量を予測する工程と、
     前記プロセッサが、前記予測消費量を出力する工程と、
    を有することを特徴とする管理方法。
  15.  1つ以上の物理記憶デバイスの記憶領域を仮想ボリュームとしてホスト計算機に提供するストレージサブシステムと、前記ストレージサブシステムを管理する管理システムと、を有する計算機システムにおいて、前記管理システムのプロセッサに、
     アプリケーションが使用すべき前記仮想ボリュームの割り当てについての入力指示に応答して、前記アプリケーションとアプリケーション種別が同一或いは類似のアプリケーションが使用する仮想ボリュームの過去の消費容量動向に関する情報を取得する処理と、
     前記消費容量動向に関する情報に基づいて、前記割当て予定の仮想ボリュームおける消費容量を予測する処理と、
    を実行させるためのプログラム。
PCT/JP2010/072377 2010-12-13 2010-12-13 計算機システム、及びその管理方法、並びに、プログラム WO2012081074A1 (ja)

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)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015063859A1 (ja) * 2013-10-29 2015-05-07 株式会社日立製作所 計算機システム及び制御方法

Families Citing this family (11)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (2)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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