WO2011105091A1 - 制御装置、管理装置、制御装置のデータ処理方法、およびプログラム - Google Patents

制御装置、管理装置、制御装置のデータ処理方法、およびプログラム Download PDF

Info

Publication number
WO2011105091A1
WO2011105091A1 PCT/JP2011/001078 JP2011001078W WO2011105091A1 WO 2011105091 A1 WO2011105091 A1 WO 2011105091A1 JP 2011001078 W JP2011001078 W JP 2011001078W WO 2011105091 A1 WO2011105091 A1 WO 2011105091A1
Authority
WO
WIPO (PCT)
Prior art keywords
load
resource
server
resource usage
resources
Prior art date
Application number
PCT/JP2011/001078
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 US13/581,464 priority Critical patent/US20120324471A1/en
Priority to JP2012501685A priority patent/JPWO2011105091A1/ja
Publication of WO2011105091A1 publication Critical patent/WO2011105091A1/ja

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5083Techniques for rebalancing the load in a distributed system
    • G06F9/5088Techniques for rebalancing the load in a distributed system involving task migration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3433Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment for load management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3442Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for planning or managing the needed capacity
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/815Virtual

Definitions

  • the present invention relates to a control device, a management device, a data processing method for the control device, and a program, and in particular, a control device, a management device, a data processing method for the control device, and a control device that perform load estimation for measuring performance of a virtual server, and Regarding the program.
  • FIG. 18 is a block diagram showing the configuration of the system.
  • the servers 900, 901, and 902 are non-virtualized servers targeted for server integration.
  • the computer 930 is a terminal on which a sizing function operates. Servers 900, 901, and 902 and a computer 930 are connected by a LAN (Local Area Network) 905.
  • LAN Local Area Network
  • Each of the servers 900, 901, and 902 is an example of a real server, and the computer 930 is an example of a virtual machine server sizing device.
  • Servers 900, 901, and 902 include load measuring units 910, 911, and 912, respectively.
  • the servers 900, 901, and 902 have at least one CPU (Central Processing Unit) as a hardware resource, and also have an HDD (Hard Disk Drive) and a NIC (Network Interface Card).
  • the load measuring units 910, 911, and 912 measure the system loads of the servers 900, 901, and 902, respectively, and output them as measurement information.
  • the system load is, for example, a CPU load, a disk or network I / O (Input / Output) load.
  • the computer 930 includes a performance design unit 940, a configuration management unit 941, an input device 951 (for example, a keyboard and a mouse), a storage device 952 (for example, an HDD and a memory), a processing device 953 (for example, a CPU), and an output device 954 (for example, Display device and printer device).
  • a performance design unit 940 for example, a configuration management unit 941, an input device 951 (for example, a keyboard and a mouse), a storage device 952 (for example, an HDD and a memory), a processing device 953 (for example, a CPU), and an output device 954 (for example, Display device and printer device).
  • an input device 951 for example, a keyboard and a mouse
  • a storage device 952 for example, an HDD and a memory
  • a processing device 953 for example, a CPU
  • an output device 954 for example, Display device and printer device.
  • description is abbreviate
  • the conventional computer system having such a configuration operates as follows.
  • the CPU performance conversion unit 923 obtains the measured values of the CPU load of the servers 900, 901, and 902.
  • the load conversion unit 920 obtains an estimated value of the CPU load of the server X caused by disk or network I / O from the disk load or network load of the servers 900, 901, and 902.
  • the CPU overhead calculation unit 924 obtains a coefficient indicating the CPU overhead due to virtualization.
  • the load estimation unit 925 estimates the CPU load of the server X using the measured value, the estimated value, and the coefficient.
  • the feature is that the CPU overhead for I / O when each resource (disk, network) is used on the virtual server is measured, and further, the frequency of each resource used by the application on the physical server is measured. .
  • the CPU overhead corresponding to the resource usage frequency is calculated, and the CPU resource usage frequency is estimated by adding the above CPU overhead assuming that application processing is performed on the virtual server from the physical server, Measures the resource usage frequency when application processing on a physical server is executed on a virtual server.
  • the computer system described above has a problem that it is difficult to accurately estimate the target load because the dependency relationship with resources other than the CPU (Central Processing Unit) is not considered.
  • An object of the present invention is to provide a control device, a data processing method thereof, a program thereof, and a management device capable of accurately performing load estimation for performing performance measurement of a virtual server, which is the above-described problem. is there.
  • the control device of the present invention An acquisition unit for acquiring resource usage of a plurality of resources of a physical server and a virtual server operating on the physical server; Load generation means for generating a load on the measurement target resource; By applying the load to the measurement target resource, a resource on which the measurement target resource depends is obtained, and the dependence degree of the measurement target resource is determined based on the number of the resource on which the measurement target resource depends.
  • a dependency frequency calculating means for calculating for calculating; Ranking means for ranking the resources in descending order of the number of dependencies calculated as the measurement target resource for a plurality of the resources; Select the measurement target resource from a plurality of the resources in the order ranked by the ranking unit, and adjust the processing capacity index of the resource usage of the measurement target resource while generating the load sequentially by the load generation unit Adjusting means.
  • the management apparatus of the present invention is obtained by the estimation unit as a physical server to be verified by sequentially operating the performance measurement virtual server of the control apparatus on the physical server as a plurality of migration destination candidates.
  • Presenting means for presenting the processing capability index is provided.
  • the program of the present invention is stored in a computer.
  • the procedure for calculating A procedure for ranking the resources in descending order of the dependency number calculated as the measurement target resource for the plurality of resources, The measurement target resource is selected from the plurality of resources in the ranked order, and the procedure for adjusting the processing capacity index of the resource usage of the measurement target resource is executed while sequentially generating loads.
  • the data processing method of the control device of the present invention is: A data processing method of a control device that measures a load of a plurality of resources of a physical server and a virtual server operating on the physical server, the control device comprising: Obtaining resource usage of the plurality of resources of the physical server and the virtual server running on the physical server; Generate a load on the measurement target resource, By applying the load to the measurement target resource, a resource on which the measurement target resource depends is obtained, and the dependence degree of the measurement target resource is determined based on the number of the resource on which the measurement target resource depends.
  • the measurement target resource is selected from a plurality of the resources in the ranked order, and the processing capacity index of the resource usage of the measurement target resource is adjusted while sequentially generating a load.
  • a plurality of components are formed as a single member, and a single component is formed of a plurality of members. It may be that a certain component is a part of another component, a part of a certain component overlaps with a part of another component, or the like.
  • the data processing method and the computer program of the present invention describe a plurality of procedures in order, the described order does not limit the order in which the plurality of procedures are executed. For this reason, when implementing the data processing method and computer program of this invention, the order of the several procedure can be changed in the range which does not interfere in content.
  • the data processing method and the plurality of procedures of the computer program of the present invention are not limited to being executed at different timings. For this reason, another procedure may occur during the execution of a certain procedure, or some or all of the execution timing of a certain procedure and the execution timing of another procedure may overlap.
  • a control device a management device, a data processing method for the control device, and a program capable of accurately estimating a load for performing performance measurement of the virtual server.
  • FIG. 1 is a schematic block diagram showing a configuration of an information processing system 1 according to an embodiment of the present invention.
  • one physical server computer hereinafter referred to as “physical server”
  • virtual server a plurality of virtual computers
  • the resources of a plurality of physical servers are efficiently used by using a server virtualization technology that operates different operating systems (OSs) and applications on each virtual server.
  • OSs operating systems
  • the present invention relates to a provisioning technique for adjusting resources and providing an optimal service to a user so that a process having performance according to the user's demand can be executed using the computer.
  • the virtual server has an advantage that the resources can be flexibly allocated according to the user's demand in this way, but the processing performance is reduced by the overhead of virtualization.
  • the characteristics of the dependency relationship between the resources in which a load corresponding to that occurs between other resources is analyzed. Then, the target load is generated by absorbing the generation of the load due to the characteristics. Then, on the virtual server that generates a load on the physical server, it is possible to perform the load estimation excluding the influence of the overhead between resources generated by the load generation.
  • resources such as a plurality of servers, networks, applications, and storage are virtualized. Then, when there is a request from the user or at the time of failure, the necessary amount of resources can be dynamically allocated to another resource.
  • the processing performance of the virtual server before and after the movement of the resource is estimated in advance as accurately as possible, so that it is possible to avoid a large load change or a high load during the movement.
  • the present invention enables the system to have performance that meets the needs of the user.
  • the present invention can be applied to a data center business that is mounted on a monitoring middleware product and efficiently operates a virtual server that operates on a physical server.
  • the information processing system 1 of the present embodiment includes a management server 4, a pool server 5, a save server 6, a migration source server 7 having a management agent 70, and a plurality of management agents 90.
  • Destination server 9 (SV21,..., SV2m, m is a natural number). These are connected to each other via the communication network 3.
  • the communication network 3 is not particularly limited, and is configured such that servers can communicate with each other. For example, a LAN (Local Area Network), a WAN (Wide Area Network), a mobile communication network, a fixed telephone communication network, the Internet, and combinations thereof It can be.
  • the pool server 5, the migration source server 7, the migration destination server 9, and the evacuation server 6 are physical servers in which virtual servers can be arranged and functions that can move between the servers are provided.
  • Each physical server includes, for example, a CPU, a memory, a hard disk, and a communication device (not shown) and is connected to an input device such as a keyboard and a mouse and an output device such as a display and a printer, or a computer corresponding thereto. It is realizable with the apparatus which does.
  • Each function of each unit can be realized by the CPU reading the program stored in the hard disk into the memory and executing it.
  • the configuration of parts not related to the essence of the present invention is omitted and is not shown.
  • Each component of the information processing system 1 includes an arbitrary computer CPU, memory, a program that realizes the components shown in the figure loaded in the memory, a storage unit such as a hard disk that stores the program, and a network connection interface. It is realized by any combination of hardware and software. It will be understood by those skilled in the art that there are various modifications to the implementation method and apparatus. Each figure described below shows functional unit blocks, not hardware unit configurations.
  • VM1i, i is a natural number
  • business virtual server 96 in the case of the migration destination server SV21.
  • VM21,..., VM2j, j are natural numbers
  • the other is a performance measurement virtual server 100 (VM31,..., VM3n, n is a natural number) that performs the performance measurement processing of the present invention.
  • the destination server 9 may not exist.
  • the destination server 9 does not exist when performing the performance measurement process of the present embodiment in order to newly introduce the destination server.
  • the business virtual server 76 and the business virtual server 96 are equipped with applications that perform processing such as web, mail, backup, and the like, and perform these processing.
  • the performance measurement virtual server 100 of the present embodiment operates.
  • a plurality (n) of servers may operate on the pool server 5 like the performance measurement virtual server 100 (VM31 to VM3n) shown in FIG.
  • the management agent 70 of the source server 7 has a load information collection unit 72 and a load information notification unit 74, and has a role of instructing to start or end these functions.
  • a business virtual server 76 operates on the migration source server 7.
  • a plurality (i) of business virtual servers 76 may operate on the migration source server 7 (VM11 to VM1i in the figure).
  • the load information collection unit 72 collects the resource usage of the migration source server 7 and the virtual server running on the migration source server 7.
  • the load information notification unit 74 periodically transmits the resource usage collected by the load information collection unit 72 to the management server 4 via the communication network 3.
  • the management agent 90 of the destination server 9 has a load information collection unit 92 and a load information notification unit 94, and has a role of instructing to start or end these functions.
  • a business virtual server 96 operates on the destination server 9.
  • there are a plurality of business virtual servers 96 on each destination server 9 (j in the case of destination server SV21, and other destination servers SV2m (m is 2, 3, 4,%)).
  • (For example, x, y, z,...) May be operated one by one (in the figure, the virtual servers VM21 to VM2j of the migration destination server SV21 and the virtual servers of other migration destination servers SV2m are omitted).
  • the load information collection unit 92 collects the resource usage of the migration destination server 9 and the virtual server running on the migration destination server 9. Then, the load information notification unit 94 periodically transmits the resource usage collected by the load information collection unit 92 to the management server 4 via the communication network 3.
  • the evacuation server 6 is a physical server that temporarily evacuates the business virtual server 76 operating on the migration source server 7 when performing the performance measurement process of the present invention described later. As a result, the information processing system 1 of the present embodiment can execute the performance measurement processing of the present invention without stopping the actual business service. It is assumed that the evacuation server 6 has sufficient resources that do not cause a shortage of resources even when the business virtual server 76 is evacuated.
  • the management server 4 includes a performance information acquisition instruction unit 21, a load adjustment and reproduction instruction unit 22, a virtual server activation unit 24, a virtual server movement unit 25, an information transmission unit 26, an information reception unit 27, and an information comparison.
  • Unit 28 virtual server image storage unit 29, and performance information storage unit 20.
  • the information processing system 1 of the present embodiment includes a load adjustment phase and a load reproduction phase.
  • the information processing system 1 of the present embodiment performs a performance measurement by generating a pseudo load on the movement source server 7.
  • the information processing system 1 according to the present embodiment generates a load on the movement destination server 9 based on the processing capability index obtained in the load adjustment phase, and acquires the resource usage.
  • the performance information storage unit 20 stores the processing capability index of each resource received from the performance measurement virtual server 100 operating on the migration source server 7 in the load adjustment phase. Furthermore, the performance information storage unit 20 uses the resource usage consumed on the destination server 9 received from the performance measurement virtual server 100 operating on the destination server 9 in the load reproduction phase, for example, in time series. Remember.
  • the performance information acquisition instruction unit 21 gives a load adjustment instruction or a load reproduction instruction to the load adjustment and reproduction instruction unit 22.
  • the operator can instruct load adjustment or load reproduction to the management server 4 of the information processing system 1 using, for example, an operation unit (not shown).
  • the performance information acquisition instruction unit 21 instructs the load adjustment and reproduction instruction unit 22 according to the instruction.
  • the performance information acquisition instructing unit 21 receives the designation of which source server 7 is the measurement target by causing the operator to designate it.
  • the operator may create a load adjustment or load reproduction execution schedule in advance and register it in the management server 4, and the performance information acquisition instruction unit 21 may automatically issue an instruction according to the schedule. In this way, verification can be performed in the middle of the night when the system is not actually operating. As a result, even if a failure occurs, the damage can be minimized.
  • the load adjustment and reproduction instruction unit 22 performs the performance measurement virtual server on the pool server 5 instead of the business virtual server 76 operating on the movement source server 7 designated as the measurement target.
  • the performance measurement virtual server 100 is moved to the movement source server 7.
  • the virtual server moving unit 25 is instructed to move the business virtual server 76 operating on the movement source server 7 to the evacuation server 6.
  • an instruction to return to the original state is also given.
  • the load adjustment and reproduction instruction unit 22 transmits a performance information measurement instruction to the performance measurement virtual server 100 moved to the movement source server 7 using the information transmission unit 26 via the communication network 3.
  • This performance information measurement instruction includes the setting information 130 shown in FIG. 13 and information on each resource amount of the performance measurement virtual server 100.
  • the setting information 130 can be set by the operator, and parameters set using the operation unit from a setting screen or the like may be received, or may be received in the form of a setting file.
  • the setting information 130 includes information for each virtual server. For example, the initial processing capacity index (numerical value), the initial adjustment fluctuation width (%), the reproduction fluctuation width (%), and the number of skips. (Times), number of continuations (times), allowable range (%), reference resource usage (% or numerical value), maximum number of adjustments (times), multiprocessor support, CPU resource flag, memory resource flag, NW (network ) Resource flag and HDD resource flag.
  • the initial processing capacity index (numerical value) is set for each resource, and this initial processing capacity index is used when a load is first generated using a performance measurement program.
  • the initial adjustment fluctuation width (%) may be set for each resource, and is a range of fluctuation of the load when the load is first generated using the performance measurement program.
  • the reproduction fluctuation width (%) may be set for each resource, and is a range of load fluctuation when a load is generated using a performance measurement program at the time of load reproduction.
  • the skip count (times) may be set for each resource, and is a count of skipping the resource load information received from the physical server in consideration of a case where the load is not increased.
  • the number of times of continuation (times) may be set for each resource, and is the number of times that has entered an allowable range as a result of measurement by outputting a load corresponding to a reference processing capability index.
  • the permissible range (%) may be set for each resource, and is a range from the reference resource usage as a result of measuring and outputting a load corresponding to the reference processing capability index.
  • the reference resource usage (% or numerical value) may be set for each resource, and is a reference resource usage with a small load that does not affect other virtual servers.
  • the maximum number of adjustments (times) may be set for each resource, and is the number of adjustments for obtaining a reference resource usage.
  • the multiprocessor support indicates the maximum number of CPU cores in the measurement server environment.
  • the CPU resource flag, memory resource flag, NW resource flag, and HDD resource flag indicate whether or not to measure CPU, memory, NW, and HDD resources, respectively.
  • the CPU and memory resources indicate whether or not to perform measurement, and the NW and HDD resources indicate input or output, or all. These settings are used in the processing described later.
  • the load adjustment and reproduction instruction unit 22 moves the performance measurement virtual server 100 on the pool server 5 to the movement source server 7 designated as the measurement target. Instructs the virtual server moving unit 25.
  • the load adjustment and reproduction instruction unit 22 transmits a load reproduction instruction to the performance measurement virtual server 100 via the communication network 3 using the information transmission unit 26.
  • the load reproduction instruction includes the processing capacity index of the business virtual server 76 on the source server 7 estimated by the performance measurement virtual server 100 in the load adjustment phase.
  • the virtual server image storage unit 29 stores an image of a virtual server operating in the information processing system 1.
  • the virtual server activation unit 24 copies the image of each virtual server registered in the virtual server image storage unit 29 to the server to be activated, and instructs to activate the virtual server.
  • a plurality of performance measurement virtual servers 100 VM31 to VM31n
  • the virtual server moving unit 25 moves each virtual server in accordance with an instruction from the load adjustment and reproduction instruction unit 22.
  • the information transmission unit 26 instructs the performance measurement virtual server 100 running on the migration source server 7 and the performance measurement virtual server 100 running on the migration destination server 9 via the communication network 3. And send information.
  • the information receiving unit 27 receives information from the performance measurement virtual server 100 operating on the movement source server 7 and the performance measurement virtual server 100 operating on the movement destination server 9 via the communication network 3. Receive.
  • the information comparison unit 28 acquires the resource usage consumed on the destination server 9 in the performance information storage unit 20 in the load reproduction phase. Then, the information comparison unit 28 presents it on a display unit (not shown) or the like so that the amount of resource usage can be compared when it is performed on a plurality of destination servers 9 (SV 21 to 2 m).
  • the management server 4 sequentially operates the performance measurement virtual server 100 on a plurality of physical destination servers (movement destination servers 9). And the management server 4 can be provided with the presentation part (not shown) which presents the processing capacity parameter
  • each unit of the management server 4 described above are realized by executing a computer program on a computer.
  • This computer program may be recorded on a computer-readable recording medium.
  • the recording medium is not particularly limited, and various forms can be considered.
  • the program may be loaded from a recording medium into a computer memory, or downloaded to a computer through a network and loaded into the memory.
  • FIG. 2 is a functional block diagram showing the configuration of the performance measurement virtual server 100 of this embodiment.
  • the control device (performance measurement virtual server 100) of this embodiment includes a physical server (migration source server 7 or migration destination server 9) and a virtual server (business virtual server 76 or business virtual server 96) operating on the physical server.
  • the acquisition unit 52 that acquires the resource usage
  • the load generation unit 54 that generates a load on the measurement target resource
  • the measurement target resource depends on the load on the measurement target resource.
  • a dependency level calculation unit 56 that calculates the dependency level of the measurement target resource based on the number of resources on which the measurement target resource depends, and a plurality of resources calculated as the measurement target resources.
  • selecting the target object from the resource comprises while generating sequential load by the load generator 54, an adjuster 60 for adjusting the processing capabilities indication of resource usage measurement target resource, the.
  • the performance measurement virtual server 100 further includes an interface (shown as “I / F” in the figure) 62.
  • the interface 62 is connected to the management server 4, the evacuation server 6, and the migration source server 7 via the communication network 3. , And the destination server 9 to communicate.
  • the control device of the present invention refers to the performance measurement virtual server 100 operable on the physical server. It is in accordance with an instruction from the management server 4 on which physical server the performance measurement virtual server 100 is moved. That is, since the control apparatus of the present invention does not determine on which physical server the performance measurement virtual server 100 is to be operated, it is not limited to which computer it is realized.
  • the performance measurement virtual server 100 includes an information transmission unit 101, an information reception unit 103, a load determination unit 105, a load generation unit 107, and a setting file reading.
  • the intermediate information storage unit 125 and the dependency information storage unit 127 are provided.
  • the figure shows the performance measurement virtual server VM31, the other performance measurement virtual server VM3n has the same configuration.
  • the control device (performance measurement virtual server 100) further includes resources other than the measurement target resource based on the resource usage acquired by the information reception unit 103 while the load is generated by the load generation unit 107.
  • the measurement target resource depends on the resource A determination unit (load determination unit 105) that determines that the resource to be measured is included, and the dependency frequency calculation unit (dependency analysis unit 113) is determined by the load determination unit 105 that the measurement target resource is dependent.
  • Dependency count is calculated by counting the number of resources.
  • control device (performance measurement virtual server 100) of this embodiment is replaced with at least one virtual server (business virtual server 76 in FIG. 1) operating on a physical server (migration source server 7 in FIG. 1).
  • the performance measurement virtual server 100 for realizing each unit of the performance measurement virtual server 100 is operated on the movement source server 7 (FIG. 1) as the movement source, and the load generation unit 107 is moved to the movement source server 7.
  • a load is generated on the source server 7, and the information receiving unit 103 operates on the source server 7 and the source server 7.
  • the resource usage of the plurality of resources of the virtual server 100 is periodically acquired, and the load adjustment unit 111 adjusts the processing capacity index.
  • the load adjustment unit 111 is based on the resource usage of each resource acquired by the information reception unit 103 until the previous time other than the current measurement target resource.
  • the resource usage amount of the resource to which the load generation unit 107 applied a load and the resource usage amount of the measurement target resource to which the load generation unit 107 applied the current load are set as the measurement targets of the preset virtual server.
  • the processing capacity index is adjusted to be the resource usage amount removed from the resource usage amount of the resource, and the control device (performance measurement virtual server 100) is further based on the processing capacity index adjusted by the load adjustment unit 111.
  • the load generation unit 107 selects the measurement target resource from the plurality of resources in the order ranked by the dependency analysis unit 113.
  • a determination unit (load determination unit 105) that determines whether or not the absolute value of the target resource usage is within the allowable range from the resource usage acquired by the information reception unit 103 while sequentially generating a load.
  • an estimation unit (load) that estimates a processing capability index corresponding to the target resource usage amount from the resource usage amount acquired by the information receiving unit 103 when the load determination unit 105 determines that it is within the allowable range. Adjustment unit 111).
  • the information transmission unit 101 transmits information about the processing capability index obtained by the performance measurement process to the management server 4 via the communication network 3 in the load adjustment phase. Further, the information transmission unit 101 transmits information on the latest resource usage to the management server 4 via the communication network 3 in the load reproduction phase.
  • the information receiving unit 103 receives instructions and information from the management server 4, the source server 7, or the destination server 9 via the communication network 3, and stores them in a predetermined storage unit. For example, the information reception unit 103 receives a performance information measurement instruction from the load adjustment and reproduction instruction unit 22 of the management server 4 and stores it in the reception information storage unit 121. Then, the information receiving unit 103 periodically receives the resource usage from the load information notification unit 74 on the source server 7 that has generated the load in a pseudo manner, and stores it in the load information storage unit 117. Further, the information receiving unit 103 receives a load reproduction instruction from the load adjustment and reproduction instruction unit 22 and stores it in the reception information storage unit 121. Then, the information receiving unit 103 periodically receives the resource usage from the load information notification unit 94 on the destination server 9 that has reproduced the load, and stores it in the load information storage unit 117.
  • the information reception unit 103 corresponds to the acquisition unit 52 in FIG.
  • the received information storage unit 121 stores instructions and information received from the management server 4, the movement source server 7, or the movement destination server 9 via the communication network 3 by the information reception unit 103.
  • the load information storage unit 117 stores the resource usage for each resource that the information reception unit 103 periodically receives from the load information notification unit 74 of the source server 7 in the load adjustment phase. Further, the load information storage unit 117 stores the resource usage for each resource that the information reception unit 103 periodically receives from the load information notification unit 94 of the destination server 9 in the load reproduction phase.
  • the load determination unit 105 refers to the load information storage unit 117 in the load adjustment phase, and determines the dependency relationship from each resource usage based on the resource usage of the source server 7 and the destination server 9. Further, the load determination unit 105 calculates the number of dependencies as the measurement target resource for each resource based on the number of resources on which the measurement target resource depends.
  • the load determination unit 105 corresponds to the dependency frequency calculation unit 56 in FIG. The calculated dependency frequency is stored in the dependency information storage unit 127 for each resource.
  • the load determination unit 105 detects whether there is an increase or decrease in the resource usage of resources other than the measurement target resource. When an increase / decrease is detected, the load determination unit 105 determines that the measurement target resource is dependent on the resource. In this embodiment, the load determination unit 105 determines the dependency based on the increase / decrease of the resource usage acquired by the load information collection unit of the management agent provided in each server, but the present invention is not limited to this. For example, the dependency relationship can be determined by using an index that shows an increase or decrease in the resource usage of the server by another monitoring tool.
  • the load determination unit 105 refers to the load information storage unit 117 in the load reproduction phase, and reads the final resource usage based on the resource usage of the destination server 9. Then, the load determination unit 105 transmits the read final resource usage amount to the management server 4 via the communication network 3 using the information transmission unit 101.
  • the setting file reading unit 109 reads each parameter from the setting information 130 of FIG. 13 received from the management server 4 and stored in the reception information storage unit 121, and stores it in the setting information storage unit 123.
  • the setting information storage unit 123 stores parameters of the setting information 130 read from the reception information storage unit 121 by the setting file reading unit 109.
  • the load adjustment unit 111 adjusts the processing capability index in the load adjustment phase according to a procedure described later.
  • This processing capacity index becomes the resource usage of the business virtual server 76 based on the processing capacity index for each resource updated after the load is generated and the resource usage of each resource measured periodically.
  • the load adjustment unit 111 corresponds to the adjustment unit 60 in FIG.
  • the performance information storage unit 119 stores the processing capability index adjusted by the load adjustment unit 111 for each resource.
  • the measurement instruction unit 115 instructs the load generation unit 107 to generate a resource load in units of resources. Details of how to apply the load will be described later.
  • the load generation unit 107 generates a pseudo load on the measurement target resources of the performance measurement virtual server 100 on the movement source server 7 and the performance measurement virtual server 100 on the movement destination server 9. This corresponds to the load generation unit 54 in FIG.
  • the dependency relationship analysis unit 113 performs resource-dependent ordering (descending order) based on the performance measurement result for each resource existing in the dependency information storage unit 127.
  • the dependency relationship analysis unit 113 corresponds to the ranking unit 58 of FIG.
  • the intermediate information storage unit 125 stores the resource usage other than the measurement target resource in the load adjustment phase.
  • the dependency information storage unit 127 stores the number of dependency degrees of each resource obtained by the load determination unit 105.
  • the functions of the units of the performance measurement virtual server 100 described above are realized by executing a computer program on a computer.
  • the computer program of the present embodiment is a computer for realizing the performance measurement virtual server 100.
  • the procedure for acquiring the resource usage of a plurality of resources in one business virtual server 76), the procedure for generating a pseudo load on the measurement target resource, and applying a load to the measurement target resource allows the measurement target resource to Obtain the dependent resources, and calculate the number of dependencies of the measurement target resource based on the number of resources on which the measurement target resource depends, and the number of dependencies calculated as the measurement target resource for each of the multiple resources.
  • the performance measurement program according to the present embodiment is a performance measurement virtual program including a program instead of at least one virtual server (business virtual server 76 in FIG. 1) running on a physical server (migration source server 7 in FIG. 1).
  • a procedure for operating the server 100 on the source server 7 (FIG. 1) as the source and at least one business virtual server 76 operating on the source server 7 (FIG. 1) as the source A procedure for generating a load on the migration source server 7; a procedure for periodically acquiring the resource usage of the plurality of resources of the migration source server 7 and the performance measurement virtual server 100 operated on the migration source server 7; , And a procedure for adjusting the processing capability index are further described.
  • the performance measurement program of this embodiment uses the resource usage of each resource acquired in the acquisition procedure, and the resource usage of resources loaded in the procedure that generates a load up to the previous time other than the current measurement target resource
  • the resource usage of the measurement target resource that is loaded this time in the load generation procedure is removed from the resource usage of the measurement target resource of the target virtual server that is set in advance.
  • the measurement target resources are selected from the plurality of resources in the order ranked by the ranking procedure based on the processing capability index adjusted by the adjusting procedure. Select and use the target resource usage from the resource usage acquired in the acquisition procedure while generating sequential load.
  • the target resource is determined from the resource usage acquired in the acquisition procedure It is described that the computer further executes a procedure for estimating the processing capacity index corresponding to the usage amount.
  • the computer program of this embodiment may be recorded on a computer-readable storage medium.
  • the recording medium is not particularly limited, and various forms can be considered.
  • the program may be loaded from a recording medium into a computer memory, or downloaded to a computer through a network and loaded into the memory.
  • the information processing system 1 of the present embodiment includes a load adjustment phase and a load reproduction phase.
  • the information processing system 1 of the present embodiment performs a performance measurement by generating a pseudo load on the movement source server 7.
  • the information processing system 1 according to the present embodiment generates a load on the movement destination server 9 based on the processing capability index obtained in the load adjustment phase, and acquires the resource usage.
  • the management server 4 starts a load adjustment phase.
  • the performance measurement virtual server 100 applies a load corresponding to the business virtual server 76 on the migration source server 7 and performs performance measurement.
  • the management server 4 starts a load reproduction phase, generates a load on the destination server 9, and acquires the resource usage.
  • the performance measurement virtual server 100 and two types of virtual server images of the business virtual server 76 and the business virtual server 96 are registered in the virtual server image storage unit 29. .
  • the performance measurement virtual server 100 is activated on the pool server 5 by the virtual server activation unit 24 in advance.
  • the startup method is to copy the performance measurement virtual server 100 image registered in the virtual server image storage unit 29 to the pool server 5 with respect to the virtual server startup unit 24 and perform the performance measurement virtual server for performance measurement.
  • a method of instructing to start 100 can be used.
  • a plurality of virtual servers such as the performance measurement virtual server 100 (VM31 to VM31n) for performance measurement may be activated.
  • the virtual server activation unit 24 causes the business virtual servers 76 (VM11 to VM1i) and the business virtual servers 96 (VM21 to VM2j) to be placed on the migration source server 7 and the migration destination server 9 (SV21 to SV2m), respectively. It is in the activated state.
  • the startup method is to copy the image of the business virtual server registered in the virtual server image storage unit 29 to the virtual server startup unit 24 on the migration source server 7 and the migration destination server 9 (SV21 to SV2m), A method of instructing to start the business virtual server 76 (VM11 to VM1i) and the business virtual server 96 (VM21 to VM2j) may be used.
  • a plurality of virtual servers such as the business virtual server 76 (VM11 to VM1i) and the business virtual server 96 (VM21 to VM2j, VM81 to VM8x, VM91 to VM9y,...) May be activated.
  • the business virtual server 76 (VM11 to VM1i), the business virtual server 96 (VM21 to VM2j), and the performance measurement virtual server 100 (VM31 to VM3n) described above can perform client processing or job scheduled processing, Generate a load. Then, it is assumed that these loads consume resources of the physical server (migration source server 7, migration destination server 9, or pool server 5).
  • the operator performs a load adjustment instruction or a load reproduction instruction using an operation unit (not shown), and the performance information acquisition instruction unit 21 receives the instruction.
  • the performance measurement virtual server 100 is one and the business virtual server 76 is one.
  • FIG. 4 is a flowchart illustrating an example of the processing procedure of the load adjustment phase in the management server 4 of the present embodiment.
  • the management server 4 when the performance information acquisition instruction unit 21 (FIG. 1) receives a load adjustment instruction from the operator, the load adjustment and reproduction instruction unit 22 (FIG. 1) is subjected to load adjustment. An instruction is given (step S101 in FIG. 4). Then, in response to the load adjustment instruction, the load adjustment and reproduction instruction unit 22 (FIG. 1) performs a performance measurement virtual on the pool server 5 (FIG. 1) with respect to the virtual server moving unit 25 (FIG. 1).
  • the server 100 (FIG.
  • the performance measurement virtual server 100 (FIG. 1) is moved from the pool server 5 (FIG. 1) to the source server 7 (FIG. 1) (step S103 in FIG. 4).
  • the virtual server moving unit 25 (FIG. 1) is already realized by existing technologies such as operation management products and virtualization middleware products, and the implementation method is not particularly limited here.
  • the load adjustment and reproduction instructing unit 22 (FIG. 1) transfers the business virtual server 76 (FIG. 1) on the source server 7 (FIG. 1) to the evacuation server 6 with respect to the virtual server moving unit 25 (FIG. 1).
  • FIG. 1 Instructs to move up.
  • the business virtual server 76 (FIG. 1) on the source server 7 (FIG. 1) is moved to the evacuation server 6 (FIG. 1) (step S105 in FIG. 4).
  • the load adjustment and reproduction instruction unit 22 sends a performance information measurement instruction to the performance measurement virtual server 100 (FIG. 1) using the information transmission unit 26 (FIG. 1). (FIG. 1) (step S107 in FIG. 4).
  • the performance information measurement instruction includes each resource amount of the business virtual server 76 (FIG. 1) and the setting information 130 shown in FIG.
  • the performance measurement virtual server 100 starts the performance measurement process in response to the performance information measurement instruction (step S109 in FIG. 4). Details of the performance measurement processing in the performance measurement virtual server 100 (FIG. 1) will be described later.
  • the management server 4 receives the information reception unit 27 from the performance measurement virtual server 100 (FIG. 1) on each movement source server 7 (FIG. 1).
  • the processing capability index is received by (FIG. 1) and stored in the performance information storage unit 20 (FIG. 1) (step S111 in FIG. 4).
  • the load adjustment and reproduction instruction unit 22 replaces the virtual server moving unit 25 (FIG. 1) with the performance measurement virtual server 100 (FIG. 1) on the source server 7 (FIG. 1) as a pool server. 5 (FIG. 1) is instructed to move up.
  • the performance measurement virtual server 100 (FIG. 1) on the source server 7 (FIG. 1) is moved to the pool server 5 (FIG. 1) (step S113 in FIG. 4).
  • the load adjustment and reproduction instruction unit 22 replaces the virtual server moving unit 25 (FIG. 1) with the business virtual server 76 (FIG. 1) on the save server 6 (FIG. 1).
  • FIG. 1 Instructs to move up.
  • the business virtual server 76 (FIG. 1) on the save server 6 (FIG. 1) is moved to the source server 7 (FIG. 1) (step S115 in FIG. 4).
  • the load adjustment phase is completed, and the performance measurement process is performed without stopping the actual business service.
  • FIG. 5 and FIG. 6 are flowcharts showing an example of the procedure of the performance measurement process at the time of load adjustment in the performance measurement virtual server 100 of this embodiment.
  • the function of the performance measurement virtual server 100 of the present embodiment is realized by the computer executing the procedure shown below for the performance measurement program of the present embodiment. This flow is called from step S109 of the load adjustment process in the load adjustment phase of the management server 4 of the present embodiment in FIG.
  • description will be made with reference to FIGS. 1, 3 to 6, and 13.
  • the data processing method of the performance measurement virtual server 100 of this embodiment measures the load of a plurality of resources of a physical server (migration source server 7) and a virtual server (business virtual server 76) operating on the migration source server 7.
  • Data processing method of the control device (performance measurement virtual server 100) that performs the control device (performance measurement virtual server 100) on the migration source server 7 and the virtual server that operates on the migration source server 7 Resource usage amount (step S221 in FIG. 5), a load is generated on the measurement target resource (step S205 in FIG. 5), and the measurement target resource depends on the load on the measurement target resource.
  • the number of dependencies of the measurement target resource is calculated based on the number of resources on which the measurement target resource depends (step S in FIG. 5).
  • step S213 in FIG. 5 rank the resources in descending order of the number of dependencies calculated as the measurement target resources for the plurality of resources
  • step S3 in FIG. 6 select the measurement target resources from the plurality of resources in the ranked order
  • step S303 in FIG. 6 While generating the load sequentially (step S303 in FIG. 6), the processing capacity index of the resource usage of the measurement target resource is adjusted (step S307 in FIG. 6).
  • the performance measurement virtual server 100 is operated on the migration source server 7 instead of at least one virtual server running on the migration source server 7.
  • the control device is realized (step S103 in FIG. 4), and the performance measurement virtual server 100 is replaced by at least one business virtual server 76 operating on the migration source server 7 serving as the migration source. 7 is generated (step S303 in FIG. 6), and the resource usage of the multiple resources of the migration source server 7 and the performance measurement virtual server 100 operated on the migration source server 7 is periodically acquired. (Step S321 in FIG. 6), the processing capacity index is adjusted (Step S307 in FIG. 6).
  • the performance measurement virtual server 100 uses the resource usage of each acquired resource for resources that have been loaded up to the previous time other than the current measurement target resource. Process the resource usage so that the resource usage of the measurement target resource to which the load is applied this time is removed from the resource usage of the measurement target resource of the target virtual server set in advance.
  • the capacity index is adjusted (step S307 in FIG. 6), and based on the adjusted processing capacity index, the measurement target resource is selected from the plurality of resources in the ranked order, and the load is sequentially generated (in FIG. 6).
  • Step S309 whether the absolute value of the target resource usage from the acquired resource usage is within the allowable range (Step S313, step S315 in FIG. 6), and when it is determined that it is within the allowable range (YES in step S315 in FIG. 6), it corresponds to the target resource usage from the acquired resource usage
  • the processing capability index to be estimated is estimated (step S319 in FIG. 6).
  • the information receiving unit 103 measures the performance information transmitted from the management server 4 (FIG. 1) in step S107 of FIG.
  • the instruction is received and stored in the reception information storage unit 121 (FIG. 3) (step S201 in FIG. 5).
  • the measurement instruction unit 115 instructs the setting file reading unit 109 (FIG. 3) to read the parameters of the setting information 130 of FIG.
  • the setting file reading unit 109 reads the setting parameters of the performance measurement virtual server 100 specified by the setting information 130 (FIG. 13) from the reception information storage unit 121, and the setting information storage unit 123. (FIG. 3) (step S203 in FIG. 5).
  • the measurement instruction unit 115 instructs the load generation unit 107 (FIG. 3) to sequentially generate resource loads in units of resources.
  • the load generation unit 107 refers to each resource flag of the setting information 130 (FIG. 13), and is designated by the setting information 130 (FIG. 13) with the resource designated to be measured.
  • the job is processed with the initial processing capability index being input as an input, resulting in a resource load (step S205 in FIG. 5). Do nothing for resources that are not measured.
  • step S205 of FIG. 5 as in the setting information 130 shown in FIG. 13, the load generation unit 107 activates the number of processes corresponding to the number of cores from the multiprocessor information, and a plurality of processes simultaneously load. Can be generated.
  • the load generation unit 107 executes a load generation process or thread as a plurality of processes or threads, and the estimation unit (load adjustment unit 111) estimates a processing capability index of the virtual server in a multiprocessor environment. Can do.
  • the job is a unit of work performed by an information processing apparatus represented by a general server, and the size of the job is defined as a processing capability index.
  • the load can be adjusted by defining the number of numerical operations as the size of a job.
  • FIG. 14 it is assumed that a load generation and a rest (sleep) are alternately repeated within a certain period, and the resource usage output by the physical server can be adjusted. This is an example for explanation, and a method for generating a target load is not limited to this method.
  • the processing capacity index inherent in the server is 200
  • the resource usage is 50%.
  • the load generation period and the sleep period are alternately repeated at 500 ms.
  • the resource usage is 25%.
  • the load generation period is 250 ms and the sleep period is 750 ms, which are alternately repeated.
  • the resource corresponds to a CPU, a memory, an NW, and an HDD, and is calculated as a resource usage amount or a usage rate.
  • the usage rate can be determined from the resource usage of physical servers and virtual servers within a certain period.
  • the NW can control the load generated in the same manner as the CPU by alternately inputting NW input / output and sleep processing per second for a certain period.
  • the HDD can control the load generated in the same manner as the CPU by performing read / write and sleep processes per second for a certain period.
  • the HDD can be an HDD that can be shared by each server via a network. Resources are not limited to these, and if there are other resources that depend on them, they are to be measured.
  • the load generation period and the sleep period may be repeated at a shorter cycle. For example, it may be repeated alternately every 100 ms.
  • the information receiving unit 103 loads the load information notification unit 74 (FIG. 1) of the management agent 70 (FIG. 1) on the source server 7 (FIG. 1).
  • the resource usage of each resource is periodically received from 1) via the communication network 3 (FIG. 1) and stored in the load information storage unit 117 (FIG. 3).
  • the load information collection unit 72 (FIG. 1) of the management agent 70 (FIG. 1) uses the resources of the migration source server 7 (FIG. 1) and the performance measurement virtual server 100 (FIG. 1).
  • the acquired usage amount is periodically transmitted to the information receiving unit 103 (FIG. 3) of the management server 4 (FIG. 3) via the communication network 3 (FIG. 1) (step S221 in FIG. 5). ).
  • the resource usage may be monitored every 1000 ms.
  • the resource usage monitoring interval is shorter than the load generation period, the acquired resource usage may be incorrect. For this reason, it is preferable that the resource usage monitoring interval be equal to or longer than the load generation cycle obtained by adding the load generation period and the sleep period.
  • the load determination unit 105 determines whether or not the load of the measurement target resource is stable (step S207 in FIG. 5). For example, first, the load determination unit 105 (FIG. 3) updates the resource usage of the measurement target resource in the load information storage unit 117 (FIG. 3) (which is periodically updated in step S221 of FIG. 5). Make sure. If not updated, the process returns to step S205 in FIG. If there is an updated resource usage amount and skips the number of skips set in the setting information 130 of FIG. 13, it is determined that the load is stable (YES in step S207 of FIG. 5), and the load The determination unit 105 (FIG. 3) employs the updated resource usage. If the number of times has not been reached, it is determined that it is not yet stable (NO in step S207 in FIG. 5), and the process returns to step S205 in FIG.
  • the server Immediately after the load is applied, the server is not stable, and the effect of the load is not immediately reflected in the resource usage. Therefore, it is possible to obtain a stable and accurate value by skipping the specified number of skips. Can do.
  • the resource usage may be monitored periodically to check whether it is stable or not, but the process of skipping a predetermined number of times may be simpler and lighter.
  • the load determination unit 105 recognizes that the resource usage of the measurement target resource stored in the load information storage unit 117 (FIG. 3) has been updated, and the resource of another resource If it is determined that the usage amount is higher than before the load is generated, it is determined that there is a dependency. Then, the number of increasing resources is counted as the dependency level, and the dependency level of each resource is stored in the dependency information storage unit 127 (FIG. 3) in FIG. 15 (step S209 in FIG. 5).
  • FIG. 15 shows the usage amount of each resource stored in the load information storage unit 117 (FIG. 3) and the corresponding dependency number. The resource usage amount of each resource and the dependency number may be stored in association with each other.
  • step S205 the process proceeds to step S205 in FIG.
  • steps S205 to S209 are repeated with another resource as the measurement target. If there are no remaining resources (YES in step S211 in FIG. 5), the process proceeds to the next step S213 in FIG. At this time, the reception processing of the resource usage in step S221 in FIG. 5 is also stopped, and the process proceeds to step S213 in FIG.
  • the dependency relationship analysis unit 113 sorts the measurement results for each resource existing in the dependency information storage unit 127 in the order depending on the resources (descending order) (step S213 in FIG. 5). As described above, the dependency analysis processing is completed, and the dependency for each resource is obtained as shown in FIG.
  • the measurement instruction unit 115 applies a load to the load generation unit 107 (FIG. 3) in numerical order (descending order) of the dependency frequency stored in the dependency information storage unit 127 (FIG. 3).
  • a load generation instruction is issued (step S301 in FIG. 6). The reason for this is that if a load is applied in order from a resource with a high dependency frequency, when a load is applied to another resource with a low dependency frequency, the target load may be generated while absorbing the load depending on the load. This is because it can. This is because the target load will be exceeded later in ascending order.
  • the load generation unit 107 (FIG. 3) refers to each resource flag of the setting information 130 in FIG. 13 and generates a load on the resource to be measured (step S303 in FIG. 6).
  • a resource load is generated based on the initial processing capacity index set in the setting information 130.
  • a resource load is generated based on the processing capability index updated in the processing described later. Do nothing for resources that are not measured.
  • a processing capacity index is input to the load generation unit 107, a load of the performance measurement virtual server 100 is generated.
  • the information receiving unit 103 In parallel with steps S303 to S317, the information receiving unit 103 (FIG. 3) periodically receives the load information notification unit 74 (FIG. 1) of the management agent 70 (FIG. 1) on the source server 7 (FIG. 1). The resource usage of each resource is received via the communication network 3 (FIG. 1) and stored in the load information storage unit 117 (FIG. 3).
  • the load information collection unit 72 (FIG. 1) of the management agent 70 (FIG. 1) is operating on the migration source server 7 (FIG. 1) and the migration source server 7.
  • the resource usage of the virtual server 100 (FIG. 1) acquired is periodically sent to the information receiving unit 103 (FIG. 3) of the performance measurement virtual server 100 (FIG. 3) via the communication network 3 (FIG. 1). It is assumed that the message is transmitted (step S321 in FIG. 6).
  • the load determination unit 105 determines whether or not the load of the measurement target resource is stable (step S304 in FIG. 6). For example, first, the load determination unit 105 (FIG. 3) updates the resource usage of the measurement target resource in the load information storage unit 117 (FIG. 3) (updated periodically in step S321 in FIG. 6). Make sure. If not updated, the process returns to step S303 in FIG. If the updated resource usage amount exists and skips the number of skips set in the setting information 130 of FIG. 13, it is determined that the load is stable (YES in step S304 of FIG. 6), and the load The determination unit 105 (FIG. 3) employs the updated resource usage. If the number of times has not been reached, it is determined that it is not yet stable (NO in step S304 in FIG. 6), and the process returns to step S303 in FIG.
  • the load determination unit 105 determines whether the fluctuation before and after the resource load is within the fluctuation range. For example, the load determination unit 105 (FIG. 3) compares the latest resource usage of the performance measurement virtual server 100 with the previous resource usage, and determines whether or not it is within the range of the initial adjustment swing of the setting information 130 of FIG. Determine. If it is within the range, it is further determined whether or not the setting information 130 shown in FIG. 13 can be continued (step S305 in FIG. 6). If the condition is not satisfied (NO in step S305 in FIG. 6), the process returns to step S303 in FIG.
  • the load adjustment unit 111 (FIG. 3) is the first time, based on the initial processing capability index of the setting information 130 of FIG.
  • the updated processing capability index is associated with the resource usage of the performance measurement virtual server 100.
  • the resource usage of the measurement target is subtracted from the resource usage of each resource received from the management server 4 (FIG. 1).
  • a processing capability index that generates a load corresponding to the resource usage amount is estimated and stored in the performance information storage unit 119 (FIG. 3).
  • the following formula (1) is used for estimating the processing capacity index. If there is no resource usage of the measurement target data with reference to the intermediate information storage unit 125 (FIG. 3), the dependent resource usage of the intermediate information storage unit 125 (FIG. 3) is not used.
  • Expression (1) defines a mathematical expression to be used in the load adjustment or reproduction phase of the present embodiment described above.
  • the processing capacity index (NUM_TAR) of the business virtual server 76 (or business virtual server 96) is defined by the following equation from the dependency resource usage (P_DEP) of each measurement target.
  • NUM_TAR NUM_BSE ⁇ ((P_TAR ⁇ P_DEP) / P_AVM) (1)
  • P_DEP dependence resource usage
  • the target load is the resource usage of the business virtual server 76 (or business virtual server 96).
  • FIG. 16A there is no particular dependency when a load on the HDD I / O is generated.
  • the generated processing capacity index itself is used.
  • the HDD can be shared by each server via a network. Therefore, when a load is generated on the HDD I / O, a load is also generated on the NWI / O. Note that FIG. 16 shows that the load generated by the HDD I / O is a portion surrounded by a thick broken line.
  • NWI / O_T (NWI / O generated by the virtual server) usage amount (L1 + L2) is set as NWI / O_T, and NWI / O_HDDI / O is generated by HDD I / O (L2).
  • NWI / O_E of the NWI / O usage amount (L1) at the time of actual estimation is expressed by the following equation (2).
  • NWI / O_E NWI / O_T- (NWI / O_HDDI / O) (2)
  • FIG. 16C when estimating the CPU load, the CPU load (L4) when the HDD I / O load is generated and the NWI / O load are generated. CPU load (L5) is generated. Therefore, the processing capacity index that can output the resource usage of the part (L3) obtained by subtracting the parts (L4) and (L5) from the target load is estimated.
  • FIG. 16C shows that the load generated by NWI / O is a portion surrounded by a thick alternate long and short dash line.
  • CPU_T is the target CPU usage (CPU usage generated by the virtual server) (L3 + L4 + L5)
  • CPU_NWI / O is CPU usage (L5) generated by NWI / O
  • CPU_HDDI / O is HDDI / O.
  • CPU_E CPU_T- (CPU_NWI / O + CPU_HDDI / O) Formula (3) From the above, it is possible to estimate the processing capability index for the target resource usage (step S307 in FIG. 6). That is, the load generation unit 107 (FIG. 3) adjusts the processing capability index so that the resource usage amount of the business virtual server 76 (or the business virtual server 96) becomes the updated processing capability index and the resource usage amount. .
  • the load generation unit 107 (FIG. 3) performs processing based on the estimated resource processing capacity index, and as a result, generates a resource load of the performance measurement virtual server 100 (FIG. 1) (step S309 in FIG. 6). ). At this time, when a processing capability index is input to the load generation unit 107, a load on the performance measurement virtual server 100 is generated.
  • the load determination unit 105 recognizes that the resource usage of the load information storage unit 117 (FIG. 3) has been updated, and performs measurement for the number of times of the setting information 130 in FIG. If this is the case (YES in step S311 in FIG. 6), the resource usage is adopted. If the updated resource usage does not exist in the load information storage unit 117 or does not reach the number of continuations (NO in step S311 in FIG. 6), the process returns to step S309 in FIG.
  • Step S313 in FIG. 6 it is determined whether or not the load determination unit 105 (FIG. 3) satisfies the number of times that the processing capacity index has been adjusted to obtain the reference resource usage amount, that is, the maximum number of adjustments set in the setting information 130 of FIG. (Step S313 in FIG. 6). If the maximum number of adjustments is satisfied (YES in step S313 in FIG. 6), the error content is included in the result and transmitted to the management server 4 via the communication network 3 (FIG. 1), and step S111 in FIG. Returning to (step S319 in FIG. 6).
  • step S313 in FIG. 6 When the determination in step S313 in FIG. 6 is NO, the load determination unit 105 (FIG. 3) performs the performance measurement virtual server 100 obtained as a result from the processing capability index and the execution processing for the processing capability index. To resource usage. Then, the load determination unit 105 determines whether or not it is within the allowable range of the resource usage that is the reference set in the setting information 130 in FIG. 13 (step S315 in FIG. 6). If the condition is satisfied (YES in step S315 in FIG. 6), the process proceeds to step S317 in FIG. If the condition is not satisfied (NO in step S315 in FIG. 6), the process returns to step S307 in FIG.
  • step S315 in FIG. 6 determines whether the load adjustment unit 111 (FIG. 3) stores the processing capability index to be measured in the performance information storage unit 119 (FIG. 3), and is not the measurement target at that time. Are stored in the intermediate information storage unit 125 (FIG. 3). If there is another measurement target resource that has not yet generated a load (YES in step S317 in FIG. 6), the process returns to step S303 in FIG. 6, and the load of the target resource remains generated and another resource is generated. The following processing is performed on the measurement target. If there is no measurement target resource that has not yet generated a load (NO in step S317 in FIG. 6), the process proceeds to step S319 in FIG. At this time, the reception processing of the resource usage amount in step S321 in FIG. 6 is also stopped, and the process proceeds to step S319 in FIG.
  • the information transmission unit 101 (FIG. 3) is obtained as a result of the processing capability index stored in the performance information storage unit 119 (FIG. 3). Is transmitted to the management server 4 (FIG. 1) via the communication network 3 (step S319 in FIG. 6).
  • the load estimation process in the performance measurement virtual server 100 ends, and the process returns to step S111 in FIG.
  • FIG. 7 is a flowchart illustrating an example of the processing procedure of the load reproduction phase in the management server 4 of the present embodiment.
  • the management server 4 when the performance information acquisition instructing unit 21 (FIG. 1) receives a load reproduction instruction from the operator, the load reproduction and load instructing unit 22 (FIG. 1) reproduces the load.
  • An instruction is given (step S401 in FIG. 7).
  • the designation of the destination server 9 is accepted together with the load reproduction instruction.
  • the load adjustment and reproduction instruction unit 22 (FIG.
  • the performance measurement virtual server 100 (FIG. 1) performs a performance measurement virtual server on the pool server 5 (FIG. 1) with respect to the virtual server moving unit 25 (FIG. 1). 100 (FIG. 1) is instructed to move to each destination server 9 (FIG. 1) designated by the user. Reproduction processing is not performed on the servers other than the designated destination server 9 (FIG. 1). In accordance with the instruction, the performance measurement virtual server 100 (FIG. 1) is moved from the pool server 5 (FIG. 1) to the destination server 9 (FIG. 1) one by one (step S403 in FIG. 7).
  • the load adjustment and reproduction instruction unit 22 sends a performance information measurement instruction to the performance measurement virtual server 100 (FIG. 1) using the information transmission unit 26 (FIG. 1). 1) (step S405 in FIG. 7).
  • the performance information measurement instruction includes the processing capability index of the business virtual server 76 (FIG. 1) on the source server 7 (FIG. 1) estimated by the performance measurement virtual server 100 (FIG. 1). Yes.
  • the performance measurement virtual server 100 (FIG. 1) reproduces the load in response to the performance information measurement instruction and performs the performance measurement process under the reproduced load (step S407 in FIG. 7). Details of the performance measurement processing in the performance measurement virtual server 100 (FIG. 1) will be described later.
  • the management server 4 receives information from the performance measurement virtual server 100 (FIG. 1) on the destination server 9 (FIG. 1).
  • the resource usage is received by the unit 27 (FIG. 1) and stored in the performance information storage unit 20 (FIG. 1) (step S409 in FIG. 7). This reception process is periodically repeated.
  • the load reproduction process is stopped, and the process proceeds to the next step S411 in FIG.
  • the load adjustment and reproduction instruction unit 22 replaces the virtual server moving unit 25 (FIG. 1) with the performance measurement virtual server 100 (FIG. 1) on the destination server 9 (FIG. 1) as a pool server. 5 (FIG. 1) is instructed to move up.
  • the performance measurement virtual server 100 on the destination server 9 is moved to the pool server 5 (step S411 in FIG. 7).
  • the information comparison unit 28 acquires the resource usage consumed on the destination server 9 (FIG. 1) in the performance information storage unit 20 (FIG. 1).
  • the information comparison unit 28 also presents it on a display unit (not shown) or the like so that the amount of resource usage can be compared when it is performed on a plurality of destination servers 9 (SV21 to SV2m) (FIG. 1). (Step S413 in FIG. 7).
  • the operator can determine to move to a physical server (movement destination server 9) that does not become a heavy load during movement.
  • FIG. 8 is a flowchart showing an example of the procedure of the performance measurement process at the time of load reproduction in the performance measurement virtual server 100 of this embodiment.
  • the function of the performance measurement virtual server 100 of the present embodiment is realized by the computer executing the procedure shown below for the performance measurement program of the present embodiment. This flow is called from step S407 of the load reproduction process in the load reproduction phase of the management server 4 of the present embodiment in FIG.
  • the information receiving unit 103 receives the performance information measurement instruction transmitted from the management server 4 (FIG. 1) in step S405 of FIG.
  • the received information is stored in the received information storage unit 121 (FIG. 3) (step S501 in FIG. 8).
  • the measurement instruction unit 115 instructs the setting file reading unit 109 (FIG. 3) to read the parameters of the setting information 130 of FIG.
  • the setting file reading unit 109 reads the setting parameters of the performance measurement virtual server 100 specified by the setting information 130 (FIG. 13) from the reception information storage unit 121, and the setting information storage unit 123. (FIG. 3) is stored (step S503 in FIG. 8).
  • the measurement instruction unit 115 instructs the load generation unit 107 (FIG. 3) to generate a load so as to apply a load to the resource.
  • the load generation unit 107 performs processing based on the processing capability index of the setting information 130 (FIG. 13) stored in the setting information storage unit 123 (FIG. 3) to generate a resource load. (Step S505 in FIG. 8).
  • the load is applied all at once regardless of the order of loading the resources.
  • a load on the performance measurement virtual server 100 is generated.
  • step S505 in FIG. 8 as in the setting information 130 shown in FIG. 13, the load generation unit 107 activates the number of processes corresponding to the number of cores from the multiprocessor information, and a plurality of processes simultaneously load. Can be generated. That is, the load generation unit 107 executes a load generation process or thread as a plurality of processes or threads. Then, the estimation unit (load adjustment unit 111) can estimate the processing capability index of the virtual server in a multiprocessor environment.
  • the information receiving unit 103 performs load information notification unit 94 (FIG. 1) of the management agent 90 (FIG. 1) on the destination server 9 (FIG. 1).
  • the resource usage is periodically received via the communication network 3 (FIG. 1), and the data is stored in the load information storage unit 117 (FIG. 3) (step S521 in FIG. 8).
  • the load determination unit 105 (FIG. 3) checks whether the resource usage of the load information storage unit 117 (FIG. 3) has been updated (step S507 in FIG. 8).
  • the load determination unit 105 (FIG. 3) determines that the updated resource usage is present in the load information storage unit 117 (FIG. 3) (YES in step S507 in FIG. 8)
  • the load information storage unit The latest resource usage is read from 117 (FIG. 3) and transmitted to the management server 4 (FIG. 1) via the communication network 3 (FIG. 1) using the information transmission unit 101 (FIG. 3) (FIG. 8). Step S509).
  • the latest resource usage amount of the load information storage unit 117 (FIG. 3) and the absolute value of the previous resource usage amount are acquired, and are within the amplitude specified in the setting information 130 of FIG. 13, and When the number of continuations specified by the setting information 130 in FIG. 13 is satisfied (YES in step S511 in FIG. 8), this process ends, and the process returns to step S409 in FIG. At this time, the resource usage reception process in step S521 in FIG. 8 is also stopped. Thus, the performance measurement process in the performance measurement virtual server 100 ends, and the process returns to step S409 in FIG. 7 described above. If the condition is not satisfied (NO in step S511 in FIG. 8), the process returns to step S507 in FIG.
  • a dependency is applied to another resource due to I / O processing or the like.
  • Analyze (define these as dependent loads), and use the results to estimate the load for the resource usage minus the dependent load from the target load. Can be adjusted.
  • ⁇ ⁇ In particular, analyze the dependency of another resource that occurs when a load is applied to the resource to be measured by looking at the amount of use of the other resource and classify whether there is a resource with a high dependency number.
  • the load applied to another resource when the load is applied in the order depending on the resource is stored.
  • the load corresponding to the above-described load subtracted from the target resource usage is reproduced. By repeating this, the target resource usage can be generated.
  • FIG. 9 is a schematic block diagram showing the configuration of the information processing system 2 according to the embodiment of the present invention.
  • the information processing system 2 of this embodiment is different from the information processing system 1 of the above embodiment in that it has a configuration for determining a physical server having an appropriate load from among physical servers that are migration destination candidates. .
  • the performance measurement virtual server 300 is operated on the migration destination server 200 to be verified, and the load generation unit 107 (FIG. 10) performs the ranking unit (dependency analysis in FIG. 10).
  • the resource reception unit 129 acquires the information reception unit 103 (FIG. 10) while selecting the measurement target resource from the plurality of resources in the order ranked by the unit 113) and sequentially generating loads.
  • the resource usage of the resource to which the load generation unit 107 has applied load up to the previous time other than the current measurement target resource, and the measurement target to which the load generation unit 107 has applied the current load The resource usage amount obtained by removing the resource usage amount from the resource usage amount corresponding to the empty capacity of the target physical server set in advance, Further, the processing capability index is adjusted so that the control device (performance measurement virtual server 300) determines that the load generating unit 107 is ranked based on the processing capability index adjusted by the load adjusting unit 111 (FIG. 10).
  • the measurement target resource is selected from a plurality of resources in the order ranked by the attaching unit (dependency relationship analyzing unit 113), and the load is sequentially generated.
  • a determination unit load determination unit 105 in FIG. 10 that determines whether or not the absolute value of the resource usage corresponding to the empty capacity is within the allowable range and the load determination unit 105 are within the allowable range. Is determined, the processing corresponding to the resource usage corresponding to the empty capacity of the destination server 200 from the resource usage acquired by the information receiving unit 103 Comprising estimation unit to estimate a force indicator (the empty resource adjustment unit 129), the.
  • the information processing system 2 of the present embodiment includes a management server 8 having an empty resource acquisition instruction unit 23 instead of the load adjustment and reproduction instruction unit 22 of the information processing system 1 of the above embodiment of FIG. 1 includes a pool server 5 having a plurality of performance measurement virtual servers 300 instead of the plurality of performance measurement virtual servers 100 of the information processing system 1 of the above embodiment of FIG. They are connected via the communication network 3.
  • the plurality of destination servers 200 (SV31,..., SV3b, b are natural numbers) are the same as the destination servers 9 (SV21,..., SV2m, m are natural numbers) of the information processing system 1 in FIG.
  • the management agent 210 includes a load information collection unit 212 and a load information notification unit 214.
  • the pool server 5 and the migration destination server 200 are physical servers that can arrange virtual servers and are provided with a function that can move between the servers. is there.
  • the business virtual server 216 is equipped with an application that performs processing such as web, mail, and backup, and performs such processing.
  • the performance measurement virtual server 300 of the present embodiment operates.
  • a plurality (a pieces) of the performance measurement virtual server 300 shown in FIG.
  • the management agent 210 of the destination server 200 includes a load information collection unit 212 and a load information notification unit 214, and has a role of instructing to start or end these functions.
  • the business virtual server 216 operates on the migration destination server 200.
  • a plurality (k1, k2,..., Kb) of business virtual servers 216 may be operated on each migration destination server 200 (other than VM41 to VM4k are omitted in the figure).
  • the performance information acquisition instruction unit 21 issues an empty resource acquisition instruction to the empty resource acquisition instruction unit 23.
  • the operator instructs the management server 8 of the information processing system 2 to acquire empty resources using, for example, an operation unit (not shown). Can do.
  • the performance information acquisition instruction unit 21 instructs the empty resource acquisition instruction unit 23 according to the instruction. At this time, the operator specifies the destination server 200 to be verified and accepts it.
  • the empty resource acquisition instruction unit 23 of the management server 8 receives the empty resource acquisition instruction from the performance information acquisition instruction unit 21. Then, according to the instruction, the free resource acquisition instruction unit 23 instructs the virtual server moving unit 25 to move the performance measurement virtual server 300 from the pool server 5 to the movement destination server 200 to be verified. Furthermore, the empty resource acquisition instruction unit 23 transmits a performance information measurement instruction to the performance measurement virtual server 300 moved to the movement destination server 200 using the information transmission unit 26 via the communication network 3.
  • the performance information measurement instruction is the same as in the above embodiment.
  • each unit of the management server 8 described above are realized by executing a computer program on a computer.
  • This computer program may be recorded on a computer-readable storage medium.
  • the recording medium is not particularly limited, and various forms can be considered.
  • the program may be loaded from a recording medium into a computer memory, or downloaded to a computer through a network and loaded into the memory.
  • FIG. 10 is a functional block diagram showing the configuration of the performance measurement virtual server 300 of this embodiment.
  • the performance measurement virtual server 300 according to the present embodiment further includes an air resource adjustment unit 129 in addition to the configuration of the performance measurement virtual server 100 according to the above embodiment of FIG. 3.
  • the figure shows the performance measurement virtual server VM51, the other performance measurement virtual server VM5a has the same configuration.
  • the air resource adjustment unit 129 receives information while the load generation unit 107 selects a measurement target resource from a plurality of resources in the order ranked by the ranking unit (dependency relationship analysis unit 113) and sequentially generates a load. Based on the resource usage amount of each resource acquired by the unit 103, the resource usage amount of the resource to which the load generation unit 107 has applied a load up to the previous time other than the current measurement target resource, and the load generation unit 107 the current load The processing capability index is adjusted so that the resource usage amount of the measurement target resource multiplied by the resource usage amount is removed from the resource usage amount corresponding to the empty capacity of the target physical server set in advance.
  • the load determination unit 105 determines that the free resource adjustment unit 129 is within the allowable range, the resource use amount corresponding to the free capacity of the physical server from the resource use amount acquired by the information reception unit 103. Estimate the processing capacity index corresponding to.
  • the functions of the units of the performance measurement virtual server 300 described above are realized by executing a computer program on a computer.
  • the computer program according to the present embodiment causes a computer for realizing the performance measurement virtual server 300 to operate the performance measurement virtual server 300 on the migration destination server 200 to be verified, in addition to the procedure of the above embodiment.
  • the load generation procedure select the measurement target resource from the plurality of resources in the order in which they were ranked in the ranking procedure, and generate the load in order, and the resource usage of each resource acquired in the acquisition procedure Based on, the resource usage of the resource that was loaded in the procedure that generates load up to the previous time other than the current measurement target resource, and the resource usage of the measurement target resource that was loaded this time in the procedure that generates load Whether the amount is a resource usage corresponding to the empty capacity of the target server 200 that is a preset target In the order of ranking in the ranking procedure in the procedure of adjusting the processing capacity index so that it becomes the removed resource usage, and the procedure of generating load based on the processing capacity index adjusted by the adjusting procedure The absolute value of the resource usage corresponding to the empty capacity of the destination server 200 is within the allowable range from the resource usage acquired in the acquisition procedure while selecting the measurement target resource from the plurality of resources and generating the load sequentially.
  • this program When it is determined that it is within the allowable range according to the procedure for determining whether or not it is within the allowable range by the determination procedure, it corresponds to the empty capacity of the destination server 200 from the resource usage acquired in the acquisition procedure And a procedure for estimating a processing capacity index corresponding to the resource usage.
  • this program is referred to as a performance measurement program.
  • the computer program of this embodiment may be recorded on a computer-readable storage medium.
  • the recording medium is not particularly limited, and various forms can be considered.
  • the program may be loaded from a recording medium into a computer memory, or downloaded to a computer through a network and loaded into the memory.
  • 11 and 12 are flowcharts illustrating an example of the operation of the information processing system 2 of the present embodiment.
  • the data processing method of the control device (performance measurement virtual server 300) of the present embodiment is the same as the data processing method of the control device of the above-described embodiment, in which the performance measurement virtual server 300 is operated on the migration destination server 200 to be verified.
  • the measurement target resource is selected from a plurality of resources in the order of ranking, and a load is generated in sequence (step S303 in FIG. 12), based on the acquired resource usage of each resource.
  • the resource usage of the resource that has been loaded up to the previous time other than the current measurement target resource and the resource usage of the measurement target resource that has been loaded this time are set in the empty space of the target physical server that has been set in advance.
  • the processing capacity index is adjusted so as to be the resource usage removed from the resource usage corresponding to the capacity (see FIG. 12).
  • S701 based on the adjusted processing capability index, select a measurement target resource from a plurality of resources in the order of ranking (step S317 in FIG. 12), and sequentially generate loads (step in FIG. 12).
  • S309) it is determined whether or not the absolute value of the resource usage corresponding to the empty capacity of the physical server is within the allowable range from the acquired resource usage (step S703 to step S707 in FIG. 12), and the allowable range When it is determined that it falls within the range (YES in step S707 in FIG.
  • the processing capacity index corresponding to the resource usage corresponding to the empty capacity of the destination server 200 is estimated from the acquired resource usage (FIG. 12). 12 step S709). That is, the load generation unit 107 (FIG. 10) adjusts the processing capacity index so that the processing capacity index for the free resource is obtained from the reference processing capacity index.
  • the migration destination server 200 has one performance measurement virtual server 300 and a plurality of business virtual servers 216 (VM41 to VM4k). It is assumed that empty resources of the destination server 200 are acquired.
  • the management server 8 two types of virtual server images, a performance measurement virtual server 300 and a business virtual server 216, are registered in the virtual server image storage unit 29.
  • the virtual server activation unit 24 activates the performance measurement virtual server 300 on the pool server 5 in advance.
  • a plurality of performance measurement virtual servers 300 (VM51 to VM5a) may be activated.
  • a plurality of business virtual servers 216 are activated. It is assumed that a load is generated by a client process or a job scheduled process and the resources of the destination server 200 are consumed.
  • a plurality of virtual servers for business use 216 (VM41 to VM4k, VM61 to VM6k,..., VM71 to VM7k) may be started.
  • the operator performs an empty resource acquisition instruction using an operation unit (not shown), and the performance information acquisition instruction unit 21 receives the instruction.
  • the maximum capacity of each resource use amount itself is known from the results such as general benchmark results.
  • the performance information acquisition instruction unit 21 (FIG. 9) receives an empty resource acquisition instruction from the operator, the performance information acquisition instruction unit 21 (FIG. 9) instructs the empty resource acquisition instruction.
  • An empty resource acquisition instruction is issued to the unit 23 (FIG. 9) (step S601 in FIG. 11).
  • the empty resource acquisition instruction unit 23 sends a performance measurement virtual server 300 (FIG. 9) on the pool server 5 to the virtual server migration unit 25 (FIG. 9). Is moved to the destination server 200 (FIG. 9) designated by the user. Note that no measurement is performed on the destination server 200 that is not designated by the user.
  • the performance measurement virtual server 300 is moved from the pool server 5 (FIG. 9) to the destination server 200 (FIG. 9) (step S103 in FIG. 11).
  • the empty resource acquisition instruction unit 23 (FIG. 9) issues a performance information measurement instruction to the performance measurement virtual server 300 (FIG. 9) using the information transmission unit 26 (FIG. 9) (FIG. 9). Step S107). Details of the performance measurement process in the performance measurement virtual server 300 (FIG. 9) will be described later.
  • the management server 8 When the performance measurement process (step S603 in FIG. 11) in the performance measurement virtual server 300 (FIG. 9) ends, the management server 8 performs the performance measurement virtual server 300 (FIG. 9) on each destination server 200 (FIG. 9). 9) to the information receiving unit 27 (FIG. 9) receives the processing capability index. And the processing capacity parameter
  • the information comparison unit 28 acquires the processing capability index measured by the destination server 200 (FIG. 9) in the performance information storage unit 20 (FIG. 9). Then, when the information comparison unit 28 further performs measurement processing for a plurality of destination servers 200 (SV31 to SV3b) (FIG. 9), the information comparison unit 28 compares the size of the processing capability index for each destination server 200. It is presented on a display unit (not shown) or the like so that it can be done (step S605 in FIG. 11). As a result, the operator can determine whether the migration destination server 200 (SV31 to SV3b) has available resources by the size of the processing capability index.
  • the management server 8 sequentially operates the performance measurement virtual server 300 on the destination server 200 as a plurality of destination candidates, and uses the estimation unit (load adjustment) as the verification destination server 200.
  • a selection unit (not shown) for selecting the destination server 200 based on the processing capability index obtained by the unit 111).
  • the operator uses the operation unit (not shown) to instruct to select the destination server 200. be able to.
  • a condition may be set for the processing capability index, and a destination candidate that satisfies the condition may be automatically selected as the destination server 200.
  • FIG. 12 is a flowchart illustrating an example of a load estimation process procedure of the performance measurement process in the performance measurement virtual server 300 according to the present embodiment.
  • the function of the performance measurement virtual server 300 of the present embodiment is realized by the computer executing the procedure shown below for the performance measurement program of the present embodiment.
  • description will be made with reference to FIGS. 10 and 12.
  • the measurement instruction unit 115 applies a load to the load generation unit 107 (FIG. 10) in the numerical order (descending order) of the dependency frequency stored in the dependency information storage unit 127 (FIG. 10).
  • a load generation instruction is issued (step S301 in FIG. 12). The reason for this is that if a load is applied in order from a resource with a high dependency frequency, when a load of another resource with a low dependency frequency is applied, the target load may be generated while absorbing the load depending on the load. This is because it can. This is because the target load will be exceeded later in ascending order.
  • the strength of the load to be generated is defined as a processing capability index, and a method of repeating load generation and rest alternately within a certain period as shown in FIG. 14 can adjust the output resource usage.
  • the load generation unit 107 (FIG. 10) refers to each resource flag specified in the setting information 130 in FIG. 13 and generates a load on the resource to be measured (step S303 in FIG. 12).
  • a resource load is generated based on the initial processing capacity index set in the setting information 130.
  • a resource load is generated based on the processing capability index updated in the processing described later. Do nothing for resources that are not measured.
  • a processing capacity index is input to the load generation unit 107, a load of the performance measurement virtual server 100 is generated.
  • step S303 in FIG. 12 as in the setting information 130 shown in FIG. 13, the load generation unit 107 activates the number of processes corresponding to the number of cores from the multiprocessor information, and a plurality of processes simultaneously load. Can be generated. That is, the load generation unit 107 executes a load generation process or thread as a plurality of processes or threads. Then, the estimation unit (load adjustment unit 111) can estimate the processing capability index of the virtual server in a multiprocessor environment.
  • the resources correspond to CPU, memory, NW, and HDD, and are calculated as resource usage or usage rate.
  • the usage rate can be determined from the resource usage of physical servers and virtual servers within a certain period.
  • the NW can control the load generated in the same manner as the CPU by alternately inputting NW input / output and sleep processing per second for a certain period.
  • the HDD can control the load generated in the same manner as the CPU by performing read / write and sleep processes per second for a certain period. Resources are not limited to these, and if there are other resources that depend on them, they are to be measured.
  • the information receiving unit 103 performs the load information notification unit 214 (FIG. 9) of the management agent 210 (FIG. 9) on the destination server 200 (FIG. 9).
  • the resource usage is periodically received via the communication network 3 (FIG. 9) and stored in the load information storage unit 117 (FIG. 10).
  • the load information collection unit 212 (FIG. 9) of the management agent 210 (FIG. 9) operates on the migration destination server 200 (FIG. 9) and the migration destination server 200.
  • What acquired the resource usage of the measurement virtual server 300 (FIG. 9) and the business virtual server 216 (FIG. 9) is sent to the information receiving unit 103 (FIG. 10) of the performance measurement virtual server 300 (FIG. 10). It is assumed that the data is periodically transmitted via the communication network 3 (FIG. 9) (step S721 in FIG. 12).
  • the load determination unit 105 determines whether or not the load of the measurement target resource is stable (step S304 in FIG. 12). For example, first, the load determination unit 105 (FIG. 10) updates the resource usage of the measurement target resource in the load information storage unit 117 (FIG. 10) (updated periodically in step S721 in FIG. 12). Make sure. If not updated, the process returns to step S303 in FIG. If there is an updated resource usage amount and skips the number of skips set in the setting information 130 of FIG. 13, it is determined that the load is stable (YES in step S304 of FIG. 12), and the load The determination unit 105 (FIG. 10) employs the updated resource usage. If the number of times has not been reached, it is determined that it is not yet stable (NO in step S304 in FIG. 12), and the process returns to step S303 in FIG.
  • the load determination unit 105 compares the latest resource usage of the performance measurement virtual server 300 with the previous resource usage, and determines whether it is within the range of the initial adjustment swing of the setting information 130 of FIG. 13. If it is within the range, it is determined whether or not the setting information 130 shown in FIG. 13 can be continued (step S305 in FIG. 12). If the condition is not satisfied (NO in step S305 in FIG. 12), the process returns to step S303 in FIG.
  • the load adjustment unit 111 (FIG. 10) is the first time, based on the initial processing capability index of the setting information 130 of FIG.
  • the updated processing capability index is associated with the resource usage of the performance measurement virtual server 300.
  • the processing capacity index is adjusted so that the resource usage amount becomes the reference of the setting information 130 in FIG.
  • the following equation (4) is used (step S701 in FIG. 12).
  • Expression (4) defines a mathematical expression to be used in the load adjustment or reproduction phase of the present embodiment described above.
  • the reference processing capability index (NUM_BSE) is set so that the reference resource usage (P_BSE) is obtained from the load information (P_AVM) of the performance measurement virtual server 300 output by the first processing capability index (NUM_FST). It is what defines what was adjusted to.
  • NUM_BSE NUM_FST ⁇ (P_BSE / P_AVM) Expression (4)
  • the load generation unit 107 (FIG. 10) generates a resource load of the performance measurement virtual server 300 based on the processing capability index (step S309 in FIG. 12). At this time, when a processing capability index is input to the load generation unit 107, a load on the performance measurement virtual server 100 is generated. Then, the load determination unit 105 (FIG. 10) recognizes that the resource usage of the load information storage unit 117 (FIG. 10) has been updated, and performs the measurement for the number of times of the setting information 130 of FIG. If this is the case (YES in step S703 of FIG. 12), the resource usage is adopted. If the updated resource usage does not exist in the load information storage unit 117 or does not reach the number of continuations (NO in step S703 in FIG. 6), the process returns to step S701 in FIG.
  • the load determination unit 105 determines whether or not the number of times that the processing capacity index has been adjusted to obtain the reference resource usage, that is, whether or not the maximum number of adjustments set in the setting information 130 of FIG. Step S705 in FIG. 12). If the maximum number of adjustments is satisfied (YES in step S705 in FIG. 12), the error content is included in the result and transmitted to the management server 8 (FIG. 9) via the communication network 3 (FIG. 1). The process returns to step S111 (step S319 in FIG. 12).
  • step S705 of FIG. 12 determines whether it is within the allowable range of the resource usage that is the set reference. If the condition is satisfied (YES in step S707 in FIG. 12), the process proceeds to the next step S709 in FIG. If the condition is not satisfied (NO in step S707 in FIG. 12), the process returns to step S701 in FIG.
  • the capacity index is estimated from the processing capacity index serving as a reference by using the following formula (5). If the resource usage of the measurement target data does not exist with reference, the resource usage of the intermediate information storage unit 125 is not used.
  • the following formula (5) defines a formula to be used in the load adjustment or reproduction phase of the present embodiment described above.
  • the resources of the entire server including the resource usage of the host (P_SV), the resource usage of the virtual server other than the performance measurement virtual server ( ⁇ P_VM *), P_SV, and P_VM
  • P_CAP resource usage amount for the free capacity is obtained by subtracting the resource usage amount (P_AVM) of the current performance measurement virtual server from the usage amount (P_ALL).
  • * asterisk means all related servers.
  • P_CAP P_ALL ⁇ ⁇ (P_SV + ⁇ P_VM *) ⁇ P_AVM ⁇ Expression (5)
  • the target load is the resource usage when the empty resources of the destination server 200 excluding the load of the business virtual server 216 (FIG. 10) are used up.
  • the load generated by the HDD I / O is a portion surrounded by a thick broken line
  • the load generated by the NWI / O is a portion surrounded by a thick one-dot chain line.
  • HDDI / O_M is the HDD I / O usage amount (L1 + L2) for the maximum capacity on the physical server
  • HDDI / O_VM is the HDD I / O usage amount (L1) generated by the business virtual server
  • the physical server The HDDI / O_E of the HDDI / O usage amount (L2) for the above empty capacity is represented by the following equation (6).
  • HDDI / O_E HDDI / O_M-HDDI / O_VM (6)
  • the processing capacity index corresponding to the resource usage of the part (L5) obtained by subtracting the resource usage of the part (L3) used by the business virtual server (L3) from the target load is estimated. .
  • NWI / O_M is the NWI / O usage amount (L3 + L4 + L5) for the maximum capacity on the physical server
  • NWI / O_HDDI / O is the NWI / O usage amount (L4) generated by the HDD I / O load
  • NWI / O_VM is the NWI / O usage (L3) generated by the business virtual server.
  • NWI / O_E of the NWI / O usage amount (L5) corresponding to the empty capacity on the physical server is expressed by the following equation (7).
  • NWI / O_E NWI / O_M- ⁇ NWI / O_HDDI / O + NWI / O_VM ⁇ (7)
  • CPU_M is the CPU usage (L7 + L8 + L9 + L10) for the maximum capacity on the physical server
  • CPU_HDDI / O is the CPU usage (L9) generated by the load of HDDI / O
  • CPU_NWI / O is NWI / O.
  • CPU_VM is a CPU usage amount (L7) generated by the business virtual server.
  • CPU_E of the CPU usage (L10) corresponding to the empty capacity on the physical server is expressed by the following equation (8).
  • CPU_E CPU_M- ⁇ CPU_NWI / O + CPU_HDDI / O + CPU_VM ⁇ (8) From the above, it is possible to estimate the processing capacity index for the target resource usage (step S709 in FIG. 12).
  • the load adjustment unit 111 (FIG. 10) stores the processing capability index to be measured in the performance information storage unit 119 (FIG. 10), and the resource usage other than the measurement target at that time is the intermediate information storage unit 125 (FIG. 10). To remember. If there is a measurement target resource that has not yet generated a load (YES in step S317 in FIG. 12), the process returns to step S303 in FIG. 12, stops the target measurement, and sets another resource as the measurement target. . If there is no measurement target resource that has not yet generated a load (NO in step S317 in FIG. 12), the process proceeds to step S711 in FIG. At this time, the reception processing of the resource usage in step S721 in FIG. 12 is also stopped, and the process proceeds to step S711 in FIG.
  • the free resource adjustment unit 129 calculates the resource usage corresponding to the free capacity, estimates the processing capacity index corresponding to the free capacity, and the performance information storage unit 119 (FIG. 10). (Step S711 in FIG. 12). Then, the information transmission unit 101 is used to transmit the processing capability index stored in the performance information storage unit 119 (FIG. 10) to the management server 8 as a result (step S319 in FIG. 12). Thus, the load estimation process in the performance measurement virtual server 300 ends, and the process returns to step S111 in FIG.
  • the same effect as that of the information processing system 1 of the above embodiment can be obtained, and when a load is applied to a certain resource on the measurement target server.
  • Dependency analysis in which another resource is loaded by I / O processing or the like is performed (these are defined as dependency loads).
  • estimate the load for the resource usage by subtracting the dependent load from the target load, and adjust the measurement program so that it becomes a processing capacity index that can generate the load for the subtracted resource usage. It is possible to estimate the resource usage corresponding to the free capacity with an accuracy close to the target.
  • By analyzing the dependency relationship between resources in this way it is possible to estimate a load close to the target resource usage, and the accuracy of the estimated load is improved.
  • NUM_CAP NUM_BSE ⁇ ((P_CAP ⁇ P_DEP) / P_AVM) (9)
  • the load generation unit 107 assumes that the resource itself is a CPU, memory, NWI / O, and HDD I / O. In addition, other dependent resources can be observed. Furthermore, if it is possible to adjust the load of those resources, the number of resources is not limited to the above-described resources, and the number of resources may be repeated. Then, the performance measurement virtual server 100 can perform dependency analysis between resources, adjust the processing capacity index, generate a load, and estimate the target processing capacity index. According to this configuration, the present invention can be applied to various resources.
  • the load generation unit 107 assumes that the resource itself is a CPU, memory, NWI / O, and HDD I / O. In addition, other dependent resources can be observed. Furthermore, if it is possible to adjust the load of those resources, the number of resources is not limited to the above-described resources, and the number of resources may be repeated. Then, the performance measurement virtual server 100 can perform dependency analysis between resources, adjust the processing capacity index, generate a load, and estimate the target processing capacity index. According to this configuration, the present invention can be applied to various resources.
  • the load generation unit 107 assumes that the resource itself is a CPU, memory, NWI / O, and HDD I / O.
  • other dependent resources can be observed.
  • the number of resources is not limited to the above-described resources, and the number of resources may be repeated.
  • the performance measurement virtual server 300 can perform dependency analysis between resources, adjust the processing capacity index, generate a load, and estimate the processing capacity index of the target load. According to this configuration, the present invention can be applied to various resources.

Abstract

 性能計測用仮想サーバ(100)は、物理サーバおよび物理サーバ上で稼働する仮想サーバの複数のリソースの使用量を取得する取得部(52)と、計測対象リソースに負荷を発生させる負荷発生部(54)と、リソースに負荷をかけることで、計測対象リソースが依存しているリソースを求め、計測対象リソースが依存しているリソースの数に基づいて、依存度数を算出する依存度数算出部(56)と、算出された依存度数が大きい順にリソースに順位付けする順位付け部(58)と、順位付けされた順に複数のリソースから計測対象リソースを選択し、負荷発生部(54)により順次負荷を発生させながら、計測対象リソースのリソース使用量の処理能力指標を調整する調整部(60)と、を備える。

Description

制御装置、管理装置、制御装置のデータ処理方法、およびプログラム
 本発明は、制御装置、管理装置、制御装置のデータ処理方法、およびプログラムに関し、特に、仮想サーバの性能計測を行うための負荷見積もりを行う制御装置、管理装置、制御装置のデータ処理方法、およびプログラムに関する。
 この種の計算機システムの一例が特許文献1(特開2009-123174号公報)に記載されている。これは仮想化環境におけるI/O(Input/Output)エミュレーションに必要なCPU(Central Processing Unit)負荷をディスク負荷またはネットワーク負荷から換算し、CPU負荷の見積もりの精度を向上させることを目的としている。図18はシステムの構成を示すブロック図であり、これを参照すると、サーバ900、901、および902は、サーバ統合の対象となる非仮想化サーバである。コンピュータ930は、サイジング機能が動作する端末である。サーバ900、901、および902とコンピュータ930は、LAN(Local Area Network)905で接続されている。
 サーバ900、901、および902の各々は、実サーバの一例であり、コンピュータ930は、仮想マシンサーバサイジング装置の一例である。サーバ900、901、および902は、負荷測定部910、911、および912をそれぞれ備える。また、サーバ900、901、および902は、ハードウェア資源として、少なくとも1つのCPU(Central Processing Unit)を有するとともに、HDD(Hard Disk Drive)やNIC(Network Interface Card)を有する。負荷測定部910、911、および912は、それぞれ、サーバ900、901、および902の各々のシステム負荷を測定し、それを測定情報として出力する。システム負荷とは、たとえば、CPU負荷、ディスクやネットワークのI/O(Input/Output)負荷のことである。
 コンピュータ930は、性能設計部940、構成管理部941、入力装置951(たとえば、キーボードやマウス)、記憶装置952(たとえば、HDDやメモリ)、処理装置953(たとえば、CPU)、出力装置954(たとえば、表示装置やプリンタ装置)を有する。なお、これらの内部で構成される部分に関しては説明を省略する。
 このような構成を有する従来の計算機システムは次のように動作する。サーバ900、901、および902を仮想サーバとして動作させるサーバX(不図示)のCPU負荷を見積もる場合、CPU性能換算部923はサーバ900、901、および902のCPU負荷の測定値を得る。負荷変換部920はサーバ900、901、および902のディスク負荷またはネットワーク負荷から、ディスクまたはネットワークのI/Oに起因するサーバXのCPU負荷の見積値を得る。CPUオーバーヘッド算出部924は仮想化に起因するCPUオーバーヘッドを示す係数を得る。負荷見積部925は上記測定値と上記見積値と上記係数を用いてサーバXのCPU負荷を見積もる。
 特徴は仮想サーバ上で各々の資源(ディスク、ネットワーク)利用時のI/O分のCPUのオーバーヘッドを計測し、さらに物理サーバ上でのアプリケーションが利用する各々の資源利用頻度を計測することである。ここでは、資源利用頻度に対応するCPUのオーバーヘッドを算出し、物理サーバ上から仮想サーバ上でアプリケーション処理させた場合を想定して上記のCPUのオーバーヘッドを足し込んでCPU資源の利用頻度を見積もり、物理サーバの上のアプリケーションの処理を仮想サーバ上で実行させたときの資源利用頻度を計測する。
 今後は、データセンター内で多岐に渡るハードウェアおよびソフトウェアを搭載した性能の異なる物理サーバが存在することとなる。物理サーバのリソースを効率的に利用するために、リソースの仮想化(仮想CPU、仮想ストレージ、仮想ネットワーク)を支援する技術が増え、仮想サーバ上でSaaS(Software as a Service)等のサービスを提供していくと考えられる。この物理サーバ上で構築された仮想サーバは物理サーバ間で移動することが可能で、移動先ではその物理サーバのリソースを利用することができる。物理サーバ上で効率良くリソースを利用する手段として特許文献1が提案されている。
特開2009-123174号公報
 上述した計算機システムにおいてはCPU(Central Processing Unit)以外のリソースとの依存関係が考慮されていなかったため、目標の負荷を精度よく見積もることが難しいという問題点があった。
 本発明の目的は、上述した課題である仮想サーバの性能計測を行うための負荷見積もりを精度よく行うことができる制御装置、そのデータ処理方法、およびそのプログラム、ならびに、管理装置を提供することにある。
 本発明の制御装置は、
 物理サーバおよび前記物理サーバ上で稼働する仮想サーバの複数のリソースのリソース使用量を取得する取得手段と、
 計測対象リソースに負荷を発生させる負荷発生手段と、
 前記計測対象リソースに前記負荷をかけることで、前記計測対象リソースが依存しているリソースを求め、前記計測対象リソースが依存している前記リソースの数に基づいて、前記計測対象リソースの依存度数を算出する依存度数算出手段と、
 複数の前記リソースについて前記計測対象リソースとしてそれぞれ算出された前記依存度数が大きい順に前記リソースに順位付けする順位付け手段と、
 前記順位付け手段により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択し、前記負荷発生手段により順次負荷を発生させながら、前記計測対象リソースのリソース使用量の処理能力指標を調整する調整手段と、を備える。
 本発明の管理装置は、上記制御装置の前記性能計測用仮想サーバを、複数の移動先候補となる前記物理サーバ上で順次稼働させて、検証対象の物理サーバとして、前記見積手段により得られた前記処理能力指標を提示する提示手段を備える。
 本発明のプログラムは、コンピュータに、
 物理サーバおよび前記物理サーバ上で稼働する仮想サーバの複数のリソースのリソース使用量を取得する手順と、
 計測対象リソースに負荷を発生させる手順と、
 前記計測対象リソースに前記負荷をかけることで、前記計測対象リソースが依存している前記リソースを求め、前記計測対象リソースが依存している前記リソースの数に基づいて、前記計測対象リソースの依存度数を算出する手順と、
 複数の前記リソースについて前記計測対象リソースとしてそれぞれ算出された前記依存度数が大きい順に前記リソースに順位付けする手順と、
 順位付けされた順に複数の前記リソースから前記計測対象リソースを選択し、順次負荷を発生させながら、前記計測対象リソースのリソース使用量の処理能力指標を調整する手順と、を実行させる。
 本発明の制御装置のデータ処理方法は、
 物理サーバおよび前記物理サーバ上で稼働する仮想サーバの複数のリソースの負荷を計測する制御装置のデータ処理方法であって、前記制御装置が、
 前記物理サーバおよび前記物理サーバ上で稼働する前記仮想サーバの複数の前記リソースのリソース使用量を取得し、
 計測対象リソースに負荷を発生させ、
 前記計測対象リソースに前記負荷をかけることで、前記計測対象リソースが依存しているリソースを求め、前記計測対象リソースが依存している前記リソースの数に基づいて、前記計測対象リソースの依存度数を算出し、
 複数の前記リソースについて前記計測対象リソースとしてそれぞれ算出された前記依存度数が大きい順に前記リソースに順位付けし、
 順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記計測対象リソースのリソース使用量の処理能力指標を調整する。
 なお、以上の構成要素の任意の組合せ、本発明の表現を方法、装置、システム、記録媒体、コンピュータプログラムなどの間で変換したものもまた、本発明の態様として有効である。
 また、本発明の各種の構成要素は、必ずしも個々に独立した存在である必要はなく、複数の構成要素が一個の部材として形成されていること、一つの構成要素が複数の部材で形成されていること、ある構成要素が他の構成要素の一部であること、ある構成要素の一部と他の構成要素の一部とが重複していること、等でもよい。
 また、本発明のデータ処理方法およびコンピュータプログラムには複数の手順を順番に記載してあるが、その記載の順番は複数の手順を実行する順番を限定するものではない。このため、本発明のデータ処理方法およびコンピュータプログラムを実施するときには、その複数の手順の順番は内容的に支障しない範囲で変更することができる。
 さらに、本発明のデータ処理方法およびコンピュータプログラムの複数の手順は個々に相違するタイミングで実行されることに限定されない。このため、ある手順の実行中に他の手順が発生すること、ある手順の実行タイミングと他の手順の実行タイミングとの一部ないし全部が重複していること、等でもよい。
 本発明によれば、仮想サーバの性能計測を行うための負荷見積もりを精度よく行うことができる制御装置、管理装置、制御装置のデータ処理方法、およびプログラムが提供される。
 上述した目的、およびその他の目的、特徴および利点は、以下に述べる好適な実施の形態、およびそれに付随する以下の図面によってさらに明らかになる。
本発明の実施の形態に係る情報処理システムの構成を示す概略ブロック図である。 本実施形態の性能計測用仮想サーバの構成を示す概略機能ブロック図である。 本実施形態の性能計測用仮想サーバの構成を示す詳細機能ブロック図である。 本実施形態の管理サーバにおける負荷調整フェーズの処理手順の一例を示すフローチャートである。 本実施形態の性能計測用仮想サーバにおける負荷調整時の性能計測処理の手順の一例を示すフローチャートである。 本実施形態の性能計測用仮想サーバにおける負荷調整時の性能計測処理の手順の一例を示すフローチャートである。 本実施形態の管理サーバにおける負荷再現フェーズの処理手順の一例を示すフローチャートである。 本実施形態の性能計測用仮想サーバにおける負荷再現時の性能計測処理の手順の一例を示すフローチャートである。 本発明の実施の形態に係る情報処理システムの構成を示す概略ブロック図である。 本実施形態の性能計測用仮想サーバの構成を示す機能ブロック図である。 本実施形態の性能計測用仮想サーバの動作の一例を示すフローチャートである。 本実施形態の性能計測用仮想サーバにおける性能計測処理の負荷見積処理の手順の一例を示すフローチャートである。 本実施形態の情報処理システムの設定情報の構造の一例を示す図である。 本発明の実施の形態に係る情報処理システムにおける処理能力指標とリソース使用量の関係を説明するための図である。 本発明の実施の形態に係る情報処理システムにおける負荷情報と依存情報の一例を示す図である。 本実施形態に係る依存関係を示すグラフおよび目標負荷から依存した負荷を差し引いたリソース使用量を説明するための図である。 本実施形態に係る依存関係を示すグラフおよび目標負荷から依存した負荷を差し引いたリソース使用量を説明するための図である。 特許文献に記載の計算機システムの構成を示すブロック図である。
(第1の実施の形態)
 以下、本発明の実施の形態について、図面を用いて説明する。尚、すべての図面において、同様な構成要素には同様の符号を付し、適宜説明を省略する。
 図1は、本発明の実施の形態に係る情報処理システム1の構成を示す概略ブロック図である。
 本発明の実施の形態に係る情報処理システム1では、一台の物理的なサーバコンピュータ(以下、「物理サーバ」と呼ぶ)を複数台の仮想的なコンピュータ(以下、「仮想サーバ」と呼ぶ)に分割し、各仮想サーバに異なるOS(Operating System)やアプリケーションを動作させるサーバ仮想化技術を用いて、複数の物理サーバの資源を効率よく利用する。
 たとえば、データセンターなどでは、異なる性能を有する多数のコンピュータが存在する。本発明は、それらのコンピュータを用いて、ユーザの需要に応じた性能を有する処理を実行できるように、リソースを調整し、最適なサービスをユーザに提供するプロビジョニング技術に関する。仮想サーバでは、このようにリソースをユーザの需要に応じて柔軟に配分できるという利点がある一方で、仮想化にかかるオーバーヘッドの分、処理性能が低下する。
 本実施形態の情報処理システム1では、あるリソースの負荷発生時に、他のリソース間でもそれに相当する負荷が発生するリソース間の依存関係の特性を分析する。そして、その特性による負荷の発生を吸収して目標の負荷を発生する。そして、物理サーバ上にて負荷を発生する仮想サーバ上で、負荷発生により発生するリソース間のオーバーヘッドの影響を除外した負荷見積もりを行うことができる。
 本実施形態の情報処理システム1において、たとえば、複数のサーバやネットワーク、アプリケーション、ストレージなどのリソースを仮想化する。そして、ユーザから要求があった場合や、障害時などに、必要な分だけリソースを動的に別のリソースに割り当てられるようにする。本発明は、このとき、リソースの移動前後の仮想サーバの処理性能をできる限り正確に事前に見積ることで、移動時に負荷が大きく変動したり、高負荷になることを避けることができる。そして、本発明は、システムがユーザのニーズに合った性能を有するようにするものである。
 また、本発明は、監視ミドルウェア製品に実装し、物理サーバ上で稼働する仮想サーバの運用を効率的に行うデータセンター事業に適用可能である。
 図1に示すように、本実施形態の情報処理システム1は、管理サーバ4と、プールサーバ5と、退避サーバ6と、管理エージェント70を有する移動元サーバ7と、管理エージェント90をそれぞれ有する複数の移動先サーバ9(SV21、・・・、SV2m、mは自然数)と、を備える。これらは互いに通信網3を介して接続される。通信網3は、特に限定されないが、サーバ同士が互いに通信できる構成とし、たとえば、LAN(Local Area Network)、WAN(Wide Area Network)、携帯通信網、固定電話通信網、インターネット、およびこれらの組み合わせとすることができる。
 プールサーバ5、移動元サーバ7、移動先サーバ9、および退避サーバ6は、それぞれ仮想サーバを配置することが可能で、さらにお互いのサーバ間を移動できる機能が提供されている物理サーバである。各物理サーバは、たとえば、図示しないCPUやメモリ、ハードディスク、および通信装置を備え、キーボードやマウス等の入力装置やディスプレイやプリンタ等の出力装置と接続されるサーバコンピュータやパーソナルコンピュータ、またはそれらに相当する装置により実現することができる。そして、CPUが、ハードディスクに記憶されるプログラムをメモリに読み出して実行することにより、上記各ユニットの各機能を実現することができる。なお、以下の各図において、本発明の本質に関わらない部分の構成については省略してあり、図示されていない。
 なお、情報処理システム1の各構成要素は、任意のコンピュータのCPU、メモリ、メモリにロードされた本図の構成要素を実現するプログラム、そのプログラムを格納するハードディスクなどの記憶ユニット、ネットワーク接続用インタフェースを中心にハードウェアとソフトウェアの任意の組合せによって実現される。そして、その実現方法、装置にはいろいろな変形例があることは、当業者には理解されるところである。以下説明する各図は、ハードウェア単位の構成ではなく、機能単位のブロックを示している。
 本実施形態では、仮想サーバは2種類存在し、一方は業務用の業務用仮想サーバ76(VM11、・・・、VM1i、iは自然数)および業務用仮想サーバ96(移動先サーバSV21の場合、VM21、・・・、VM2j、jは自然数)、ならびに、他方は本発明の性能計測処理を行う性能計測用仮想サーバ100(VM31、・・・、VM3n、nは自然数)である。本実施形態では、移動元サーバ7は、少なくとも1台存在することとするが、これに限定されない。また、移動先サーバ9は、存在しない場合もある。たとえば、移動先サーバをこれから新たに導入するために、本実施形態の性能計測処理を行う場合などは、移動先サーバ9は存在しない。
 業務用仮想サーバ76および業務用仮想サーバ96は、たとえば、ウェブ、メール、バックアップ等の処理を行うアプリケーションを搭載し、それらの処理を行っていることを想定する。プールサーバ5の上で、本実施形態の性能計測用仮想サーバ100が稼動する。ここで、図1に示す性能計測用仮想サーバ100(VM31~VM3n)のように、プールサーバ5上で複数(n個)稼動してもよい。
 移動元サーバ7の管理エージェント70は、負荷情報収集部72および負荷情報通知部74を有し、これらの機能を開始または終了する指示をする役割を持つ。移動元サーバ7上で、業務用仮想サーバ76が稼動する。ここで、業務用仮想サーバ76は、移動元サーバ7上で複数(i個)稼動してもよい(図中、VM11~VM1i)。負荷情報収集部72は、移動元サーバ7と移動元サーバ7上で稼働する仮想サーバのリソース使用量を収集する。そして、負荷情報通知部74は、負荷情報収集部72が収集したリソース使用量を定期的に管理サーバ4に通信網3を介して送信する。
 移動先サーバ9の管理エージェント90は、負荷情報収集部92および負荷情報通知部94を有し、これらの機能を開始または終了する指示をする役割を持つ。移動先サーバ9上で、業務用仮想サーバ96が稼動する。ここで、業務用仮想サーバ96は、各移動先サーバ9上で複数(移動先サーバSV21の場合、j個、他の移動先サーバSV2m(mは、2、3、4、・・・)では、たとえば、x、y、z、・・・個ずつ)ずつ稼動してもよい(図中、移動先サーバSV21の仮想サーバVM21~VM2j、他の移動先サーバSV2mの仮想サーバは省略)。負荷情報収集部92は、移動先サーバ9と移動先サーバ9上で稼働する仮想サーバのリソース使用量を収集する。そして、負荷情報通知部94は、負荷情報収集部92が収集したリソース使用量を定期的に管理サーバ4に通信網3を介して送信する。
 退避サーバ6は、後述する本発明の性能計測処理を行う際、移動元サーバ7上で稼働している業務用仮想サーバ76を一時的に退避させる物理サーバである。これにより、本実施形態の情報処理システム1は、実際の業務用サービスを停止することなく、本発明の性能計測処理を実行することができることとなる。なお、退避サーバ6には、業務用仮想サーバ76が退避されてもリソース不足にならない程度の充分なリソースが存在することを前提とする。
 管理サーバ4は、性能情報取得指示部21と、負荷調整および再現指示部22と、仮想サーバ起動部24と、仮想サーバ移動部25と、情報送信部26と、情報受信部27と、情報比較部28と、仮想サーバイメージ記憶部29と、性能情報記憶部20と、を備えている。
 なお、本実施形態の情報処理システム1は、負荷調整フェーズと負荷再現フェーズを含む。本実施形態の情報処理システム1は、はじめに、負荷調整フェーズにおいて、移動元サーバ7上で、疑似的に負荷を発生させて、性能計測を行う。その後、本実施形態の情報処理システム1は、負荷再現フェーズにおいて、負荷調整フェーズで得られた処理能力指標に基づいて、移動先サーバ9上で、負荷を発生させ、リソース使用量を取得する。
 性能情報記憶部20は、負荷調整フェーズにて、移動元サーバ7上で稼働する性能計測用仮想サーバ100から受信した各リソースの処理能力指標を記憶する。さらに、性能情報記憶部20は、負荷再現フェーズにて、移動先サーバ9上で稼働する性能計測用仮想サーバ100から受信した移動先サーバ9上で消費したリソース使用量を、たとえば、時系列に記憶する。
 性能情報取得指示部21は、負荷調整および再現指示部22に対して負荷調整指示または負荷再現指示を行う。本実施形態では、運用者が、情報処理システム1の管理サーバ4に対して、たとえば、操作部(不図示)等を利用して、負荷調整または負荷再現の指示を行うことができる。性能情報取得指示部21は、指示に従い、負荷調整および再現指示部22に指示を行う。このとき、性能情報取得指示部21は、どの移動元サーバ7を計測対象とするのかの指定も運用者に指定させて受け付ける。
 また、運用者が予め負荷調整または負荷再現実施のスケジュールを作成して管理サーバ4に登録しておき、性能情報取得指示部21は、スケジュールに従って自動的に指示を出すようにしてもよい。このようにすれば、システムが実際には稼働していない夜中などに検証を行うことができる。これにより、万が一、障害を生じてしまった場合でも、その被害を最小限にとどめることができる。
 さらに、負荷調整フェーズにおいて、負荷調整および再現指示部22は、計測対象に指定された移動元サーバ7上で稼働している業務用仮想サーバ76の代わりにプールサーバ5上の性能計測用仮想サーバ100を稼働させるために、移動元サーバ7に性能計測用仮想サーバ100を移動する。そして、移動元サーバ7上で稼働している業務用仮想サーバ76を退避サーバ6に移動するよう仮想サーバ移動部25に指示する。また、処理が終了したときには、元に戻す指示も行う。
 さらに、負荷調整および再現指示部22は、移動元サーバ7に移動した性能計測用仮想サーバ100に対して、情報送信部26を利用して、性能情報計測指示を、通信網3を介して送信する。
 この性能情報計測指示は、図13に示される設定情報130と、性能計測用仮想サーバ100の各リソース量の情報が含まれる。設定情報130は、運用者により設定することができ、設定画面などから操作部を利用して設定したパラメータを受け付けてもよいし、設定ファイルの形式で受け付けてもよい。
 図13に示すように、設定情報130には、仮想サーバごとの情報が含まれ、たとえば、初回処理能力指標(数値)、初回調整振れ幅(%)、再現振れ幅(%)、読み飛ばし回数(回)、継続回数(回)、許容範囲(%)、基準となるリソース使用量(%または数値)、最大調整回数(回)、マルチプロセッサ対応、CPUリソースフラグ、メモリリソースフラグ、NW(ネットワーク)リソースフラグ、HDDリソースフラグを含む。
 初回処理能力指標(数値)は、リソースごとに設定され、はじめに性能計測プログラムを使用して負荷を発生させる場合、この初回処理能力指標を用いる。初回調整振れ幅(%)は、リソースごとに設定されてもよく、はじめに性能計測プログラムを使用して負荷を発生させたときの負荷の揺らぎの範囲である。
 再現振れ幅(%)は、リソースごとに設定されてもよく、負荷再現時に性能計測プログラムを使用して負荷を発生させたときの負荷の揺らぎの範囲である。読み飛ばし回数(回)は、リソースごとに設定されてもよく、負荷が上がりきっていない場合を考慮し、物理サーバから受信するリソース負荷情報を読みとばす回数である。継続回数(回)は、リソースごとに設定されてもよく、基準になる処理能力指標分の負荷を出力させて計測した結果、許容範囲に入った回数である。
 許容範囲(%)は、リソースごとに設定されてもよく、基準になる処理能力指標分の負荷を出力させて計測した結果、基準になるリソース使用量からの範囲である。
 基準となるリソース使用量(%または数値)は、リソースごとに設定されてもよく、他の仮想サーバに影響を与えない程度の小さい負荷で、基準となるリソース使用量である。最大調整回数(回)は、リソースごとに設定されてもよく、基準になるリソース使用量にするための調整回数である。
 マルチプロセッサ対応は、マルチプロセッサの場合、計測サーバ環境の最大CPUコア数を示す。
 CPUリソースフラグ、メモリリソースフラグ、NWリソースフラグ、HDDリソースフラグは、それぞれCPU、メモリ、NW、およびHDDリソースの計測を実施するか否かを示す。CPUとメモリリソースでは、計測を実施するか否かを示し、NWおよびHDDリソースでは、入力または出力か、あるいは、全てかを示す。
 これらの設定は、後述する処理で使用される。
 図1に戻り、一方、負荷再現フェーズにて、負荷調整および再現指示部22は、計測対象に指定された移動元サーバ7上に、プールサーバ5上の性能計測用仮想サーバ100を移動するよう仮想サーバ移動部25に指示する。
 そして、負荷調整および再現指示部22は、性能計測用仮想サーバ100対して、情報送信部26を利用して負荷再現指示を、通信網3を介して送信する。負荷再現指示は、後述するように、負荷調整フェーズにて性能計測用仮想サーバ100が見積もった移動元サーバ7上の業務用仮想サーバ76の処理能力指標を含む。
 仮想サーバイメージ記憶部29は、本情報処理システム1で稼働している仮想サーバのイメージを記憶する。仮想サーバ起動部24は、仮想サーバイメージ記憶部29に登録されている各仮想サーバのイメージを起動させるサーバにコピーし、仮想サーバを起動するように指示する。たとえば、図1の性能計測用の性能計測用仮想サーバ100(VM31~VM31n)のように複数起動してもよい。
 仮想サーバ移動部25は、上述したように、負荷調整および再現指示部22の指示に従い、各仮想サーバを移動する。
 情報送信部26は、通信網3を介して、移動元サーバ7上で稼働している性能計測用仮想サーバ100や、移動先サーバ9上で稼働している性能計測用仮想サーバ100に、指示や情報を送信する。
 情報受信部27は、通信網3を介して、移動元サーバ7上で稼働している性能計測用仮想サーバ100や、移動先サーバ9上で稼働している性能計測用仮想サーバ100から、情報を受信する。
 情報比較部28は、負荷再現フェーズにて、性能情報記憶部20にある移動先サーバ9上で消費したリソース使用量を取得する。そして、情報比較部28は、さらに複数の移動先サーバ9(SV21~2m)でも行った場合に、リソース使用量の大きさを比較できるように表示部(不図示)などに提示する。
 本実施形態において、管理サーバ4は、性能計測用仮想サーバ100を、複数の移動先候補となる物理サーバ(移動先サーバ9)上で順次稼働させる。そして、管理サーバ4は、検証対象の物理サーバとして、見積部(負荷調整部111)により得られた処理能力指標を提示する提示部(不図示)を備えることができる。
 上述した管理サーバ4の各ユニットの機能は、コンピュータプログラムをコンピュータに実行されることで実現する。このコンピュータプログラムは、コンピュータで読み取り可能な記録媒体に記録されてもよい。記録媒体は特に限定されず、様々に形態のものが考えられる。また、プログラムは、記録媒体からコンピュータのメモリにロードされてもよいし、ネットワークを通じてコンピュータにダウンロードされ、メモリにロードされてもよい。
 図2は、本実施形態の性能計測用仮想サーバ100の構成を示す機能ブロック図である。
 本実施形態の制御装置(性能計測用仮想サーバ100)は、物理サーバ(移動元サーバ7または移動先サーバ9)および物理サーバ上で稼働する仮想サーバ(業務用仮想サーバ76または業務用仮想サーバ96)の複数のリソース(不図示)のリソース使用量を取得する取得部52と、計測対象リソースに負荷を発生させる負荷発生部54と、計測対象リソースに負荷をかけることで、計測対象リソースが依存しているリソースを求め、計測対象リソースが依存しているリソースの数に基づいて、計測対象リソースの依存度数を算出する依存度数算出部56と、複数のリソースについて計測対象リソースとしてそれぞれ算出された依存度数が大きい順にリソースに順位付けする順位付け部58と、順位付け部58により順位付けされた順に複数のリソースから計測対象リソースを選択し、負荷発生部54により順次負荷を発生させながら、計測対象リソースのリソース使用量の処理能力指標を調整する調整部60と、を備える。
 性能計測用仮想サーバ100は、さらに、インタフェース(図中、「I/F」と示す)62を含み、インタフェース62は、通信網3を介して、管理サーバ4、退避サーバ6、移動元サーバ7、および移動先サーバ9に接続し、通信を行う。本発明の制御装置とは、物理サーバ上で稼働可能な性能計測用仮想サーバ100を指している。性能計測用仮想サーバ100をいずれの物理サーバ上で移動させるかは、管理サーバ4からの指示に従っている。つまり、本発明の制御装置は、性能計測用仮想サーバ100をいずれの物理サーバ上で稼働させるか決まっていないため、いずれのコンピュータで実現されるかは限定されない。
 より具体的には、本実施形態の性能計測用仮想サーバ100は、図3に示すように、情報送信部101と、情報受信部103と、負荷判定部105、負荷発生部107、設定ファイル読み込み部109と、負荷調整部111と、依存関係分析部113と、計測指示部115と、負荷情報記憶部117と、性能情報記憶部119と、受信情報記憶部121と、設定情報記憶部123と、中間情報記憶部125と、依存情報記憶部127と、を備える。図では、性能計測用仮想サーバVM31について示しているが、他の性能計測用仮想サーバVM3nも同様の構成となる。
 本実施形態の制御装置(性能計測用仮想サーバ100)は、さらに、負荷発生部107により負荷をかけている間に情報受信部103が取得したリソース使用量に基づいて、計測対象リソース以外のリソースのリソース使用量に増減があるかどうかを検出する検出部(負荷判定部105)と、計測対象リソース以外のリソースのリソース使用量に増減が検出された場合、当該リソースは計測対象リソースが依存しているリソースであると判別する判別部(負荷判定部105)と、を備え、依存度数算出部(依存関係分析部113)は、負荷判定部105により計測対象リソースが依存していると判別されたリソースの数を計数して依存度数を算出する。
 また、本実施形態の制御装置(性能計測用仮想サーバ100)は、物理サーバ(図1の移動元サーバ7)上で稼働する少なくとも1つの仮想サーバ(図1の業務用仮想サーバ76)の代わりに、性能計測用仮想サーバ100の各ユニットを実現させるための性能計測用仮想サーバ100を移動元となる移動元サーバ7(図1)上で稼働させ、負荷発生部107が、移動元サーバ7上で稼働する少なくとも1つの業務用仮想サーバ76の代わりに、移動元サーバ7上で負荷を発生させ、情報受信部103が、移動元サーバ7と、移動元サーバ7上で稼働させた性能計測用仮想サーバ100の複数のリソースのリソース使用量を定期的に取得し、負荷調整部111が、処理能力指標を調整する。
 さらに、本実施形態の制御装置(性能計測用仮想サーバ100)において、負荷調整部111が、情報受信部103が取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷発生部107が負荷をかけたリソースのリソース使用量で、かつ、負荷発生部107が今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる仮想サーバの計測対象リソースのリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整し、さらに、制御装置(性能計測用仮想サーバ100)は、負荷調整部111により調整された処理能力指標に基づいて、負荷発生部107が、依存関係分析部113により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、情報受信部103が取得したリソース使用量から目標となるリソース使用量の絶対値が許容範囲内に入っているか否かを判定する判定部(負荷判定部105)と、負荷判定部105により許容範囲内に入っていると判定されたとき、情報受信部103が取得したリソース使用量から目標となるリソース使用量に対応する処理能力指標を見積もる見積部(負荷調整部111)と、を備える。
 詳細には、情報送信部101は、負荷調整フェーズにて、性能計測処理で得られた処理能力指標を、通信網3を介して管理サーバ4に情報を送信する。また、情報送信部101は、負荷再現フェーズにて、最新のリソース使用量を、通信網3を介して管理サーバ4に情報を送信する。
 情報受信部103は、管理サーバ4、移動元サーバ7、または移動先サーバ9から、通信網3を介して指示や情報を受信し、所定の記憶部に記憶する。たとえば、情報受信部103は、管理サーバ4の負荷調整および再現指示部22から性能情報計測指示を受信し、受信情報記憶部121に記憶する。そして、情報受信部103は、負荷を疑似的に発生させた移動元サーバ7上の負荷情報通知部74から定期的にリソース使用量を受信し、負荷情報記憶部117に記憶する。また、情報受信部103は、負荷調整および再現指示部22から負荷再現指示を受信し、受信情報記憶部121に記憶する。そして、情報受信部103は、負荷を再現させた移動先サーバ9上の負荷情報通知部94からリソース使用量を定期的に受信し、負荷情報記憶部117に記憶する。情報受信部103は、図2の取得部52に相当する。
 受信情報記憶部121は、情報受信部103が通信網3を介して、管理サーバ4、移動元サーバ7または移動先サーバ9から受信した指示や情報を記憶する。
 負荷情報記憶部117は、負荷調整フェーズにて、情報受信部103が移動元サーバ7の負荷情報通知部74から定期的に受信したリソース毎のリソース使用量を記憶する。そして、さらに、負荷情報記憶部117は、負荷再現フェーズにて、情報受信部103が移動先サーバ9の負荷情報通知部94から定期的に受信したリソース毎のリソース使用量を記憶する。
 負荷判定部105は、負荷調整フェーズにて負荷情報記憶部117を参照し、移動元サーバ7や移動先サーバ9のリソース使用量に基づいて、各リソース使用量から依存関係を判定する。そして、さらに、負荷判定部105は、計測対象リソースが依存しているリソースの数に基づいて、各リソースについて計測対象リソースとしての依存度数をそれぞれ算出する。負荷判定部105は、図2の依存度数算出部56に相当する。算出された依存度数は、リソース毎に、依存情報記憶部127に記憶される。
 負荷判定部105は、計測対象リソース以外のリソースのリソース使用量に増減があるかどうかを検出する。そして、増減が検出されたとき、負荷判定部105は、そのリソースは計測対象リソースが依存していると判別する。なお、本実施形態では、負荷判定部105は、各サーバに設けられた管理エージェントの負荷情報収集部により取得したリソース使用量の増減に基づいて依存関係を判別したが、これに限定されない。たとえば、他の監視ツールによりサーバのリソース使用量の増減が分かる指標を用いれば、依存関係を判別することができる。
 また、負荷判定部105は、負荷再現フェーズにて、負荷情報記憶部117を参照し、移動先サーバ9のリソース使用量に基づいて、最終のリソース使用量を読み出す。そして、負荷判定部105は、読み出した最終のリソース使用量を、情報送信部101を利用して、管理サーバ4に通信網3を介して送信する。
 設定ファイル読み込み部109は、管理サーバ4から受信して受信情報記憶部121に記憶されている図13の設定情報130から各パラメータを読み出し、設定情報記憶部123に記憶する。
 設定情報記憶部123には、設定ファイル読み込み部109によって受信情報記憶部121から読み出された設定情報130のパラメータが記憶される。
 負荷調整部111は、後述する手順に従い、負荷調整フェーズにて、処理能力指標を調整する。この処理能力指標は、負荷を発生された後に更新されたリソースごとの処理能力指標と、定期的に計測された各リソースのリソース使用量に基づいて、業務用仮想サーバ76のリソース使用量になるように、調整される。負荷調整部111は、図2の調整部60に相当する。
 性能情報記憶部119は、負荷調整部111によって調整された処理能力指標をリソースごとに記憶する。
 計測指示部115は、リソース単位で負荷発生部107に対してリソースの負荷を発生させるように指示する。負荷のかけ方の詳細については、後述する。
 負荷発生部107は、移動元サーバ7上の性能計測用仮想サーバ100や移動先サーバ9上の性能計測用仮想サーバ100の計測対象リソースに疑似的に負荷を発生させる。図2の負荷発生部54に相当する。
 依存関係分析部113は、依存情報記憶部127に存在するリソースごとの性能計測結果に基づいて、リソースに依存する順番付け(降順)を行う。依存関係分析部113は、図2の順位付け部58に相当する。
 中間情報記憶部125は、負荷調整フェーズにて、計測対象リソース以外のリソース使用量を記憶する。
 依存情報記憶部127は、負荷判定部105によって求められた各リソースの依存度数を記憶する。
 上述した性能計測用仮想サーバ100の各ユニットの機能は、コンピュータプログラムをコンピュータに実行されることで実現する。
 本実施形態のコンピュータプログラムは、性能計測用仮想サーバ100を実現させるためのコンピュータに、物理サーバ(図1の移動元サーバ7)および移動元サーバ7(図1)上で稼働する仮想サーバ(図1の業務用仮想サーバ76)の複数のリソースのリソース使用量を取得する手順と、計測対象リソースに疑似的に負荷を発生させる手順と、計測対象リソースに負荷をかけることで、計測対象リソースが依存しているリソースを求め、計測対象リソースが依存しているリソースの数に基づいて、計測対象リソースの依存度数を算出する手順と、複数のリソースについて計測対象リソースとしてそれぞれ算出された依存度数が大きい順にリソースに順位付けする手順と、順位付けされた順に複数のリソースから計測対象リソースを選択し、順次負荷を発生させながら、計測対象リソースのリソース使用量の処理能力指標を調整する手順と、を実行させるように記述されている。以下、このプログラムを性能計測プログラムと呼ぶ。
 本実施形態の性能計測プログラムは、物理サーバ(図1の移動元サーバ7)上で稼働する少なくとも1つの仮想サーバ(図1の業務用仮想サーバ76)の代わりに、プログラムを含む性能計測用仮想サーバ100を移動元となる移動元サーバ7(図1)上で稼働させる手順と、移動元となる移動元サーバ7(図1)上で稼働する少なくとも1つの業務用仮想サーバ76の代わりに、移動元サーバ7上で負荷を発生させる手順と、移動元サーバ7と、移動元サーバ7上で稼働させた性能計測用仮想サーバ100の複数のリソースのリソース使用量を定期的に取得する手順と、処理能力指標を調整する手順と、をさらにコンピュータに実行させるように記述されている。
 本実施形態の性能計測プログラムは、取得する手順で取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷を発生する手順で負荷をかけたリソースのリソース使用量で、かつ、負荷を発生する手順で今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる仮想サーバの計測対象リソースのリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整する手順と、負荷を発生する手順において、調整する手順により調整された処理能力指標に基づいて、順位付けする手順により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、取得する手順で取得したリソース使用量から目標となるリソース使用量の絶対値が許容範囲内に入っているか否かを判定する手順と、判定する手順により許容範囲内に入っていると判定されたとき、取得する手順で取得したリソース使用量から目標となるリソース使用量に対応する処理能力指標を見積もる手順と、をさらにコンピュータに実行させるように記述されている。
 本実施形態のコンピュータプログラムは、コンピュータで読み取り可能な記憶媒体に記録されてもよい。記録媒体は特に限定されず、様々に形態のものが考えられる。また、プログラムは、記録媒体からコンピュータのメモリにロードされてもよいし、ネットワークを通じてコンピュータにダウンロードされ、メモリにロードされてもよい。
 このように構成された本実施形態の情報処理システム1の動作について、以下に説明する。
 図4~図8は、本実施形態の情報処理システム1の動作の一例を示すフローチャートである。
 上述したように、本実施形態の情報処理システム1は、負荷調整フェーズと負荷再現フェーズを含む。本実施形態の情報処理システム1は、はじめに、負荷調整フェーズにおいて、移動元サーバ7上で、疑似的に負荷を発生させて、性能計測を行う。その後、本実施形態の情報処理システム1は、負荷再現フェーズにおいて、負荷調整フェーズで得られた処理能力指標に基づいて、移動先サーバ9上で、負荷を発生させ、リソース使用量を取得する。
 本実施形態の情報処理システム1では、まず、管理サーバ4が、負荷調整フェーズを開始する。そして、負荷調整フェーズにおいて、性能計測用仮想サーバ100が、移動元サーバ7上に業務用仮想サーバ76に相当する負荷をかけ、性能計測を行う。その後、管理サーバ4が、負荷再現フェーズを開始し、移動先サーバ9上に負荷を発生させ、リソース使用量を取得する。
 まず、管理サーバ4において、仮想サーバイメージ記憶部29には性能計測用仮想サーバ100、ならびに、業務用仮想サーバ76および業務用仮想サーバ96の2種類の仮想サーバイメージが登録されているものとする。
 また、本実施形態では、予め仮想サーバ起動部24により、プールサーバ5上に性能計測用仮想サーバ100が起動された状態であるとする。その起動方法は、仮想サーバ起動部24に対して仮想サーバイメージ記憶部29に登録されている性能計測用仮想サーバ100のイメージをプールサーバ5上にコピーし、性能計測用の性能計測用仮想サーバ100を起動するように指示する方法とすることができる。ここで性能計測用の性能計測用仮想サーバ100(VM31~VM31n)のように複数の仮想サーバを起動してもよい。
 さらに、仮想サーバ起動部24により、移動元サーバ7および移動先サーバ9(SV21~SV2m)上に、業務用仮想サーバ76(VM11~VM1i)および業務用仮想サーバ96(VM21~VM2j)、がそれぞれ起動された状態である。その起動方法は、仮想サーバ起動部24に対して仮想サーバイメージ記憶部29に登録されている業務用仮想サーバのイメージを移動元サーバ7および移動先サーバ9(SV21~SV2m)上にコピーし、業務用仮想サーバ76(VM11~VM1i)および業務用仮想サーバ96(VM21~VM2j)を起動するように指示する方法とすることができる。ここで業務用仮想サーバ76(VM11~VM1i)および業務用仮想サーバ96(VM21~VM2j、VM81~VM8x、VM91~VM9y、・・・)のように複数の仮想サーバを起動してもよい。
 上述した業務用仮想サーバ76(VM11~VM1i)、業務用仮想サーバ96(VM21~VM2j)、および性能計測用仮想サーバ100(VM31~VM3n)は、クライアント処理もしくはジョブをスケジュール化された処理により、負荷を発生する。そして、これらの負荷が、物理サーバ(移動元サーバ7、移動先サーバ9、またはプールサーバ5)のリソースを消費しているものとする。
 また、この状態において、運用者は、負荷調整指示または負荷再現指示を、操作部(不図示)を利用して実施するものとし、性能情報取得指示部21が指示を受け付ける。
 なお、以後の説明では、説明を簡単にするために例として、性能計測用仮想サーバ100は1台とし、業務用仮想サーバ76も1台とする。
<負荷調整フェーズ>
 図4は、本実施形態の管理サーバ4における負荷調整フェーズの処理手順の一例を示すフローチャートである。以下、図1および図4を用いて説明する。
 まず、管理サーバ4(図1)において、性能情報取得指示部21(図1)が、運用者からの負荷調整指示を受け付けると、負荷調整および再現指示部22(図1)に対して負荷調整指示を行う(図4のステップS101)。そして、この負荷調整指示に呼応して、負荷調整および再現指示部22(図1)が、仮想サーバ移動部25(図1)に対して、プールサーバ5(図1)上の性能計測用仮想サーバ100(図1)を運用者が指定した移動元サーバ7(図1)上に移動させるように指示する。なお、運用者が指定しなかった物理サーバ(移動元サーバ7)に対して調整処理は行わない。指示に従い、性能計測用仮想サーバ100(図1)がプールサーバ5(図1)から移動元サーバ7(図1)に移動される(図4のステップS103)。
 ここで、仮想サーバ移動部25(図1)は、運用管理製品、仮想化ミドルウェア製品をはじめとする既存技術で既に実現されているものであり、ここでは、その実現方法は特に制限しない。そして、負荷調整および再現指示部22(図1)は、仮想サーバ移動部25(図1)に対して移動元サーバ7(図1)上の業務用仮想サーバ76(図1)を退避サーバ6(図1)上に移動させるように指示する。この指示に従い、移動元サーバ7(図1)上の業務用仮想サーバ76(図1)が退避サーバ6(図1)に移動される(図4のステップS105)。
 そして、負荷調整および再現指示部22(図1)は、性能計測用仮想サーバ100(図1)に対して、情報送信部26(図1)を利用して性能情報計測指示を、通信網3(図1)を介して送信する(図4のステップS107)。なお、性能情報計測指示の中には業務用仮想サーバ76(図1)の各リソース量と、図13の設定情報130が含まれている。
 性能計測用仮想サーバ100(図1)では、性能情報計測指示に呼応して、性能計測処理が開始される(図4のステップS109)。なお、性能計測用仮想サーバ100(図1)における性能計測処理の詳細については、後述する。
 性能計測用仮想サーバ100(図1)における性能計測処理が終了すると、管理サーバ4では、それぞれの移動元サーバ7(図1)上の性能計測用仮想サーバ100(図1)から情報受信部27(図1)によって処理能力指標の受信を行い、性能情報記憶部20(図1)に記憶する(図4のステップS111)。
 そして、負荷調整および再現指示部22(図1)が、仮想サーバ移動部25(図1)に対して移動元サーバ7(図1)上の性能計測用仮想サーバ100(図1)をプールサーバ5(図1)上に移動させるように指示する。この指示に従い、移動元サーバ7(図1)上の性能計測用仮想サーバ100(図1)がプールサーバ5(図1)上に移動される(図4のステップS113)。
 さらに、負荷調整および再現指示部22(図1)が、仮想サーバ移動部25(図1)に対して退避サーバ6(図1)上の業務用仮想サーバ76(図1)を移動元サーバ7(図1)上に移動させるように指示する。この指示に従い、退避サーバ6(図1)上の業務用仮想サーバ76(図1)が移動元サーバ7(図1)上に移動される(図4のステップS115)。以上で、負荷調整フェーズが終了し、実際の業務用サービスは停止することなく、性能計測処理が行われたこととなる。
 以下、本実施の形態の性能計測用仮想サーバ100のデータ処理方法を以下に説明する。
 図5および図6は、本実施形態の性能計測用仮想サーバ100における負荷調整時の性能計測処理の手順の一例を示すフローチャートである。上述したように、本実施形態の性能計測プログラムをコンピュータが以下に示す手順を実行することで、本実施形態の性能計測用仮想サーバ100の機能が実現されることとなる。このフローは、図4の本実施形態の管理サーバ4の負荷調整フェーズの負荷調整処理のステップS109から呼び出される。以下、図1、図3乃至図6、図13を用いて説明する。
 本実施形態の性能計測用仮想サーバ100のデータ処理方法は、物理サーバ(移動元サーバ7)および移動元サーバ7上で稼働する仮想サーバ(業務用仮想サーバ76)の複数のリソースの負荷を計測する制御装置(性能計測用仮想サーバ100)のデータ処理方法であって、制御装置(性能計測用仮想サーバ100)が、移動元サーバ7および移動元サーバ7上で稼働する仮想サーバの複数のリソースのリソース使用量を取得し(図5のステップS221)、計測対象リソースに負荷を発生させ(図5のステップS205)、計測対象リソースに負荷をかけることで、計測対象リソースが依存しているリソースを求め、計測対象リソースが依存しているリソースの数に基づいて、計測対象リソースの依存度数を算出し(図5のステップS209)、複数のリソースについて計測対象リソースとしてそれぞれ算出された依存度数が大きい順にリソースに順位付けし(図5のステップS213)、順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら(図6のステップS303)、計測対象リソースのリソース使用量の処理能力指標を調整する(図6のステップS307)。
 さらに、性能計測用仮想サーバ100のデータ処理方法において、移動元サーバ7上で稼働する少なくとも1つの仮想サーバの代わりに、性能計測用仮想サーバ100を移動元となる移動元サーバ7上で稼働させることで制御装置を実現し(図4のステップS103)、性能計測用仮想サーバ100が、移動元となる移動元サーバ7上で稼働する少なくとも1つの業務用仮想サーバ76の代わりに、移動元サーバ7上で負荷を発生させ(図6のステップS303)、移動元サーバ7と、移動元サーバ7上で稼働させた性能計測用仮想サーバ100の複数のリソースのリソース使用量を定期的に取得し(図6のステップS321)、処理能力指標を調整する(図6のステップS307)。
 さらに、性能計測用仮想サーバ100のデータ処理方法において、性能計測用仮想サーバ100が、取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷をかけたリソースのリソース使用量で、かつ、今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる仮想サーバの計測対象リソースのリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整し(図6のステップS307)、調整された処理能力指標に基づいて、順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら(図6のステップS309)、取得したリソース使用量から目標となるリソース使用量の絶対値が許容範囲内に入っているか否かを判定し(図6ステップS313、ステップS315)、許容範囲内に入っていると判定されたとき(図6のステップS315のYES)、取得したリソース使用量から目標となるリソース使用量に対応する処理能力指標を見積もる(図6のステップS319)。
 詳細には、まず、性能計測用仮想サーバ100(図3)において、情報受信部103(図3)が、上述した図4のステップS107で管理サーバ4(図1)から送信された性能情報計測指示を受信し、受信情報記憶部121(図3)に記憶する(図5のステップS201)。そして、性能情報計測指示に呼応して、計測指示部115(図3)が、設定ファイル読み込み部109(図3)に対して、図13の設定情報130のパラメータを読み込むよう指示を行う。この指示に従い、設定ファイル読み込み部109(図3)が、受信情報記憶部121から設定情報130(図13)で指定されている性能計測用仮想サーバ100の設定パラメータを読み込み、設定情報記憶部123(図3)に記憶する(図5のステップS203)。
 以下、性能計測用仮想サーバ100(図3)において、依存関係分析処理が開始される。
 図5に示すように、計測指示部115(図3)が、リソース単位で負荷発生部107(図3)に対してリソースの負荷を順に発生させるように指示する。この指示に従い、負荷発生部107(図3)が、設定情報130(図13)の各リソースフラグを参照し、計測を実施すると指定されているリソースにて、設定情報130(図13)で指定されている初回処理能力指標を入力にしてジョブを処理し、結果的にリソースの負荷を発生させる(図5のステップS205)。計測を実施しないリソースに対しては何も行わない。
 ここで、図5のステップS205において、図13に示される設定情報130のように、負荷発生部107がマルチプロセッサ情報からそのコア数に応じたプロセス数を起動し、複数のプロセスが同時に負荷を発生させることができる。すなわち、負荷発生部107は、負荷の発生のプロセスまたはスレッドを、複数プロセスまたはスレッドとして実行し、見積部(負荷調整部111)は、マルチプロセッサの環境下における仮想サーバの処理能力指標を見積もることができる。
 マルチプロセッサの場合、CPUリソースに関して、性能計測用プログラムを実行する場合、1つのCPU当り1つのプロセスが割り当てられる。そのため、2つのCPU上で計測した場合、各サーバ(移動元サーバ7または移動先サーバ9)ではCPU自体が最大50%までしか使用されない。計測対象のサーバ(負荷調整フェーズでは移動元サーバ7、負荷再現フェーズでは移動先サーバ9)の環境内にマルチCPUのサーバが存在する場合、この処理を考慮することにより、CPUリソースを最大限使用することが可能となる。その結果、シングルまたはマルチの場合でも同じように処理能力指標で比較することが可能になる。
 また、ここで、ジョブとは、一般的なサーバを代表とする情報処理装置が行う仕事の単位とし、さらにこのジョブの大きさを処理能力指標と定義する。たとえば、CPUの場合には数値演算の回数をジョブの大きさと定義することにより、負荷を調整することが可能である。さらに、図14に示すように、一定期間内に負荷発生と休み(スリープ)を交互に繰り返す方式とし、物理サーバが出力するリソース使用量を調整できるものとする。これは説明のための一例であり、目標となる負荷発生するための方法は本方式に限らない。
 図14のように、サーバ本来の処理能力指標が200であった場合に、処理能力指標を100とすると、リソース使用量は50%となる。このとき、負荷発生期間とスリープ期間をそれぞれ500msで交互に繰り返す。処理能力指標を50に変更した場合は、リソース使用量は25%となる。このとき、負荷発生期間は250ms、スリープ期間は750msとしてそれぞれ交互に繰り返す。
 本実施形態では、リソースは、CPU、メモリ、NW、HDDが該当し、リソース使用量あるいは使用率として算出されたものとする。使用率は一定期間内の物理サーバ、仮想サーバのリソース使用量から分かる。たとえばNWは一定期間に秒間当りのNWの入出力とスリープの処理を交互に入れることでCPUと同じく発生する負荷を制御することができる。HDDは一定期間に秒間当りの読み書きとスリープの処理を入れることでCPUと同じく発生する負荷を制御することができる。なお、本実施形態において、HDDは、ネットワークを介して各サーバで共有可能なHDDとすることができる。リソースはこれらに限定せずこれ以外に依存するリソースもあれば計測対象とする。
 他の例では、負荷発生期間とスリープ期間をもっと短い周期で繰り返すようにしてもよい。たとえば、100msずつ交互に繰り返してもよい。
 図5に戻り、ステップS205~ステップS211と並行して、情報受信部103(図3)が、移動元サーバ7(図1)上の管理エージェント70(図1)の負荷情報通知部74(図1)から定期的に各リソースのリソース使用量を、通信網3(図1)を介して受信し、負荷情報記憶部117(図3)に記憶する。移動元サーバ7(図1)では、管理エージェント70(図1)の負荷情報収集部72(図1)が、移動元サーバ7(図1)および性能計測用仮想サーバ100(図1)のリソース使用量を取得したものを管理サーバ4(図3)の情報受信部103(図3)に対して通信網3(図1)を介して定期的に送信するものとする(図5のステップS221)。
 たとえば、上述したように、負荷発生期間とスリープ期間を交互に1000msの周期で繰り返す構成としているので、リソース使用量の監視も1000msごとに行うとよい。ここで、リソース使用量の監視間隔が負荷発生周期より短いと、取得するリソース使用量が不正になる可能性がある。そのため、リソース使用量の監視間隔は、負荷発生期間とスリープ期間を合計した負荷発生周期以上とするのがよい。
 そして、負荷判定部105(図3)が、計測対象のリソースの負荷が安定したか否かを判定する(図5のステップS207)。たとえば、まず、負荷判定部105(図3)が、負荷情報記憶部117(図3)の計測対象のリソースのリソース使用量(図5のステップS221で定期的に更新される)が更新されたことを確認する。そして、更新されていなければ、図5のステップS205へ戻る。更新されたリソース使用量が存在し、かつ、図13の設定情報130で設定されている読み飛ばし回数だけ読み飛ばしたら、負荷が安定したと判断して(図5のステップS207のYES)、負荷判定部105(図3)が、更新されたリソース使用量を採用する。回数に達しない場合はまだ安定していないと判断し(図5のステップS207のNO)、図5のステップS205に戻る。
 負荷をかけ始めて直ぐには、サーバが安定しないことと、負荷の影響がリソース使用量に直ぐには反映されないことから、所定の読み飛ばし回数分だけ読み飛ばすことで、安定させ、正確な値を得ることができる。リソース使用量を定期的に監視し、安定したか否かを確認してもよいが、所定回数読み飛ばす処理の方が簡単で処理が軽くてよい。
 そして、負荷判定部105(図3)が、負荷情報記憶部117(図3)に記憶されている計測対象のリソースのリソース使用量が更新されたことを認知し、かつ、別のリソースのリソース使用量が負荷発生前よりも上昇していると判断した場合、依存関係があると判定する。そして、その上昇するリソース数をカウントしたものを依存度数とし、図15の依存情報記憶部127(図3)に各リソースの依存度数を記憶する(図5のステップS209)。図15では、負荷情報記憶部117(図3)に記憶されている各リソースの使用量と、対応する依存度数を示してある。各リソースのリソース使用量と依存度数を関連付けて記憶してもよい。
 負荷調整部111(図3)が、対象の計測を停止して、まだ計測されていない別の計測対象のリソースがある場合には(図5のステップS211のNO)、図5のステップS205に戻り、別のリソースを計測対象としてステップS205~ステップS209を繰り返す。残りのリソースがなければ(図5のステップS211のYES)、次の図5のステップS213に進む。このとき、図5のステップS221におけるリソース使用量の受信処理も停止し、図5のステップS213に進む。
 そして、依存関係分析部113が、依存情報記憶部127に存在するリソースごとの計測結果をリソースに依存する順番(降順)にソートを行う(図5のステップS213)。
 以上により、依存関係分析処理が終了し、図15のように、リソースごとの依存関係が求められたことになる。
 次に、性能計測用仮想サーバ100において、上記依存関係分析処理で得られた依存関係に基づいて、負荷見積処理が開始される。以下、図1、図3および図6を用いて説明する。
 まず、計測指示部115(図3)が、負荷発生部107(図3)に対して依存情報記憶部127(図3)に記憶された依存度数の数値順(降順)で負荷をかけるように負荷発生指示を行う(図6のステップS301)。この理由は依存度数の大きいリソースから順番に負荷をかけていくと、依存度数の小さい別のリソースに負荷をかけた時に、それまでに依存した負荷を吸収しながら目標の負荷を発生することができるためである。昇順にすると、後々目標の負荷を超過してしまうからである。
 そして、負荷発生部107(図3)が、図13の設定情報130の各リソースフラグを参照し、計測を実施するリソースにて、負荷を発生させる(図6のステップS303)。初回の場合は設定情報130に設定されている初回処理能力指標を元にリソースの負荷を発生する。また、2回目以降は後述の処理で更新した処理能力指標を元にリソースの負荷を発生する。計測を実施しないリソースに対しては何も行わない。ここでは、負荷発生部107に対して処理能力指標を入力すると、性能計測用仮想サーバ100の負荷を発生する。
 ここで、図6のステップS303において、図13に示される設定情報130のように、負荷発生部107がマルチプロセッサ情報からそのコア数に応じたプロセス数を起動し、複数のプロセスが同時に負荷を発生させることができる。すなわち、負荷発生部107は、負荷の発生のプロセスまたはスレッドを、複数プロセスまたはスレッドとして実行する。そして、見積部(負荷調整部111)は、マルチプロセッサの環境下における仮想サーバの処理能力指標を見積もることができる。
 マルチプロセッサの場合、CPUリソースに関して、性能計測用プログラムを実行する場合、1CPU当り1プロセスが割り当てられる。そのため、2つのCPU上で計測した場合、各サーバ(移動元サーバ7または移動先サーバ9)ではCPU自体が最大50%までしか使用されない。計測対象のサーバ(負荷調整フェーズでは移動元サーバ7、負荷再現フェーズでは移動先サーバ9)の環境内にマルチCPUのサーバが存在する場合、この処理を考慮することにより、CPUリソースを最大限使用することが可能となる。その結果、シングルまたはマルチの場合でも同じように処理能力指標で比較することが可能になる。
 ステップS303~ステップS317と並行して、情報受信部103(図3)が、移動元サーバ7(図1)上の管理エージェント70(図1)の負荷情報通知部74(図1)から定期的に各リソースのリソース使用量を、通信網3(図1)を介して受信し、負荷情報記憶部117(図3)に記憶する。移動元サーバ7(図1)では、管理エージェント70(図1)の負荷情報収集部72(図1)が、移動元サーバ7(図1)および移動元サーバ7上で稼働している性能計測用仮想サーバ100(図1)のリソース使用量を取得したものを性能計測用仮想サーバ100(図3)の情報受信部103(図3)に対して通信網3(図1)を介して定期的に送信するものとする(図6のステップS321)。
 そして、負荷判定部105(図3)が、計測対象のリソースの負荷が安定したか否かを判定する(図6のステップS304)。たとえば、まず、負荷判定部105(図3)が、負荷情報記憶部117(図3)の計測対象のリソースのリソース使用量(図6のステップS321で定期的に更新される)が更新されたことを確認する。そして、更新されていなければ、図6のステップS303へ戻る。更新されたリソース使用量が存在し、かつ、図13の設定情報130で設定されている読み飛ばし回数だけ読み飛ばしたら、負荷が安定したと判断して(図6のステップS304のYES)、負荷判定部105(図3)が、更新されたリソース使用量を採用する。回数に達しない場合はまだ安定していないと判断し(図6のステップS304のNO)、図6のステップS303に戻る。
 負荷判定部105(図3)が、リソース負荷の前後の揺らぎが振れ幅に入っているかどうかを判定する。たとえば、負荷判定部105(図3)は、性能計測用仮想サーバ100の最新とその前のリソース使用量を比較し、図13の設定情報130の初回調整振れ幅の範囲内に入っているかどうかを判定する。範囲に入っている場合、さらに、図13の設定情報130の継続回数分行えたか判定を行う(図6のステップS305)。条件を満たしていない場合(図6のステップS305のNO)、図6のステップS303に戻る。
 条件を満たしている場合(図6のステップS305のYES)、負荷調整部111(図3)が、初回の場合は、図13の設定情報130の初回処理能力指標を元にし、2回目以降は更新した処理能力指標と性能計測用仮想サーバ100のリソース使用量を対応付ける。ここで、中間情報記憶部125(図3)の計測対象データのリソース使用量を参照し、管理サーバ4(図1)から受信した各リソースのリソース使用量から計測対象のリソース使用量を差し引いた分のリソース使用量分の負荷を発生する処理能力指標を見積もり、性能情報記憶部119(図3)に記憶する。ここでは、処理能力指標の見積もりには、下記の式(1)を利用する。なお、中間情報記憶部125(図3)を参照して計測対象データのリソース使用量が存在しなければ、中間情報記憶部125(図3)の依存リソース使用量は利用しない。
 式(1)は、上述した本実施形態の負荷調整または再現フェーズにおいて、利用する数式を定義したものである。
 式(1)では、現時点の性能計測用仮想サーバ100の処理能力指標(NUM_BSE)、リソース使用量(P_AVM)、業務用仮想サーバ76(または業務用仮想サーバ96)のリソース使用量(P_TAR)、各計測対象の依存リソース使用量(P_DEP)から、業務用仮想サーバ76(または業務用仮想サーバ96)の処理能力指標(NUM_TAR)を以下の式で定義する。
 NUM_TAR=NUM_BSE×((P_TAR-ΣP_DEP)/P_AVM) ・・・式(1)
 ここで、たとえば、各計測対象の依存リソース使用量(P_DEP)は、リソースの分だけ存在する。そして、図15に示す、HDDI(HDDリソースの入力)計測時に、HDDI以外のリソースの使用量がこれに該当する。計測ごとに、この値を足し込んでいく。
 図16には、図15に示した依存度数の高い順(HDDI/O(HDDリソースの入出力)>NWI/O(NWの入出力)>CPU=メモリ)とした負荷の依存特性から各リソース負荷の見積もり方法を示した一例を示す。なお、目標負荷は業務用仮想サーバ76(または業務用仮想サーバ96)のリソース使用量である。図16(a)に示すように、HDDI/Oの負荷を発生させた場合には、特に依存関係は存在しない。処理能力指標自体は発生させたものを利用する。
 次に、図16(b)に示すように、NWI/Oの負荷を見積もる場合には、HDDI/Oの負荷を発生させた場合にNWI/Oでも負荷(L2)が発生する。そのため、目標の負荷から、(L2)の部分を差し引いた部分(L1)のリソース使用量が出力可能な処理能力指標を見積もる。なお、上述したように、本実施形態では、HDDはネットワークを介して各サーバが共有可能である。そのため、HDDI/Oに負荷を発生させた場合に、NWI/Oでも負荷が発生することとなる。なお、図16では、HDDI/Oによって発生する負荷は、太い破線で囲まれた部分であることを示している。
 ここで、NWI/O_Tを目標とするNWI/O(仮想サーバが発生するNWI/O)使用量(L1+L2)とし、NWI/O_HDDI/OをHDDI/Oによって発生するNWI/O使用量(L2)とすると、実際に見積もる際のNWI/O使用量(L1)のNWI/O_Eは、以下の式(2)で示される。
 NWI/O_E=NWI/O_T-(NWI/O_HDDI/O)  ・・・式(2)
 さらに、図16(c)に示すように、CPUの負荷を見積もる場合には、HDDI/Oの負荷を発生させた場合のCPU負荷(L4)および、NWI/Oの負荷を発生させた場合のCPU負荷(L5)が発生する。したがって、目標の負荷から(L4)と(L5)の部分を差し引いた部分(L3)のリソース使用量が出力可能な処理能力指標を見積もる。図16(c)では、NWI/Oによって発生する負荷は、太い一点鎖線で囲まれた部分であることを示している。
 ここで、CPU_Tを目標とするCPU使用量(仮想サーバが発生するCPU使用量)(L3+L4+L5)とし、CPU_NWI/OをNWI/Oによって発生するCPU使用量(L5)とし、CPU_HDDI/OをHDDI/Oによって発生するCPU使用量(L4)とすると、実際に見積もる際のCPU使用量(L3)のCPU_Eは、以下の式(3)で示される。
 CPU_E=CPU_T-(CPU_NWI/O+CPU_HDDI/O)  ・・・式(3)
 以上より、目標のリソース使用量に対する処理能力指標を見積もることができる(図6のステップS307)。すなわち、負荷発生部107(図3)が、更新された処理能力指標とリソース使用量から業務用仮想サーバ76(または業務用仮想サーバ96)のリソース使用量になるように処理能力指標を調整する。
 負荷発生部107(図3)が、見積もったリソースの処理能力指標を元に処理を行い、結果的に性能計測用仮想サーバ100(図1)のリソースの負荷を発生させる(図6のステップS309)。このとき、負荷発生部107に対して処理能力指標を入力すると、性能計測用仮想サーバ100の負荷を発生する。
 そして、負荷判定部105(図3)が、負荷情報記憶部117(図3)のリソース使用量が更新されたことを認知して、かつ、図13の設定情報130の継続回数だけ計測を実施した場合(図6のステップS311のYES)、リソース使用量を採用する。更新されたリソース使用量が負荷情報記憶部117に存在しない、または継続回数に達しない場合は(図6のステップS311のNO)、図6のステップS309に戻る。
 そして、負荷判定部105(図3)が、基準になるリソース使用量にするために処理能力指標を調整した回数、つまり図13の設定情報130に設定されている最大調整回数を満たすかどうか判定する(図6のステップS313)。最大調整回数を満たしていれば(図6のステップS313のYES)、エラー内容を結果に含めて、管理サーバ4に対して通信網3(図1)を介して送信し、図4のステップS111に戻る(図6のステップS319)。
 そして、図6のステップS313の判定がNOの場合、負荷判定部105(図3)が、処理能力指標と、処理能力指標分の実行処理から、結果的に得られた性能計測用仮想サーバ100のリソース使用量に変換する。そして、負荷判定部105が、図13の設定情報130に設定されている基準になるリソース使用量の許容範囲内に入っているかどうかを判定する(図6のステップS315)。条件を満たしていれば(図6のステップS315のYES)、次の図6のステップS317に進む。条件を満たしていなければ(図6のステップS315のNO)、図6のステップS307に戻る。
 そして、図6のステップS315の判定がNOの場合、負荷調整部111(図3)が、計測対象の処理能力指標を性能情報記憶部119(図3)に記憶し、その時点の計測対象以外のリソース使用量を中間情報記憶部125(図3)に記憶する。まだ負荷を発生していない他の計測対象のリソースがある場合には(図6のステップS317のYES)、図6のステップS303に戻り、対象のリソースの負荷は発生させたままで、別のリソースを計測対象として以降の処理を実施する。まだ負荷を発生していない計測対象のリソースがなければ(図6のステップS317のNO)、次の図6のステップS319に進む。このとき、図6のステップS321におけるリソース使用量の受信処理も停止し、図6のステップS319に進む。
 すなわち、全ての対象リソースについて負荷の発生が終了したら(図6のステップS317のNO)、性能情報記憶部119(図3)に記憶した処理能力指標を結果として、情報送信部101(図3)が、管理サーバ4(図1)に通信網3を介して送信する(図6のステップS319)。
 以上で、性能計測用仮想サーバ100における負荷見積り処理が終了し、図4のステップS111に戻る。
<負荷再現フェーズ>
 次に、負荷再現フェーズについて以下に説明する。
 図7は、本実施形態の管理サーバ4における負荷再現フェーズの処理手順の一例を示すフローチャートである。以下、図1および図7を用いて説明する。
 まず、管理サーバ4(図1)において、性能情報取得指示部21(図1)が、運用者からの負荷再現指示を受け付けると、負荷調整および再現指示部22(図1)に対して負荷再現指示を行う(図7のステップS401)。ここで、負荷再現指示とともに、移動先サーバ9の指定も受け付ける。そして、この負荷再現指示に呼応して、負荷調整および再現指示部22(図1)が、仮想サーバ移動部25(図1)に対してプールサーバ5(図1)上の性能計測用仮想サーバ100(図1)を利用者が指定したそれぞれの移動先サーバ9(図1)上に移動させるように指示する。指定しなかった移動先サーバ9(図1)以外に対して再現処理は行わない。指示に従い、性能計測用仮想サーバ100(図1)がプールサーバ5(図1)から移動先サーバ9(図1)に1台ずつ移動される(図7のステップS403)。
 そして、負荷調整および再現指示部22(図1)が、性能計測用仮想サーバ100(図1)対して、情報送信部26(図1)を利用して性能情報計測指示を、通信網3(図1)を介して送信する(図7のステップS405)。なお、性能情報計測指示の中には性能計測用仮想サーバ100(図1)が見積もった移動元サーバ7(図1)上の業務用仮想サーバ76(図1)の処理能力指標が含まれている。
 そして、性能計測用仮想サーバ100(図1)では、性能情報計測指示に呼応して、負荷を再現させるとともに、再現された負荷の元で性能計測処理を行う(図7のステップS407)。なお、性能計測用仮想サーバ100(図1)における性能計測処理の詳細については、後述する。
 性能計測用仮想サーバ100(図1)における性能計測処理が終了すると、管理サーバ4(図1)が、移動先サーバ9(図1)上の性能計測用仮想サーバ100(図1)から情報受信部27(図1)によってリソース使用量の受信を行い、性能情報記憶部20(図1)に記憶する(図7のステップS409)。この受信処理は定期的に繰り返し実行され、運用者の指示を受け付けたとき、負荷再現処理を停止し、次の図7のステップS411に進む。
 そして、負荷調整および再現指示部22(図1)が、仮想サーバ移動部25(図1)に対して移動先サーバ9(図1)上の性能計測用仮想サーバ100(図1)をプールサーバ5(図1)上に移動させるように指示する。この指示に従い、移動先サーバ9上の性能計測用仮想サーバ100が、プールサーバ5上に移動される(図7のステップS411)。
 情報比較部28(図1)が、性能情報記憶部20(図1)にある移動先サーバ9(図1)上で消費したリソース使用量を取得する。そして、情報比較部28は、さらに複数の移動先サーバ9(SV21~SV2m)(図1)でも行った場合に、リソース使用量の大きさを比較できるように表示部(不図示)などに提示する(図7のステップS413)。これにより、運用者は移動時に高負荷にならない物理サーバ(移動先サーバ9)に移動する判断をすることが可能となる。
 図8は、本実施形態の性能計測用仮想サーバ100における負荷再現時の性能計測処理の手順の一例を示すフローチャートである。上述したように、本実施形態の性能計測プログラムをコンピュータが以下に示す手順を実行することで、本実施形態の性能計測用仮想サーバ100の機能が実現されることとなる。このフローは、図7の本実施形態の管理サーバ4の負荷再現フェーズの負荷再現処理のステップS407から呼び出される。以下、図1、図3、および図8を用いて説明する。
 まず、性能計測用仮想サーバ100(図3)において、情報受信部103(図3)が、上述した図7のステップS405で管理サーバ4(図1)から送信された性能情報計測指示を受信し、受信情報記憶部121(図3)に記憶する(図8のステップS501)。そして、性能情報計測指示に呼応して、計測指示部115(図3)が、設定ファイル読み込み部109(図3)に対して、図13の設定情報130のパラメータを読み込むよう指示を行う。この指示に従い、設定ファイル読み込み部109(図3)が、受信情報記憶部121から設定情報130(図13)で指定されている性能計測用仮想サーバ100の設定パラメータを読み込み、設定情報記憶部123(図3)に記憶する(図8のステップS503)。
 そして、計測指示部115(図3)が、負荷発生部107(図3)に対して、リソースに負荷をかけるように負荷発生指示を行う。この指示に従い、負荷発生部107(図3)が、設定情報記憶部123(図3)に記憶された設定情報130(図13)の処理能力指標を元に処理を行い、リソースの負荷を発生させる(図8のステップS505)。ここではリソースに負荷をかける順番は問わず、一斉に負荷をかける。このように、負荷発生部107に対して調整フェーズで調整した処理能力指標を入力すると、性能計測用仮想サーバ100の負荷を発生する。
 ここで、図8のステップS505において、図13に示される設定情報130のように、負荷発生部107がマルチプロセッサ情報からそのコア数に応じたプロセス数を起動し、複数のプロセスが同時に負荷を発生させることができる。すなわち、負荷発生部107は、負荷の発生のプロセスまたはスレッドを、複数プロセスまたはスレッドとして実行する。そして、見積部(負荷調整部111)は、マルチプロセッサの環境下における仮想サーバの処理能力指標を見積もることができる。
 マルチプロセッサの場合、CPUリソースに関して、性能計測用プログラムを実行する場合、1CPU当り1プロセスが割り当てられる。そのため、2つのCPU上で計測した場合、各サーバ(移動元サーバ7または移動先サーバ9)ではCPU自体が最大50%までしか使用されない。計測対象のサーバ(負荷調整フェーズでは移動元サーバ7、負荷再現フェーズでは移動先サーバ9)の環境内にマルチCPUのサーバが存在する場合、この処理を考慮することにより、CPUリソースを最大限使用することが可能となる。その結果、シングルまたはマルチの場合でも同じように処理能力指標で比較することが可能になる。
 図8のステップS505~ステップS511と並行して、情報受信部103(図3)が、移動先サーバ9(図1)上の管理エージェント90(図1)の負荷情報通知部94(図1)からリソース使用量を、通信網3(図1)を介して定期的に受信し、そのデータを負荷情報記憶部117(図3)に記憶する(図8のステップS521)。
 そして、負荷判定部105(図3)が、負荷情報記憶部117(図3)のリソース使用量が更新されたどうかを確認する(図8のステップS507)。ここで、負荷判定部105(図3)が、負荷情報記憶部117(図3)に更新されたリソース使用量が存在したと判定した場合(図8のステップS507のYES)、負荷情報記憶部117(図3)から最新のリソース使用量を読み出し、情報送信部101(図3)を利用して通信網3(図1)を介して管理サーバ4(図1)に送信する(図8のステップS509)。
 負荷情報記憶部117(図3)の最新のリソース使用量とその前のリソース使用量の絶対値を取得し、図13の設定情報130で指定されている振れ幅以内に収まっており、かつ、図13の設定情報130で指定されている継続回数を満たした場合(図8のステップS511のYES)、本処理を終了し、図7のステップS409に戻る。このとき、図8のステップS521におけるリソース使用量の受信処理も停止する。
 以上により、性能計測用仮想サーバ100における性能計測処理が終了し、上述した図7のステップS409に戻ることとなる。なお、条件を満たしていない場合(図8のステップS511のNO)、図8のステップS507に戻る。
 以上説明したように、本実施形態の情報処理システム1によれば、移動元サーバ7上にて、あるリソースに負荷をかけた際にI/O処理等で、別のリソースに負荷がかかる依存分析を行い(これらを依存負荷と定義する)、その結果を利用して、目標負荷から依存負荷を引いたリソース使用量分の負荷を見積もり、さらにこの差し引いたリソース使用量分の処理能力指標となるように調整することができる。その結果、目標負荷に近い精度で移動元サーバ7上でのリソース使用量分を発生できる処理能力指標を見積もることが可能になる。リソース間の依存関係を分析することで、目標のリソース使用量に近い負荷を見積もることが可能になり、見積もり負荷の精度が向上する。
 たとえば、仮想サーバの負荷見積もりの際にリソースに対して負荷をかけた時に、他のリソースの間で依存する特性が出る。そのため、観測されたリソースの使用量を元にそのまま再現させると、この特性から余分に負荷が発生してしまう。計測対象のリソースに負荷をかけた際に発生する別のリソースの依存関係を分析し、依存度数で分類する。目標のリソースの負荷を発生させるために、リソースに依存する順番にリソースに負荷を発生させ、目標のリソースの使用量から差し引いた分の負荷を再現することで、負荷発生により発生するリソース間のオーバーヘッドの影響を除外し、余分な負荷の発生を防ぐことができる。
 特に、計測対象のリソースに負荷をかけた際に発生する別のリソースの依存関係を別のリソースの使用量等を見て分析し、依存度数の高いリソースがあるかどうかを分類する。目標のリソースの負荷を発生させるために、リソースに依存する順番に負荷をかけた際の別のリソースにかかる負荷を記憶させておく。さらに別のリソースに負荷を発生させる際に上述した負荷を目標のリソースの使用量から差し引いた分の負荷を再現する。これを繰り返すことにより、目標のリソースの使用量を発生させることができる。
(第2の実施の形態)
 図9は、本発明の実施の形態に係る情報処理システム2の構成を示す概略ブロック図である。
 本実施形態の情報処理システム2は、上記実施形態の情報処理システム1とは、移動先候補となる物理サーバの中から負荷が適切な値になる物理サーバを決定する構成を有する点で相違する。
 本実施形態の情報処理システム2において、検証対象となる移動先サーバ200上に性能計測用仮想サーバ300を稼働させ、負荷発生部107(図10)が、順位付け部(図10の依存関係分析部113)により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、空資源調整部129(図10)が、情報受信部103(図10)が取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷発生部107が負荷をかけたリソースのリソース使用量で、かつ、負荷発生部107が今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる物理サーバの空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整し、さらに、制御装置(性能計測用仮想サーバ300)は、負荷調整部111(図10)により調整された処理能力指標に基づいて、負荷発生部107が、順位付け部(依存関係分析部113)により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、情報受信部103が取得したリソース使用量から移動先サーバ200の空キャパシティに相当するリソース使用量の絶対値が許容範囲内に入っているか否かを判定する判定部(図10の負荷判定部105)と、負荷判定部105により許容範囲内に入っていると判定されたとき、情報受信部103が取得したリソース使用量から移動先サーバ200の空キャパシティに相当するリソース使用量に対応する処理能力指標を見積もる見積部(空資源調整部129)と、を備える。
 具体的には、本実施形態の情報処理システム2は、図1の上記実施形態の情報処理システム1の負荷調整および再現指示部22に代えて空資源取得指示部23を有する管理サーバ8と、図1の上記実施形態の情報処理システム1の複数の性能計測用仮想サーバ100に代えて複数の性能計測用仮想サーバ300を有するプールサーバ5と、移動先サーバ200と、を備え、これらは互いに通信網3を介して接続される。
 複数の移動先サーバ200(SV31、・・・、SV3b、bは自然数)は、図1の情報処理システム1の移動先サーバ9(SV21、・・・、SV2m、mは自然数)とそれぞれ同様な構成を有し、管理エージェント90と同様に、負荷情報収集部212および負荷情報通知部214を有する管理エージェント210をそれぞれ含む。
 図9において、プールサーバ5、移動先サーバ200(SV31、・・・、SV3b)、は仮想サーバを配置することが可能で、さらにお互いのサーバ間を移動できる機能が提供されている物理サーバである。仮想サーバは2種類存在し、一方は業務用の業務用仮想サーバ216(VM41、・・・、VM4k、kは自然数)、他方は性能計測用仮想サーバ300(VM51、・・・、VM5a、aは自然数)である。
 業務用仮想サーバ216は、ウェブ、メール、バックアップ等の処理を行うアプリケーションを搭載し、それらの処理を行っていることを想定する。プールサーバ5の上で、本実施形態の性能計測用仮想サーバ300が稼動する。ここで、図9に示す性能計測用仮想サーバ300(VM51、・・・、V54a)のようにプールサーバ5上で複数(a個)稼動してもよい。
 移動先サーバ200の管理エージェント210は、負荷情報収集部212および負荷情報通知部214を有し、これらの機能を開始または終了する指示をする役割を持つ。移動先サーバ200上で、業務用仮想サーバ216が稼動する。ここで、業務用仮想サーバ216は、各移動先サーバ200上で複数(k1、k2、・・・kb個)ずつ稼動してもよい(図中、VM41~VM4kの他は省略)。
 本実施形態の管理サーバ8において、性能情報取得指示部21は、空資源取得指示部23に対して空資源取得指示を行う。本実施形態でも、上記実施形態と同様に、運用者が、情報処理システム2の管理サーバ8に対して、たとえば、操作部(不図示)等を利用して、空資源取得の指示を行うことができる。性能情報取得指示部21は、指示に従い、空資源取得指示部23に指示を行う。このとき、どの移動先サーバ200を検証対象とするのかの指定も運用者に指定させて受け付ける。
 管理サーバ8の空資源取得指示部23は、性能情報取得指示部21から空資源取得指示を受け付け。そして、空資源取得指示部23は、指示に従い、検証対象の移動先サーバ200にプールサーバ5から性能計測用仮想サーバ300を移動するように仮想サーバ移動部25に指示する。さらに、空資源取得指示部23は、移動先サーバ200に移動した性能計測用仮想サーバ300に対して、情報送信部26を利用して性能情報計測指示を、通信網3を介して送信する。ここでは、性能情報計測指示は、上記実施形態と同様とする。
 上述した管理サーバ8の各ユニットの機能は、コンピュータプログラムをコンピュータに実行されることで実現する。このコンピュータプログラムは、コンピュータで読み取り可能な記憶媒体に記録されてもよい。記録媒体は特に限定されず、様々に形態のものが考えられる。また、プログラムは、記録媒体からコンピュータのメモリにロードされてもよいし、ネットワークを通じてコンピュータにダウンロードされ、メモリにロードされてもよい。
 図10は、本実施形態の性能計測用仮想サーバ300の構成を示す機能ブロック図である。
 具体的には、図10に示すように、本実施形態の性能計測用仮想サーバ300は、図3の上記実施形態の性能計測用仮想サーバ100の構成に加え、さらに、空資源調整部129を備える。図では、性能計測用仮想サーバVM51について示しているが、他の性能計測用仮想サーバVM5aも同様の構成となる。
 空資源調整部129は、負荷発生部107が、順位付け部(依存関係分析部113)により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、情報受信部103が取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷発生部107が負荷をかけたリソースのリソース使用量で、かつ、負荷発生部107が今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる物理サーバの空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整する。さらに、空資源調整部129は、負荷判定部105により許容範囲内に入っていると判定されたとき、情報受信部103が取得したリソース使用量から物理サーバの空キャパシティに相当するリソース使用量に対応する処理能力指標を見積もる。
 上述した性能計測用仮想サーバ300の各ユニットの機能は、コンピュータプログラムをコンピュータに実行されることで実現する。
 本実施形態のコンピュータプログラムは、性能計測用仮想サーバ300を実現させるためのコンピュータに、上記実施形態の手順に加え、検証対象となる移動先サーバ200上に性能計測用仮想サーバ300を稼働させる手順と、負荷を発生する手順において、順位付けする手順により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、取得する手順で取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷を発生する手順で負荷をかけたリソースのリソース使用量で、かつ、負荷を発生する手順で今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる移動先サーバ200の空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整する手順と、調整する手順により調整された処理能力指標に基づいて、負荷を発生する手順において、順位付けする手順により順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら、取得する手順で取得したリソース使用量から移動先サーバ200の空キャパシティに相当するリソース使用量の絶対値が許容範囲内に入っているか否かを判定する手順と、判定する手順により許容範囲内に入っていると判定されたとき、取得する手順で取得したリソース使用量から移動先サーバ200の空キャパシティに相当するリソース使用量に対応する処理能力指標を見積もる手順と、を実行させるように記述されている。以下、このプログラムを性能計測プログラムと呼ぶ。
 本実施形態のコンピュータプログラムは、コンピュータで読み取り可能な記憶媒体に記録されてもよい。記録媒体は特に限定されず、様々に形態のものが考えられる。また、プログラムは、記録媒体からコンピュータのメモリにロードされてもよいし、ネットワークを通じてコンピュータにダウンロードされ、メモリにロードされてもよい。
 上述のような構成において、本実施の形態の制御装置のデータ処理方法を以下に説明する。図11および図12は、本実施形態の情報処理システム2の動作の一例を示すフローチャートである。
 本実施形態の制御装置(性能計測用仮想サーバ300)のデータ処理方法は、上記実施形態の制御装置のデータ処理方法において、検証対象となる移動先サーバ200上に性能計測用仮想サーバ300を稼働させることで制御装置を実現し、順位付けされた順に複数のリソースから計測対象リソースを選択して、順次負荷を発生させながら(図12のステップS303)、取得した各リソースのリソース使用量に基づいて、今回の計測対象リソース以外の前回までに負荷をかけたリソースのリソース使用量で、かつ、今回負荷をかけた計測対象リソースのリソース使用量を、予め設定された目標となる物理サーバの空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように処理能力指標を調整し(図12のステップS701)、調整された処理能力指標に基づいて、順位付けされた順に複数のリソースから計測対象リソースを選択して(図12のステップS317)、順次負荷を発生させながら(図12のステップS309)、取得したリソース使用量から物理サーバの空キャパシティに相当するリソース使用量の絶対値が許容範囲内に入っているか否かを判定し(図12のステップS703~ステップS707)、許容範囲内に入っていると判定されたとき(図12のステップS707のYES)、取得したリソース使用量から移動先サーバ200の空キャパシティに相当するリソース使用量に対応する処理能力指標を見積もる(図12のステップS709)。すなわち、負荷発生部107(図10)が、基準となる処理能力指標から空きリソース分の処理能力指標となるように処理能力指標を調整する。
 このように構成された本実施形態の情報処理システム2の動作について、以下に説明する。以下、図9乃至図12を用いて説明する。
 以後の説明では、移動先サーバ200には性能計測用仮想サーバ300は1台として、複数の業務用仮想サーバ216(VM41~VM4k)が存在する状態とする。移動先サーバ200の空資源取得を行うものとする。前提として、管理サーバ8において、仮想サーバイメージ記憶部29には性能計測用仮想サーバ300および業務用仮想サーバ216の2種類の仮想サーバイメージが登録されている。また、あらかじめ仮想サーバ起動部24は、プールサーバ5上に性能計測用仮想サーバ300を起動している。ここで性能計測用仮想サーバ300(VM51~VM5a)のように複数起動してもよい。
 移動先サーバ200には、複数の業務用仮想サーバ216(VM41~VM4k)を起動している。クライアント処理もしくはジョブをスケジュール化された処理により、負荷を発生し、移動先サーバ200のリソースを消費しているものとする。ここで、業務用仮想サーバ216(VM41~VM4k、VM61~VM6k、・・・、VM71~VM7k)のように複数起動してもよい。また、ここで、運用者は空資源取得指示を、操作部(不図示)を利用して実施するものとし、性能情報取得指示部21が指示を受け付ける。また、各リソース使用量の最大キャパシティ自体は一般的なベンチマーク結果等の結果より判明していることとする。
 まず、管理サーバ8(図9)において、性能情報取得指示部21(図9)が、運用者からの空資源取得指示を受け付けると、性能情報取得指示部21(図9)が空資源取得指示部23(図9)に対して空資源取得指示を行う(図11のステップS601)。
 この空資源取得指示に呼応して、空資源取得指示部23(図9)が、仮想サーバ移動部25(図9)に対して、プールサーバ5上の性能計測用仮想サーバ300(図9)を利用者が指定した移動先サーバ200(図9)に移動させるように指示する。なお、利用者が指定しなかった移動先サーバ200に対して計測は行わない。指示に従い、性能計測用仮想サーバ300(図9)がプールサーバ5(図9)から移動先サーバ200(図9)に移動される(図11のステップS103)。
 そして、空資源取得指示部23(図9)が、性能計測用仮想サーバ300(図9)に対して、情報送信部26(図9)を利用して性能情報計測指示を出す(図9のステップS107)。なお、性能計測用仮想サーバ300(図9)における性能計測処理の詳細については、後述する。
 性能計測用仮想サーバ300(図9)における性能計測処理(図11のステップS603)が終了すると、管理サーバ8では、それぞれの移動先サーバ200(図9)上の性能計測用仮想サーバ300(図9)から情報受信部27(図9)によって処理能力指標の受信を行う。そして、計測対象となるすべての移動先サーバ200で計測した処理能力指標を受信し、性能情報記憶部20(図9)に記憶する(図11のステップS111)。
 情報比較部28(図9)が、性能情報記憶部20(図9)にある移動先サーバ200(図9)で計測した処理能力指標を取得する。そして、情報比較部28は、さらに複数の移動先サーバ200(SV31~SV3b)(図9)に対して計測処理を行った場合には、移動先サーバ200毎に処理能力指標の大きさを比較できるように表示部(不図示)などに提示する(図11のステップS605)。これにより、運用者は、移動先サーバ200(SV31~SV3b)にそれぞれリソースの空きがあるかを、処理能力指標の大きさで判断することが可能となる。
 本実施形態において、管理サーバ8は、複数の移動先候補となる移動先サーバ200上で、性能計測用仮想サーバ300を順次稼働させて、検証対象の移動先サーバ200として、見積部(負荷調整部111)により得られた処理能力指標に基づいて、移動先サーバ200を選択する選択部(不図示)を備えることができる。上記実施形態と同様な提示部により表示部(不図示)に提示された処理能力指標を参照して、運用者は操作部(不図示)を利用して移動先サーバ200を選択する指示を行うことができる。あるいは、処理能力指標に条件を設け、条件を満たす移動先候補を、移動先サーバ200として自動的に選択する構成としてもよい。
 以下、本実施形態の性能計測用仮想サーバ300における性能計測処理について説明する。本実施形態の性能計測用仮想サーバ300における性能計測処理は、はじめに上記実施形態の性能計測用仮想サーバ100(図3)と同様な図5の依存関係分析処理を開始する。図5のステップS201~ステップS213、およびステップS221を実行し、リソース間の依存関係の分析を行う。終了したら、上記依存関係分析処理で得られた依存関係に基づいて、図12の負荷見積処理が開始される。図12は、本実施形態の性能計測用仮想サーバ300における性能計測処理の負荷見積処理の手順の一例を示すフローチャートである。上述したように、本実施形態の性能計測プログラムをコンピュータが以下に示す手順を実行することで、本実施形態の性能計測用仮想サーバ300の機能が実現されることとなる。以下、図10および図12を用いて説明する。
 図12の負荷見積もり処理は、図6と同様なステップS301~ステップS305、ステップS309、ステップS317、およびステップS319を有し、さらに、ステップS701~ステップS711、およびステップS721を有する。
 まず、計測指示部115(図10)が、負荷発生部107(図10)に対して依存情報記憶部127(図10)に記憶された依存度数の数値順(降順)で負荷をかけるように負荷発生指示を行う(図12のステップS301)。この理由は依存度数の大きいリソースから順番に負荷をかけていくと、依存度数の小さい別のリソースの負荷をかけた時に、それまでに依存した負荷を吸収しながら目標の負荷を発生することができるためである。昇順にすると、後々目標の負荷を超過してしまうからである。なお、発生させる負荷の強さを処理能力指標と定義し、図14のように一定期間内に負荷発生と休みを交互に繰り返す方式とし、出力されるリソース使用量を調整できる。
 そして、負荷発生部107(図10)が、図13の設定情報130で指定されている各リソースフラグを参照し、計測を実施するリソースにて、負荷を発生させる(図12のステップS303)。初回の場合は設定情報130に設定されている初回処理能力指標を元にリソースの負荷を発生する。また、2回目以降は後述の処理で更新した処理能力指標を元にリソースの負荷を発生する。計測を実施しないリソースに対しては何も行わない。ここでは、負荷発生部107に対して処理能力指標を入力すると、性能計測用仮想サーバ100の負荷を発生する。
 ここで、図12のステップS303において、図13に示される設定情報130のように、負荷発生部107がマルチプロセッサ情報からそのコア数に応じたプロセス数を起動し、複数のプロセスが同時に負荷を発生させることができる。すなわち、負荷発生部107は、負荷の発生のプロセスまたはスレッドを、複数プロセスまたはスレッドとして実行する。そして、見積部(負荷調整部111)は、マルチプロセッサの環境下における仮想サーバの処理能力指標を見積もることができる。
 マルチプロセッサの場合、CPUリソースに関して、性能計測用プログラムを実行する場合、1CPU当り1プロセスが割り当てられる。そのため、2つのCPU上で計測した場合、各サーバ(移動元サーバ7または移動先サーバ9)ではCPU自体が最大50%までしか使用されない。計測対象のサーバ(負荷調整フェーズでは移動元サーバ7、負荷再現フェーズでは移動先サーバ9)の環境内にマルチCPUのサーバが存在する場合、この処理を考慮することにより、CPUリソースを最大限使用することが可能となる。その結果、シングルまたはマルチの場合でも同じように処理能力指標で比較することが可能になる。
 ここで、リソースはCPU、メモリ、NW、HDDが該当し、リソース使用量あるいは使用率として算出されたものとする。使用率は一定期間内の物理サーバ、仮想サーバのリソース使用量から分かる。たとえばNWは一定期間に秒間当りのNWの入出力とスリープの処理を交互に入れることでCPUと同じく発生する負荷を制御することができる。HDDは一定期間に秒間当りの読み書きとスリープの処理を入れることでCPUと同じく発生する負荷を制御することができる。リソースはこれらに限定せずこれ以外に依存するリソースもあれば計測対象とする。
 図12のステップS303~ステップS317と並行して、情報受信部103(図10)が、移動先サーバ200(図9)上の管理エージェント210(図9)の負荷情報通知部214(図9)から定期的にリソース使用量を、通信網3(図9)を介して受信し、負荷情報記憶部117(図10)に記憶する。移動先サーバ200(図9)では、管理エージェント210(図9)の負荷情報収集部212(図9)が、移動先サーバ200(図9)、移動先サーバ200上で稼働している各性能計測用仮想サーバ300(図9)、および業務用仮想サーバ216(図9)のリソース使用量を取得したものを性能計測用仮想サーバ300(図10)の情報受信部103(図10)に対して通信網3(図9)を介して定期的に送信するものとする(図12のステップS721)。
 そして、負荷判定部105(図10)が、計測対象のリソースの負荷が安定したか否かを判定する(図12のステップS304)。たとえば、まず、負荷判定部105(図10)が、負荷情報記憶部117(図10)の計測対象のリソースのリソース使用量(図12のステップS721で定期的に更新される)が更新されたことを確認する。更新されていなければ、図12のステップS303へ戻る。更新されたリソース使用量が存在し、かつ、図13の設定情報130で設定されている読み飛ばし回数だけ読み飛ばしたら、負荷が安定したと判断して(図12のステップS304のYES)、負荷判定部105(図10)が、更新されたリソース使用量を採用する。回数に達しない場合はまだ安定していないと判断し(図12のステップS304のNO)、図12のステップS303に戻る。
 負荷判定部105(図10)が、性能計測用仮想サーバ300の最新とその前のリソース使用量を比較し、図13の設定情報130の初回調整振れ幅の範囲内に入っているかどうかを判定し、範囲に入っている場合、図13の設定情報130の継続回数分行えたか判定を行う(図12のステップS305)。条件を満たしていない場合(図12のステップS305のNO)、図12のステップS303に戻る。
 条件を満たしている場合(図12のステップS305のYES)、負荷調整部111(図10)が、初回の場合は、図13の設定情報130の初回処理能力指標を元にし、2回目以降は更新した処理能力指標と性能計測用仮想サーバ300のリソース使用量を対応付ける。ここでは、図13の設定情報130の基準になるリソース使用量となるように処理能力指標を調整する。以下の式(4)を利用する(図12のステップS701)。
 式(4)は、上述した本実施形態の負荷調整または再現フェーズにおいて、利用する数式を定義したものである。
 初回の処理能力指標(NUM_FST)で出力した性能計測用仮想サーバ300の負荷情報(P_AVM)から基準になるリソース使用量(P_BSE)となるように、基準になる処理能力指標(NUM_BSE)となるように調整したものを定義したものである。
 NUM_BSE=NUM_FST×(P_BSE/P_AVM)  ・・・式(4)
 負荷発生部107(図10)が、処理能力指標を元に性能計測用仮想サーバ300のリソースの負荷を発生させる(図12のステップS309)。このとき、負荷発生部107に対して処理能力指標を入力すると、性能計測用仮想サーバ100の負荷を発生する。
 そして、負荷判定部105(図10)が、負荷情報記憶部117(図10)のリソース使用量が更新されたことを認知して、かつ、図13の設定情報130の継続回数だけ計測を実施した場合(図12のステップS703のYES)、リソース使用量を採用する。更新されたリソース使用量が負荷情報記憶部117に存在しない、または継続回数に達しない場合は(図6のステップS703のNO)、図12のステップS701に戻る。
 負荷判定部105(図10)が、基準になるリソース使用量にするために処理能力指標を調整した回数、つまり図13の設定情報130に設定されている最大調整回数を満たすかどうか判定する(図12のステップS705)。最大調整回数を満たしていれば(図12のステップS705のYES)、エラー内容を結果に含めて管理サーバ8(図9)に対して通信網3(図1)を介して送信し、図11のステップS111に戻る(図12のステップS319)。
 そして、図12のステップS705の判定がNOの場合、負荷判定部105(図10)が、処理能力指標と、性能計測用仮想サーバ300のリソース使用量を対応付け、図13の設定情報130に設定されている基準になるリソース使用量の許容範囲内に入っているかどうかを判定する(図12のステップS707)。条件を満たしていれば(図12のステップS707のYES)、次の図12のステップS709に進む。条件を満たしていなければ(図12のステップS707のNO)、図12のステップS701に戻る。
 中間情報記憶部125(図10)の計測対象データのリソース使用量を参照し、空となるリソース使用量から計測対象の依存リソース使用量を差し引いた分のリソース使用量分の負荷を発生する処理能力指標を基準となる処理能力指標から以下の式(5)を利用して見積もる。参照して計測対象データのリソース使用量が存在しなければ、中間情報記憶部125のリソース使用量は利用しない。
 以下の式(5)は、上述した本実施形態の負荷調整または再現フェーズにおいて、利用する数式を定義したものである。
 基準になる処理能力指標を用いて負荷を出力後、ホストのリソース使用量(P_SV)、性能計測仮想サーバ以外の仮想サーバのリソース使用量(ΣP_VM*)、P_SV、P_VMを含めたサーバ全体のリソース使用量(P_ALL)から現時点の性能計測仮想サーバのリソース使用量(P_AVM)を引いたものが空きキャパシティ分のリソース使用量(P_CAP)であることを以下の式(5)で定義する。ここで、*アスタリスクは、関連する全てのサーバを意味する。
 P_CAP=P_ALL-{(P_SV+ΣP_VM*)-P_AVM}  ・・・式(5)
 図17に、図15に示した依存度数の高い順(HDDI/O>NWI/O>CPU=メモリ)とした負荷の依存特性から各リソース負荷の見積もり方法を示した一例を示す。目標負荷は業務用仮想サーバ216(図10)の負荷を除いた移動先サーバ200の空リソースを使いきった場合のリソース使用量である。なお、図17では、HDDI/Oによって発生する負荷は、太い破線で囲まれた部分であり、NWI/Oによって発生する負荷は、太い一点鎖線で囲まれた部分であることを示している。
 図17(a)に示すように、HDDI/Oの負荷を発生させた場合には特に依存関係は存在しないが、目標の負荷から業務用仮想サーバが利用している部分(L1)のリソース使用量を差し引いた部分(L2)のリソース使用量に相当する処理能力指標を見積もる。
 ここで、HDDI/O_Mを物理サーバ上の最大キャパシティ分のHDDI/O使用量(L1+L2)とし、HDDI/O_VMを業務用仮想サーバによって発生するHDDI/O使用量(L1)とすると、物理サーバ上の空キャパシティ分のHDDI/O使用量(L2)のHDDI/O_Eは、以下の式(6)で示される。
 HDDI/O_E=HDDI/O_M-HDDI/O_VM  ・・・式(6)
 図17(b)に示すように、NWI/Oの負荷を見積もる場合にはHDDI/Oの負荷を発生させた場合にNWI/Oでも負荷(L4)が発生する。そのため、目標の負荷から、(L4)の部分と、業務用仮想サーバが利用している部分(L3)のリソース使用量と差し引いた部分(L5)のリソース使用量に相当する処理能力指標を見積もる。
 ここで、NWI/O_Mを物理サーバ上の最大キャパシティ分のNWI/O使用量(L3+L4+L5)とし、NWI/O_HDDI/OをHDDI/Oの負荷にて発生するNWI/O使用量(L4)とし、NWI/O_VMを業務用仮想サーバによって発生するNWI/O使用量(L3)とする。このとき、物理サーバ上の空キャパシティ分のNWI/O使用量(L5)のNWI/O_Eは、以下の式(7)で示される。
 NWI/O_E=NWI/O_M-{NWI/O_HDDI/O+NWI/O_VM}  ・・・式(7)
 図17(c)に示すように、CPUの負荷を見積もる場合にはHDDI/Oの負荷を発生させた場合のCPU負荷(L9)及び、NWI/Oの負荷を発生させた場合のCPU負荷(L8)が発生する。したがって、目標の負荷から、(L9)と(L8)の部分と、業務用仮想サーバが利用している部分(L7)のリソース使用量と差し引いた部分(L10)のリソース使用量に相当する処理能力指標を見積もる。
 ここで、CPU_Mを物理サーバ上の最大キャパシティ分のCPU使用量(L7+L8+L9+L10)とし、CPU_HDDI/OをHDDI/Oの負荷にて発生するCPU使用量(L9)とし、CPU_NWI/OをNWI/Oの負荷にて発生するCPU使用量(L8)とし、CPU_VMを業務用仮想サーバによって発生するCPU使用量(L7)とする。このとき、物理サーバ上の空キャパシティ分のCPU使用量(L10)のCPU_Eは、以下の式(8)で示される。
 CPU_E=CPU_M-{CPU_NWI/O+CPU_HDDI/O+CPU_VM}  ・・・式(8)
 以上より、目標のリソース使用量に対する処理能力指標を見積もることができる(図12のステップS709)。
 負荷調整部111(図10)が、計測対象の処理能力指標を性能情報記憶部119(図10)に記憶し、その時点の計測対象以外のリソース使用量を中間情報記憶部125(図10)に記憶する。まだ負荷を発生していない計測対象のリソースがある場合には(図12のステップS317のYES)、図12のステップS303に戻り、対象の計測を停止して、別のリソースを計測対象とする。まだ負荷を発生していない計測対象のリソースがなければ(図12のステップS317のNO)、次の図12のステップS711に進む。このとき、図12のステップS721におけるリソース使用量の受信処理も停止し、図12のステップS711に進む。
 空資源調整部129が、上述したように空きキャパシティ分に相当するリソース使用量を算出し、それに対応した空きキャパシティ分に相当する処理能力指標を見積もり、性能情報記憶部119(図10)に記憶する(図12のステップS711)。
 そして、情報送信部101を使用して管理サーバ8に対して性能情報記憶部119(図10)に記憶した処理能力指標を結果送信する(図12のステップS319)。
 以上で、性能計測用仮想サーバ300における負荷見積り処理が終了し、図11のステップS111に戻る。
 以上説明したように、本実施形態の情報処理システム2によれば、上記実施形態の情報処理システム1と同様な効果を奏するとともに、計測対象サーバ上にて、あるリソースに負荷をかけた際にI/O処理等で別のリソースに負荷がかかる依存分析を行う(これらを依存負荷と定義する)。この結果を利用して目標負荷から依存負荷を引いたリソース使用量分の負荷を見積もり、さらに計測プログラムでこの差し引いたリソース使用量分の負荷を発生できる処理能力指標となるように調整することで、目標に近い精度で空きキャパシティ分に相当するリソース使用量を見積もることが可能になる。このようにリソース間の依存関係を分析することで、目標のリソース使用量に近い負荷を見積もることが可能になり、見積もり負荷の精度が向上する。
 以上、図面を参照して本発明の実施形態について述べたが、これらは本発明の例示であり、上記以外の様々な構成を採用することもできる。
 たとえば、以下の式(9)は、本発明で負荷調整及び再現手段に利用する数式を定義したものである。
 現時点の性能計測用仮想サーバの処理能力指標(NUM_BSE)、リソース使用量(P_AVM)、空きキャパシティ分のリソース使用量(P_CAP)、各計測対称の依存リソース使用量(P_DEP)から空きキャパシティ分の処理能力指標(NUM_CAP)を以下の式(9)で定義する。
 NUM_CAP=NUM_BSE×((P_CAP-ΣP_DEP)/P_AVM)  ・・・式(9)
 特許文献1に記載の物理マシン上では発生しない仮想マシンが利用するNWI/O、HDDI/OのI/Oオーバーヘッド特性を調べる。このオーバーヘッドを物理マシンが利用するアプリケーションのCPU使用率に上乗せしてサーバ統合後の仮想マシンのCPU使用率を見積もっている。I/O分の負荷を利用しているが、用途と見積もり方式が違うため本特許提案と内容が異なる。
 また、上記実施形態の性能計測用仮想サーバ100において、図5のステップS205では、負荷発生部107が、リソース自体をCPU、メモリ、NWI/O、HDDI/Oと想定しているが、それ以外にも他に依存関係にあるリソースを観測可能である。さらにそれらのリソースの負荷の調整が可能であるならば、上記に挙げたリソースに限らず、そのリソースの個数分だけ、繰り返せばよい。そして、性能計測用仮想サーバ100が、リソース間の依存分析を行い、処理能力指標を調整し、負荷を発生させ、目標となる負荷の処理能力指標を見積もることができる。
 この構成によれば、様々なリソースについて、本発明を適用できることとなる。
 また、上記実施形態の性能計測用仮想サーバ100において、図6のステップS303では、負荷発生部107が、リソース自体をCPU、メモリ、NWI/O、HDDI/Oと想定しているが、それ以外にも他に依存関係にあるリソースを観測可能である。さらにそれらのリソースの負荷の調整が可能であるならば、上記に挙げたリソースに限らず、そのリソースの個数分だけ、繰り返せばよい。そして、性能計測用仮想サーバ100が、リソース間の依存分析を行い、処理能力指標を調整し、負荷を発生させ、目標となる負荷の処理能力指標を見積もることができる。
 この構成によれば、様々なリソースについて、本発明を適用できることとなる。
 たとえば、上記実施形態の性能計測用仮想サーバ300において、図12のステップS303では、負荷発生部107が、リソース自体をCPU、メモリ、NWI/O、HDDI/Oと想定しているが、それ以外にも他に依存関係にあるリソースを観測可能である。さらにそれらのリソースの負荷の調整が可能であるならば、上記に挙げたリソースに限らず、そのリソースの個数分だけ、繰り返せばよい。そして、性能計測用仮想サーバ300が、リソース間の依存分析を行い、処理能力指標を調整し、負荷を発生させ、目標となる負荷の処理能力指標を見積もることができる。
 この構成によれば、様々なリソースについて、本発明を適用できることとなる。
 以上、実施形態を参照して本願発明を説明したが、本願発明は上記実施形態に限定されるものではない。本願発明の構成や詳細には、本願発明のスコープ内で当業者が理解し得る様々な変更をすることができる。
 この出願は、2010年2月26日に出願された日本出願特願2010-041476号を基礎とする優先権を主張し、その開示の全てをここに取り込む。

Claims (18)

  1.  物理サーバおよび前記物理サーバ上で稼働する仮想サーバの複数のリソースのリソース使用量を取得する取得手段と、
     計測対象リソースに負荷を発生させる負荷発生手段と、
     前記計測対象リソースに前記負荷をかけることで、前記計測対象リソースが依存しているリソースを求め、前記計測対象リソースが依存している前記リソースの数に基づいて、前記計測対象リソースの依存度数を算出する依存度数算出手段と、
     複数の前記リソースについて前記計測対象リソースとしてそれぞれ算出された前記依存度数が大きい順に前記リソースに順位付けする順位付け手段と、
     前記順位付け手段により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択し、前記負荷発生手段により順次負荷を発生させながら、前記計測対象リソースのリソース使用量の処理能力指標を調整する調整手段と、
    を備える制御装置。
  2.  請求項1に記載の制御装置において、
     前記負荷発生手段により前記負荷をかけている間に前記取得手段が取得した前記リソース使用量に基づいて、前記計測対象リソース以外のリソースの前記リソース使用量に増減があるかどうかを検出する検出手段と、
     前記検出手段により前記計測対象リソース以外のリソースの前記リソース使用量に増減が検出された場合、当該リソースは前記計測対象リソースが依存しているリソースであると判別する判別手段と、を備え、
     前記依存度数算出手段は、前記判別手段により前記計測対象リソースが依存していると判別された前記リソースの数を計数して前記依存度数を算出する制御装置。
  3.  請求項1または2に記載の制御装置において、
     前記物理サーバ上で稼働する少なくとも1つの仮想サーバの代わりに、前記制御装置の前記各手段を実現させるための性能計測用仮想サーバを移動元となる前記物理サーバ上で稼働させ、
     前記負荷発生手段が、前記移動元となる前記物理サーバ上で稼働する少なくとも1つの前記仮想サーバの代わりに、前記物理サーバ上で前記負荷を発生させ、
     前記取得手段が、前記物理サーバと、前記物理サーバ上で稼働させた前記性能計測用仮想サーバの複数の前記リソースの前記リソース使用量を定期的に取得し、
     前記調整手段が、前記処理能力指標を調整する制御装置。
  4.  請求項3に記載の制御装置において、
     前記調整手段が、前記取得手段が取得した各リソースの前記リソース使用量に基づいて、今回の前記計測対象リソース以外の前回までに前記負荷発生手段が負荷をかけた前記リソースの前記リソース使用量で、かつ、前記負荷発生手段が今回負荷をかけた前記計測対象リソースの前記リソース使用量を、予め設定された目標となる仮想サーバの前記計測対象リソースの前記リソース使用量から取り除いたリソース使用量、となるように前記処理能力指標を調整し、
     さらに、前記制御装置は、
     前記負荷発生手段が、前記調整手段により調整された前記処理能力指標に基づいて、前記順位付け手段により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記取得手段が取得した前記リソース使用量から前記目標となるリソース使用量の絶対値が許容範囲内に入っているか否かを判定する判定手段と、
     前記判定手段により前記許容範囲内に入っていると判定されたとき、前記取得手段が取得した前記リソース使用量から前記目標となるリソース使用量に対応する処理能力指標を見積もる見積手段と、を備える制御装置。
  5.  請求項3に記載の制御装置において、
     検証対象となる物理サーバ上に前記性能計測用仮想サーバを稼働させ、
     前記負荷発生手段が、前記順位付け手段により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、
     前記調整手段が、前記取得手段が取得した各リソースの前記リソース使用量に基づいて、今回の前記計測対象リソース以外の前回までに前記負荷発生手段が負荷をかけた前記リソースの前記リソース使用量で、かつ、前記負荷発生手段が今回負荷をかけた前記計測対象リソースの前記リソース使用量を、予め設定された目標となる物理サーバの空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように前記処理能力指標を調整し、
     さらに、前記制御装置は、
     前記調整手段により調整された前記処理能力指標に基づいて、前記負荷発生手段が、前記順位付け手段により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記取得手段が取得した前記リソース使用量から前記物理サーバの前記空キャパシティに相当する前記リソース使用量の絶対値が許容範囲内に入っているか否かを判定する判定手段と、
     前記判定手段により前記許容範囲内に入っていると判定されたとき、前記取得手段が取得した前記リソース使用量から前記物理サーバの前記空キャパシティに相当する前記リソース使用量に対応する処理能力指標を見積もる見積手段と、を備える制御装置。
  6.  請求項4または5に記載の制御装置において、
     前記負荷発生手段は、前記負荷の発生のプロセスまたはスレッドを、複数プロセスまたはスレッドとして実行し、
     前記見積手段は、マルチプロセッサの環境下における前記仮想サーバの前記処理能力指標を見積もる制御装置。
  7.  請求項4乃至6いずれかに記載の制御装置において、
     前記リソースは、CPU(Central Processing Unit)、メモリ、ネットワークI/O(Input/Output)、およびハードディスクドライブI/Oを含む制御装置。
  8.  請求項7に記載の制御装置において、
     前記リソース以外で負荷発生時に依存関係にあるリソースを観測可能で、さらに該リソースの負荷の調整が可能であるものに対し、前記性能計測用仮想サーバが、前記リソース間の依存分析を行い、前記処理能力指標を調整し、前記負荷を発生させ、目標となる負荷の処理能力指標を見積もる制御装置。
  9.  請求項4乃至8いずれかに記載の制御装置の前記性能計測用仮想サーバを、複数の移動先候補となる前記物理サーバ上で順次稼働させて、検証対象の物理サーバとして、前記見積手段により得られた前記処理能力指標を提示する提示手段を備える管理装置。
  10.  請求項9に記載の管理装置において、
     複数の前記移動先候補となる前記物理サーバ上で、前記性能計測用仮想サーバを順次稼働させて、前記検証対象の物理サーバとして、前記見積手段により得られた前記処理能力指標に基づいて、移動先の物理サーバを選択する選択手段を備える管理装置。
  11.  コンピュータに、
     物理サーバおよび前記物理サーバ上で稼働する仮想サーバの複数のリソースのリソース使用量を取得する手順と、
     計測対象リソースに負荷を発生させる手順と、
     前記計測対象リソースに前記負荷をかけることで、前記計測対象リソースが依存している前記リソースを求め、前記計測対象リソースが依存している前記リソースの数に基づいて、前記計測対象リソースの依存度数を算出する手順と、
     複数の前記リソースについて前記計測対象リソースとしてそれぞれ算出された前記依存度数が大きい順に前記リソースに順位付けする手順と、
     順位付けされた順に複数の前記リソースから前記計測対象リソースを選択し、順次負荷を発生させながら、前記計測対象リソースのリソース使用量の処理能力指標を調整する手順と、を実行させるプログラム。
  12.  請求項11に記載のプログラムにおいて、
     前記物理サーバ上で稼働する少なくとも1つの仮想サーバの代わりに、前記プログラムを含む性能計測用仮想サーバを移動元となる前記物理サーバ上で稼働させる手順と、
     前記移動元となる前記物理サーバ上で稼働する少なくとも1つの前記仮想サーバの代わりに、前記物理サーバ上で前記負荷を発生させる手順と、
     前記物理サーバと、前記物理サーバ上で稼働させた前記性能計測用仮想サーバの複数の前記リソースの前記リソース使用量を定期的に取得する手順と、
     前記処理能力指標を調整する手順と、をさらにコンピュータに実行させるプログラム。
  13.  請求項12に記載のプログラムにおいて、
     前記取得する手順で取得した各リソースの前記リソース使用量に基づいて、今回の前記計測対象リソース以外の前回までに前記負荷を発生する手順で負荷をかけた前記リソースの前記リソース使用量で、かつ、前記負荷を発生する手順で今回負荷をかけた前記計測対象リソースの前記リソース使用量を、予め設定された目標となる仮想サーバの前記計測対象リソースの前記リソース使用量から取り除いたリソース使用量、となるように前記処理能力指標を調整する手順と、
     前記負荷を発生する手順において、前記調整する手順により調整された前記処理能力指標に基づいて、前記順位付けする手順により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記取得する手順で取得した前記リソース使用量から前記目標となるリソース使用量の絶対値が許容範囲内に入っているか否かを判定する手順と、
     前記判定する手順により前記許容範囲内に入っていると判定されたとき、前記取得する手順で取得した前記リソース使用量から前記目標となるリソース使用量に対応する処理能力指標を見積もる手順と、をさらにコンピュータに実行させるプログラム。
  14.  請求項12に記載のプログラムにおいて、
     検証対象となる物理サーバ上に前記性能計測用仮想サーバを稼働させる手順と、
     前記負荷を発生する手順において、前記順位付けする手順により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記取得する手順で取得した各リソースの前記リソース使用量に基づいて、今回の前記計測対象リソース以外の前回までに前記負荷を発生する手順で負荷をかけた前記リソースの前記リソース使用量で、かつ、前記負荷を発生する手順で今回負荷をかけた前記計測対象リソースの前記リソース使用量を、予め設定された目標となる物理サーバの空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように前記処理能力指標を調整する手順と、
     前記調整する手順により調整された前記処理能力指標に基づいて、前記負荷を発生する手順において、前記順位付けする手順により順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記取得する手順で取得した前記リソース使用量から前記物理サーバの前記空キャパシティに相当する前記リソース使用量の絶対値が許容範囲内に入っているか否かを判定する手順と、
     前記判定する手順により前記許容範囲内に入っていると判定されたとき、前記取得する手順で取得した前記リソース使用量から前記物理サーバの前記空キャパシティに相当する前記リソース使用量に対応する処理能力指標を見積もる手順と、をさらにコンピュータに実行させるプログラム。
  15.  物理サーバおよび前記物理サーバ上で稼働する仮想サーバの複数のリソースの負荷を計測する制御装置のデータ処理方法であって、前記制御装置が、
     前記物理サーバおよび前記物理サーバ上で稼働する前記仮想サーバの複数の前記リソースのリソース使用量を取得し、
     計測対象リソースに負荷を発生させ、
     前記計測対象リソースに前記負荷をかけることで、前記計測対象リソースが依存しているリソースを求め、前記計測対象リソースが依存している前記リソースの数に基づいて、前記計測対象リソースの依存度数を算出し、
     複数の前記リソースについて前記計測対象リソースとしてそれぞれ算出された前記依存度数が大きい順に前記リソースに順位付けし、
     順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、前記計測対象リソースのリソース使用量の処理能力指標を調整する制御装置のデータ処理方法。
  16.  請求項15に記載の制御装置のデータ処理方法において、
     前記物理サーバ上で稼働する少なくとも1つの仮想サーバの代わりに、性能計測用仮想サーバを移動元となる前記物理サーバ上で稼働させることで前記制御装置を実現し、
     前記制御装置が、
     前記移動元となる前記物理サーバ上で稼働する少なくとも1つの前記仮想サーバの代わりに、前記物理サーバ上で前記負荷を発生させ、
     前記物理サーバと、前記物理サーバ上で稼働させた前記性能計測用仮想サーバの複数の前記リソースの前記リソース使用量を定期的に取得し、
     前記処理能力指標を調整する制御装置のデータ処理方法。
  17.  請求項16に記載の制御装置のデータ処理方法において、
     前記制御装置が、
     取得した各リソースの前記リソース使用量に基づいて、今回の前記計測対象リソース以外の前回までに負荷をかけた前記リソースの前記リソース使用量で、かつ、今回負荷をかけた前記計測対象リソースの前記リソース使用量を、予め設定された目標となる仮想サーバの前記計測対象リソースの前記リソース使用量から取り除いたリソース使用量、となるように前記処理能力指標を調整し、
     調整された前記処理能力指標に基づいて、順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、
     取得した前記リソース使用量から前記目標となるリソース使用量の絶対値が許容範囲内に入っているか否かを判定し、
     前記許容範囲内に入っていると判定されたとき、取得した前記リソース使用量から前記目標となるリソース使用量に対応する処理能力指標を見積もる制御装置のデータ処理方法。
  18.  請求項16に記載の制御装置のデータ処理方法において、
     検証対象となる物理サーバ上に前記性能計測用仮想サーバを稼働させることで前記制御装置を実現し、
     前記制御装置が、
     順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、
     取得した各リソースの前記リソース使用量に基づいて、今回の前記計測対象リソース以外の前回までに負荷をかけた前記リソースの前記リソース使用量で、かつ、今回負荷をかけた前記計測対象リソースの前記リソース使用量を、予め設定された目標となる物理サーバの空キャパシティに相当するリソース使用量から取り除いたリソース使用量、となるように前記処理能力指標を調整し、
     調整された前記処理能力指標に基づいて、順位付けされた順に複数の前記リソースから前記計測対象リソースを選択して、順次負荷を発生させながら、取得した前記リソース使用量から前記物理サーバの前記空キャパシティに相当する前記リソース使用量の絶対値が許容範囲内に入っているか否かを判定し、
     前記許容範囲内に入っていると判定されたとき、取得した前記リソース使用量から前記物理サーバの前記空キャパシティに相当する前記リソース使用量に対応する処理能力指標を見積もる制御装置のデータ処理方法。
PCT/JP2011/001078 2010-02-26 2011-02-24 制御装置、管理装置、制御装置のデータ処理方法、およびプログラム WO2011105091A1 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US13/581,464 US20120324471A1 (en) 2010-02-26 2011-02-24 Control device, management device, data processing method of control device, and program
JP2012501685A JPWO2011105091A1 (ja) 2010-02-26 2011-02-24 制御装置、管理装置、制御装置のデータ処理方法、およびプログラム

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2010041476 2010-02-26
JP2010-041476 2010-02-26

Publications (1)

Publication Number Publication Date
WO2011105091A1 true WO2011105091A1 (ja) 2011-09-01

Family

ID=44506518

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2011/001078 WO2011105091A1 (ja) 2010-02-26 2011-02-24 制御装置、管理装置、制御装置のデータ処理方法、およびプログラム

Country Status (3)

Country Link
US (1) US20120324471A1 (ja)
JP (1) JPWO2011105091A1 (ja)
WO (1) WO2011105091A1 (ja)

Cited By (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014085809A (ja) * 2012-10-23 2014-05-12 Nec Corp 運用管理装置、運用管理方法、及び、プログラム
EP2824571A4 (en) * 2012-03-08 2015-11-18 Nec Corp DEVICE FOR MANAGING VIRTUAL COMPUTERS AND METHOD FOR MANAGING VIRTUAL COMPUTERS
JP2016040651A (ja) * 2014-08-12 2016-03-24 富士通株式会社 情報処理装置、試験方法および試験制御プログラム
US9602729B2 (en) 2015-06-07 2017-03-21 Apple Inc. Devices and methods for capturing and interacting with enhanced digital images
US9612741B2 (en) 2012-05-09 2017-04-04 Apple Inc. Device, method, and graphical user interface for displaying additional information in response to a user contact
US9619076B2 (en) 2012-05-09 2017-04-11 Apple Inc. Device, method, and graphical user interface for transitioning between display states in response to a gesture
US9632664B2 (en) 2015-03-08 2017-04-25 Apple Inc. Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US9639184B2 (en) 2015-03-19 2017-05-02 Apple Inc. Touch input cursor manipulation
US9645732B2 (en) 2015-03-08 2017-05-09 Apple Inc. Devices, methods, and graphical user interfaces for displaying and using menus
US9674426B2 (en) 2015-06-07 2017-06-06 Apple Inc. Devices and methods for capturing and interacting with enhanced digital images
US9891811B2 (en) 2015-06-07 2018-02-13 Apple Inc. Devices and methods for navigating between user interfaces
US9996233B2 (en) 2012-12-29 2018-06-12 Apple Inc. Device, method, and graphical user interface for navigating user interface hierarchies
US10067653B2 (en) 2015-04-01 2018-09-04 Apple Inc. Devices and methods for processing touch inputs based on their intensities
US10073615B2 (en) 2012-05-09 2018-09-11 Apple Inc. Device, method, and graphical user interface for displaying user interface objects corresponding to an application
US10175879B2 (en) 2012-12-29 2019-01-08 Apple Inc. Device, method, and graphical user interface for zooming a user interface while performing a drag operation
US10235035B2 (en) 2015-08-10 2019-03-19 Apple Inc. Devices, methods, and graphical user interfaces for content navigation and manipulation
US10248308B2 (en) 2015-08-10 2019-04-02 Apple Inc. Devices, methods, and graphical user interfaces for manipulating user interfaces with physical gestures
US10275087B1 (en) 2011-08-05 2019-04-30 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10346030B2 (en) 2015-06-07 2019-07-09 Apple Inc. Devices and methods for navigating between user interfaces
US10416800B2 (en) 2015-08-10 2019-09-17 Apple Inc. Devices, methods, and graphical user interfaces for adjusting user interface objects
CN112950447A (zh) * 2019-12-10 2021-06-11 浙江宇视科技有限公司 资源调度方法、装置、服务器及存储介质

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140032642A1 (en) * 2012-07-30 2014-01-30 International Business Machines Corporation Controlling server response based on client performance
US20140379725A1 (en) * 2013-06-19 2014-12-25 Microsoft Corporation On demand parallelism for columnstore index build
CN103997544B (zh) * 2014-06-12 2017-08-25 网易(杭州)网络有限公司 一种资源下载的方法和设备
US9794193B2 (en) * 2015-01-30 2017-10-17 Gigamon Inc. Software defined visibility fabric
US9894150B2 (en) 2015-09-30 2018-02-13 Spirent Communications, Inc. Accurate generation of multiple dimensions of computer load
CN106055408B (zh) * 2016-05-31 2017-11-24 广东欧珀移动通信有限公司 一种应用控制方法及移动终端
CN109495351B (zh) * 2018-12-26 2021-01-12 网易(杭州)网络有限公司 一种确定服务器系统数据处理能力方法、装置、电子设备及存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001306365A (ja) * 2000-04-27 2001-11-02 Mitsubishi Electric Corp 負荷測定方式
JP2007323245A (ja) * 2006-05-31 2007-12-13 Nec Corp 計算機システムおよび性能計測方法ならびに管理サーバ装置
WO2008102739A1 (ja) * 2007-02-23 2008-08-28 Nec Corporation 仮想サーバシステム及び物理サーバ選択方法
JP2009123174A (ja) * 2007-11-19 2009-06-04 Mitsubishi Electric Corp 仮想マシンサーバサイジング装置及び仮想マシンサーバサイジング方法及び仮想マシンサーバサイジングプログラム
JP2010033292A (ja) * 2008-07-28 2010-02-12 Nippon Telegraph & Telephone West Corp 仮想サーバリソース調整システム、リソース調整装置、仮想サーバリソース調整方法、及び、コンピュータプログラム

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7603448B2 (en) * 2000-12-15 2009-10-13 Wind River Systems, Inc. System and method for managing client processes

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001306365A (ja) * 2000-04-27 2001-11-02 Mitsubishi Electric Corp 負荷測定方式
JP2007323245A (ja) * 2006-05-31 2007-12-13 Nec Corp 計算機システムおよび性能計測方法ならびに管理サーバ装置
WO2008102739A1 (ja) * 2007-02-23 2008-08-28 Nec Corporation 仮想サーバシステム及び物理サーバ選択方法
JP2009123174A (ja) * 2007-11-19 2009-06-04 Mitsubishi Electric Corp 仮想マシンサーバサイジング装置及び仮想マシンサーバサイジング方法及び仮想マシンサーバサイジングプログラム
JP2010033292A (ja) * 2008-07-28 2010-02-12 Nippon Telegraph & Telephone West Corp 仮想サーバリソース調整システム、リソース調整装置、仮想サーバリソース調整方法、及び、コンピュータプログラム

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
MITSURU YANAGISAWA: "A method for estimated performance of virtual machines by common index and its evaluation", IPSJ SIG NOTES, vol. 2009, no. 6, 21 January 2009 (2009-01-21), pages 27 - 33 *

Cited By (35)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10345961B1 (en) 2011-08-05 2019-07-09 P4tents1, LLC Devices and methods for navigating between user interfaces
US10365758B1 (en) 2011-08-05 2019-07-30 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10338736B1 (en) 2011-08-05 2019-07-02 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10649571B1 (en) 2011-08-05 2020-05-12 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10386960B1 (en) 2011-08-05 2019-08-20 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10656752B1 (en) 2011-08-05 2020-05-19 P4tents1, LLC Gesture-equipped touch screen system, method, and computer program product
US10664097B1 (en) 2011-08-05 2020-05-26 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10275087B1 (en) 2011-08-05 2019-04-30 P4tents1, LLC Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10540039B1 (en) 2011-08-05 2020-01-21 P4tents1, LLC Devices and methods for navigating between user interface
EP2824571A4 (en) * 2012-03-08 2015-11-18 Nec Corp DEVICE FOR MANAGING VIRTUAL COMPUTERS AND METHOD FOR MANAGING VIRTUAL COMPUTERS
US9612741B2 (en) 2012-05-09 2017-04-04 Apple Inc. Device, method, and graphical user interface for displaying additional information in response to a user contact
US9619076B2 (en) 2012-05-09 2017-04-11 Apple Inc. Device, method, and graphical user interface for transitioning between display states in response to a gesture
US10908808B2 (en) 2012-05-09 2021-02-02 Apple Inc. Device, method, and graphical user interface for displaying additional information in response to a user contact
US10073615B2 (en) 2012-05-09 2018-09-11 Apple Inc. Device, method, and graphical user interface for displaying user interface objects corresponding to an application
US10114546B2 (en) 2012-05-09 2018-10-30 Apple Inc. Device, method, and graphical user interface for displaying user interface objects corresponding to an application
JP2014085809A (ja) * 2012-10-23 2014-05-12 Nec Corp 運用管理装置、運用管理方法、及び、プログラム
US9996233B2 (en) 2012-12-29 2018-06-12 Apple Inc. Device, method, and graphical user interface for navigating user interface hierarchies
US10175879B2 (en) 2012-12-29 2019-01-08 Apple Inc. Device, method, and graphical user interface for zooming a user interface while performing a drag operation
JP2016040651A (ja) * 2014-08-12 2016-03-24 富士通株式会社 情報処理装置、試験方法および試験制御プログラム
US9645732B2 (en) 2015-03-08 2017-05-09 Apple Inc. Devices, methods, and graphical user interfaces for displaying and using menus
US9645709B2 (en) 2015-03-08 2017-05-09 Apple Inc. Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US10268342B2 (en) 2015-03-08 2019-04-23 Apple Inc. Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US9632664B2 (en) 2015-03-08 2017-04-25 Apple Inc. Devices, methods, and graphical user interfaces for manipulating user interface objects with visual and/or haptic feedback
US9639184B2 (en) 2015-03-19 2017-05-02 Apple Inc. Touch input cursor manipulation
US10152208B2 (en) 2015-04-01 2018-12-11 Apple Inc. Devices and methods for processing touch inputs based on their intensities
US10067653B2 (en) 2015-04-01 2018-09-04 Apple Inc. Devices and methods for processing touch inputs based on their intensities
US10346030B2 (en) 2015-06-07 2019-07-09 Apple Inc. Devices and methods for navigating between user interfaces
US10303354B2 (en) 2015-06-07 2019-05-28 Apple Inc. Devices and methods for navigating between user interfaces
US9891811B2 (en) 2015-06-07 2018-02-13 Apple Inc. Devices and methods for navigating between user interfaces
US9674426B2 (en) 2015-06-07 2017-06-06 Apple Inc. Devices and methods for capturing and interacting with enhanced digital images
US9602729B2 (en) 2015-06-07 2017-03-21 Apple Inc. Devices and methods for capturing and interacting with enhanced digital images
US10248308B2 (en) 2015-08-10 2019-04-02 Apple Inc. Devices, methods, and graphical user interfaces for manipulating user interfaces with physical gestures
US10416800B2 (en) 2015-08-10 2019-09-17 Apple Inc. Devices, methods, and graphical user interfaces for adjusting user interface objects
US10235035B2 (en) 2015-08-10 2019-03-19 Apple Inc. Devices, methods, and graphical user interfaces for content navigation and manipulation
CN112950447A (zh) * 2019-12-10 2021-06-11 浙江宇视科技有限公司 资源调度方法、装置、服务器及存储介质

Also Published As

Publication number Publication date
JPWO2011105091A1 (ja) 2013-06-20
US20120324471A1 (en) 2012-12-20

Similar Documents

Publication Publication Date Title
WO2011105091A1 (ja) 制御装置、管理装置、制御装置のデータ処理方法、およびプログラム
JP4839361B2 (ja) 仮想マシン移動管理サーバおよび仮想マシン移動方法
JP5983728B2 (ja) 仮想マシン管理装置及び仮想マシン管理方法
JP6168576B2 (ja) 仮想マシンマイグレーション管理の方法、装置およびシステム
US7864679B2 (en) System utilization rate managing apparatus and system utilization rate managing method to be employed for it, and its program
US8935501B2 (en) Apparatus, method, and recording medium storing a program for selecting a destination storage based on a buffer size
US10282272B2 (en) Operation management apparatus and operation management method
WO2015121925A1 (ja) システム管理方法
JP5577453B2 (ja) 仮想計算機のマイグレーション評価方法及び仮想計算機システム
US20160006640A1 (en) Management computer, allocation management method, and non-transitory computer readable storage medium
US9910709B2 (en) Allocation control method and apparatus
JP2012198843A (ja) 仮想サーバ調整システム、仮想サーバ制御装置及びプログラム
Shen et al. A resource-efficient predictive resource provisioning system in cloud systems
US9195515B1 (en) Method and system for process load balancing
JP5879117B2 (ja) 情報処理システムおよび運用管理方法
US20220229689A1 (en) Virtualization platform control device, virtualization platform control method, and virtualization platform control program
JP5751372B2 (ja) データ処理システム、そのコンピュータプログラムおよびデータ処理方法
De Grande et al. Measuring communication delay for dynamic balancing strategies of distributed virtual simulations
JP5056346B2 (ja) 情報処理装置、情報処理システム、仮想サーバの移動処理の制御方法、及び、プログラム
JP2014174609A (ja) ハードウェア構成見積システム、ハードウェア構成見積方法及びハードウェア構成見積プログラム
US10942780B1 (en) Resource use and operational load of performing computing and storage tasks in distributed systems
US20170201535A1 (en) Estimation device and estimation method
JP5413210B2 (ja) 情報処理システム、情報処理装置、情報処理方法およびプログラム
JP2023183342A (ja) ジョブスケジューラおよびジョブスケジューリング方法
CN114968493A (zh) 虚拟机调度方法、装置、计算机可读介质及电子设备

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 11747058

Country of ref document: EP

Kind code of ref document: A1

WWE Wipo information: entry into national phase

Ref document number: 2012501685

Country of ref document: JP

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 13581464

Country of ref document: US

122 Ep: pct application non-entry in european phase

Ref document number: 11747058

Country of ref document: EP

Kind code of ref document: A1