JP3861087B2 - The virtual machine management system and program - Google Patents

The virtual machine management system and program Download PDF

Info

Publication number
JP3861087B2
JP3861087B2 JP2003349017A JP2003349017A JP3861087B2 JP 3861087 B2 JP3861087 B2 JP 3861087B2 JP 2003349017 A JP2003349017 A JP 2003349017A JP 2003349017 A JP2003349017 A JP 2003349017A JP 3861087 B2 JP3861087 B2 JP 3861087B2
Authority
JP
Grant status
Grant
Patent type
Prior art keywords
virtual machine
server
virtual
means
combination
Prior art date
Legal status (The legal status 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 status listed.)
Active
Application number
JP2003349017A
Other languages
Japanese (ja)
Other versions
JP2005115653A (en )
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
Grant date

Links

Images

Description

この発明は、複数のサーバに複数の仮想マシンを最適配置する仮想マシン管理装置等に関する。 This invention relates to a virtual machine management unit, which optimally arranging a plurality of virtual machines across servers.

従来、サーバのマシン資源をソフトウェアを使って複数に分割して独立させ、1台のサーバ上に複数の仮想マシンを同時に稼働させる仮想マシン(VM:Vertual Machine)技術が知られている。 Conventionally, using software the machine resources of the server is independent divided into a plurality, virtual machines to run concurrently a plurality of virtual machines on a single server (VM: Vertual Machine) technique is known. このような仮想マシンシステムをより効率的に稼働させるために仮想マシンをサーバ上に最適配置する技術が考案されている。 Optimal placement techniques have been devised in such a virtual machine system more efficiently on a virtual machine in order to run the server.

例えば、1台のサーバ上で複数の仮想マシンを稼働させるシステムにおいて、仮想マシンへの資源の割り当てを各仮想マシンの負荷量に応じて動的に行う仮想計算機システムもある(特許文献1参照)。 For example, in a system to run multiple virtual machines on a single server, there is also a virtual computer system dynamically performed according to allocation of resources to the virtual machine to a load amount of each virtual machine (see Patent Document 1) .
特開2002−202959号公報(第6頁、第1図) JP 2002-202959 JP (page 6, Figure 1)

上記のように、従来のシステムは、複数の仮想マシンを1台のサーバ上で稼働させて管理するものであり、複数台のサーバを用いて仮想マシンを稼働させる場合には、各サーバに配置した仮想マシンをサーバ毎に独立して管理を行うため、仮想マシンの稼働状況等によってはサーバ間に負荷の偏りが生じていた。 As described above, the conventional system is for managing and running multiple virtual machines on a single server, when operating the virtual machine using the plurality of servers is located in each server order to perform independently manage virtual machines in each server has, in some operational circumstances such as the virtual machine had occurred bias load among servers.

本発明は、上記実状に鑑みてなされたものであり、複数の仮想マシンを複数のサーバで効率良く稼働させることができる仮想マシン管理装置等を提供することを目的とする。 The present invention has been made in consideration of the above, and an object thereof is to provide a virtual machine management unit or the like can be efficiently run multiple virtual machines on multiple servers.
また、本発明は、複数のサーバにまたがって仮想マシンの最適配置を行うことができる仮想マシン管理装置等を提供することを他の目的とする。 Further, the present invention is to provide a virtual machine management apparatus that can perform optimal placement of virtual machines across multiple servers and other purposes.

上記目的を達成するため、この発明の第1の観点に係る仮想マシン管理装置は、 To achieve the above object, the virtual machine management system according to a first aspect of the invention,
複数の仮想マシンを稼働させる複数のサーバとネットワークを介して接続される仮想マシン管理装置であって、 A virtual machine management apparatus connected via a plurality of servers and network to run multiple virtual machines,
第1の所定期間において、それぞれの仮想マシン毎に、所定時間毎に取得されたパフォーマンスを示す実測データを記憶する稼働情報管理データベースと、 At a first predetermined time period, for each of the virtual machines, and operation information management database for storing actual data indicating to performance it acquired every predetermined time,
各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを前記稼働情報管理データベースから読み出す読出手段と、 Reading means for reading out actual measurement data indicating the performance of a predetermined time of each of the virtual machine from the operation information management database,
前記読み出した各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを用いて、 前記所定時間毎の、各仮想マシンを複数のサーバのいずれかで稼働させた場合の各時間における各仮想マシンのパフォーマンス値を求め、前記求められた所定時間毎の前記仮想マシンのパフォーマンス値が前記所定時間を複数集めた第2の所定期間において最大となる、仮想マシンとサーバの組み合わせを算出する組み合わせ算出手段と、 Using measured data that indicates performance of each predetermined time of the read each said virtual machine, wherein the predetermined time intervals of, for each virtual machine at each time when allowed to run on any of the virtual machine a plurality of servers calculated performance values, the maximum in a second predetermined period of performance values is collected a plurality of the predetermined time of the virtual machine for each of the determined predetermined time, and a combination calculating means for calculating a combination of virtual machines and the server ,
前記組み合わせ算出手段により算出された仮想マシンとサーバの組み合わせに従って、各仮想マシンのファイルを当該仮想マシンに対応するサーバの記憶領域に格納して各仮想マシンの再配置を行う手段と、 According to the combination of virtual machines and the server calculated by the combination calculating means, and means for performing re-arrangement of the virtual machine file stored in the storage area of ​​the server corresponding to the virtual machines each virtual machine,
を備えることを特徴とする。 Characterized in that it comprises a.

このような構成によれば、全ての仮想マシンサーバの資源を利用して各仮想マシンのパフォーマンスが最大となるような仮想マシンと仮想マシンサーバの組み合わせを求め、この組み合わせに基づいて仮想マシンの配置を行うため、複数のサーバにまたがって仮想マシンの最適配置を行うことを可能とし、複数の仮想マシンを複数のサーバで効率良く稼働させることができる。 According to such a configuration, determine the combination of all the virtual machine server virtual machines and virtual machine server, such as the performance of each virtual machine by utilizing the resources is the greatest, the arrangement of the virtual machines based on the combination for performing, it makes it possible to perform optimal placement of virtual machines across multiple servers, can be efficiently run multiple virtual machines on multiple servers.

前記読出手段は、各前記サーバの記憶容量に関するデータと、各前記仮想マシンの記憶容量に関するデータと、を前記稼働情報管理データベースからさらに読み出してもよく、 Said read means includes data relating to the storage capacity of each said server, data relating to the storage capacity of each said virtual machine may also further read from the operation information management database,
前記組み合わせ算出手段は、前記読出手段により読み出した、各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データと、各前記サーバの記憶容量に関するデータと、各前記仮想マシンの記憶容量に関するデータと、を算出条件に用いて、前記仮想マシンとサーバの組み合わせを算出してもよい。 Wherein the combination calculation means read by the reading means, the measured data indicating the performance of a predetermined time of each of the virtual machines, and the data relating to the storage capacity of each said server, data relating to the storage capacity of each said virtual machine, using the calculation condition may calculate the combination of the virtual machine and the server.

仮想マシンの作成要求を受信する手段と、 It means for receiving a request to create a virtual machine,
各前記サーバの記憶領域の使用量と、前記受信した作成要求が示す仮想マシンのファイル容量と、に基づいて、前記作成要求が示す仮想マシンのファイルを記憶領域に格納できるサーバを選択する手段と、 And usage of the storage area of ​​each of the servers, and the file capacity of the virtual machine indicated by the creation request thus received, based on, means for selecting a server that can store files of the virtual machine the creation request is shown in a storage area ,
前記選択したサーバの記憶領域に、前記作成要求が示す仮想マシンのファイルを格納させる手段と、 The storage area of ​​the selected server, and means for storing the file of the virtual machine the creation request is shown,
を備えてもよい。 It may be provided.

また、この発明の第2の観点に係るプログラムは、 Further, the program according to the second aspect of the invention,
複数の仮想マシンを稼働させる複数のサーバとネットワークを介して接続されるコンピュータに、 A computer connected through a plurality of servers and network to run multiple virtual machines,
第1の所定期間において、それぞれの仮想マシン毎に、所定時間毎に取得されたパフォーマンスを示す実測データを稼働情報管理データベースに記憶する記憶ステップ、 At a first predetermined time period, for each of the virtual machines, storage step of storing the measured data indicating the by performance acquired at predetermined time intervals in the operational information management database,
各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを前記稼働情報管理データベースから読み出す読出ステップ、 Reading step of reading the actual measurement data indicating the performance of a predetermined time of each of the virtual machine from the operation information management database,
前記読出ステップにより読み出した、各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを用いて、 前記所定時間毎の、各仮想マシンを複数のサーバのいずれかで稼働させた場合の各時間における各仮想マシンのパフォーマンス値を求め、前記求められた所定時間毎の前記仮想マシンのパフォーマンス値が前記所定時間を複数集めた第2の所定期間において最大となる、仮想マシンとサーバの組み合わせを算出する組み合わせ算出ステップ、 Said read by the read step, each said using measured data that indicates performance of each predetermined time of a virtual machine, for each of the predetermined time, at each time when is operated in any of the multiple servers each virtual machine calculated performance values for each virtual machine, the maximum in a second predetermined period of performance values is collected a plurality of the predetermined time of the virtual machine for each of the determined predetermined time, calculates the combination of virtual machines and the server combination calculation step,
前記組み合わせ算出ステップにより算出された仮想マシンとサーバの組み合わせに従って、各仮想マシンのファイルを当該仮想マシンに対応するサーバの記憶領域に格納させて各仮想マシンの再配置を行うステップ、 Wherein according to the combination of virtual machines and the server calculated by the combination calculating step, the step of the file for each virtual machine to re-arrangement of the virtual machine is stored in a storage area of ​​the server corresponding to the virtual machine,
を実行させる。 To the execution.

本発明によれば、複数の仮想マシンを複数のサーバで効率良く稼働させることができる。 According to the present invention, it is possible to efficiently run multiple virtual machines on multiple servers.

以下、本発明の実施の形態に係る仮想マシンシステムを図面を参照して説明する。 Hereinafter will be described a virtual machine system according to an embodiment of the present invention with reference to the drawings.
本発明の実施形態に係る仮想マシンシステムの構成を図1に示す。 The configuration of the virtual machine system according to an embodiment of the present invention shown in FIG. この仮想マシンシステムは、クライアント端末1と、仮想マシン管理サーバ2と、仮想マシンサーバ3と、ファイルサーバ4と、を備える。 The virtual machine system includes a client terminal 1, the virtual machine management server 2, a virtual machine server 3, the file server 4, the. 仮想マシン管理サーバ2と、仮想マシンサーバ3と、ファイルサーバ4は、インターネット等のネットワーク10により接続されている。 And the virtual machine management server 2, a virtual machine server 3, the file server 4 are connected by a network 10 such as the Internet. また、クライアント端末1は、LAN等のネットワークを介して仮想マシン管理サーバ2に接続されている。 The client terminal 1 is connected to the virtual machine management server 2 via a network such as a LAN.

クライアント端末1は、管理者により操作される端末であり、制御部、記憶部、表示部、入力部、通信制御部等を備えるコンピュータから構成される。 The client terminal 1 is a terminal operated by the administrator, the control unit, storage unit, display unit, input unit, and a computer having a communication control unit or the like. クラアイント端末1の制御部は、記憶部に記憶される動作プログラム等を読み出して実行することにより、仮想マシン管理サーバ2に接続し、各種要求の送信、送信した要求に応じたデータの受信及び表示等の処理を行う。 Controller of Kuraainto terminal 1, by reading and executing operation programs stored in the storage unit, connected to the virtual machine management server 2, the transmission of the various requests, receive and display the data corresponding to the transmitted request It performs the processing and the like.

仮想マシン管理サーバ2は、例えば図2に示すように、記憶部21、制御部22、通信制御部23等を備えるコンピュータから構成される。 Virtual machine management server 2, for example, as shown in FIG. 2, and a computer having a storage unit 21, the control unit 22, a communication control unit 23 or the like.

記憶部21は、例えば、ハードディスク装置等から構成される。 Storage unit 21, for example, a hard disk device or the like. 記憶部21は、制御部22が実行するための動作プログラム及び処理に必要な各種データを記憶する。 Storage unit 21 stores various data necessary for the operation program and processing for the control unit 22 executes. また、記憶部21は、VMサーバ管理DB211、ファイルサーバ管理DB212、VM管理DB213、VMイメージファイル管理DB214、稼働状況管理DB215等を備える。 The storage unit 21 includes VM server management DB 211, the file server management DB 212, VM management DB 213, VM image file management DB 214, the operation status management DB215 like.

VMサーバ管理DB211は、各仮想マシンサーバ3に関する情報(仮想マシンサーバ情報)を記憶する。 VM server management DB211 stores information (virtual machine server information) about each virtual machine server 3. 仮想マシンサーバ情報は、例えば図3に示すように、仮想マシンサーバ名、ホストOS名、仮想マシンソフトウェア名、IPアドレス、CPUサイクル数、メモリ容量、ハードディスク容量、ハードディスクIO帯域幅、ネットワークIO帯域幅、ベンチマーク結果、当該仮想マシンサーバで稼働する仮想マシンの仮想マシンID等のデータを含む。 Virtual machine server information, for example, as shown in FIG. 3, the virtual machine server name, host OS name, virtual machine software name, IP address, number of CPU cycles, memory, hard disk space, a hard disk IO bandwidth, network IO bandwidth , benchmark results, including data such as the virtual machine ID of the virtual machines running in the virtual machine server.

ファイルサーバ管理DB212は、各ファイルサーバ4に関する情報(ファイルサーバ情報)を記憶する。 File server management DB212 stores information (file server information) about each file server 4. ファイルサーバ情報は、例えば図4に示すように、IPアドレス、サーバ名、ハードディスク容量等のデータを含む。 File server information includes, for example, as shown in FIG. 4, IP address, server name, data such as a hard disk capacity.

VM管理DB213は、各仮想マシンサーバ3上で稼働させる仮想マシンに関する情報(仮想マシン情報)を記憶する。 VM management DB213 stores information (virtual machine information) about the virtual machines to run on the virtual machine server 3. 仮想マシン情報は、例えば図5に示すように、仮想マシンID、ユーザ名、OS名、CPUサイクル、メモリ容量、ハードディスク容量、IPアドレス、当該仮想マシンのパフォーマンスデータを特定するためのパフォーマンスID等のデータを含む。 Virtual machine information, for example, as shown in FIG. 5, virtual machine ID, user name, OS name, CPU cycles, memory, hard disk space, IP address, such as performance ID for identifying the performance data of the virtual machine including the data.

VMイメージファイル管理DB214は、仮想マシンのイメージファイル(ディスクやメモリの内容をそのままファイル化したもの)に関する情報(イメージファイル情報)を記憶する。 VM image file management DB214 stores information about the virtual machine image file (which the disk or the contents of the memory was directly filed) (image file information). イメージファイル情報は、例えば図6に示すように、イメージファイル名(モデル名)、OS名、メモリ容量、ハードディスク容量、各ソフトウェア名、当該イメージファイル保存先のファイルサーバのIPアドレス、当該イメージファイル保存先のファイルパス等のデータを含む。 Image file information, for example, as shown in FIG. 6, the image file name (model name), OS name, memory capacity, hard disk space, the software name, the image file storage destination of the file server IP address, saving the image file including data such as the previous file path.

稼働状況管理DB215は、各仮想マシンについて所定時間毎(例えば1時間毎)に取得された、パフォーマンスの実測データ(パフォーマンスデータ)を所定期間分(例えば、1ヶ月分)記憶する。 Availability management DB215, for each virtual machine is acquired every predetermined time (for example, every 1 hour), the performance of the measurement data (performance data) a predetermined period (e.g., 1 month) and stored. 本実施例では、例えば図7に示すように、1時間毎(0時、1時、・・・、23時)に取得された1ヶ月分のパフォーマンスデータが仮想マシンID毎に記憶されることとする。 In this embodiment, for example, as shown in FIG. 7, every 1 hour (0:00, 1:00, ..., 23:00) to 1 month's performance data acquired is stored for each virtual machine ID to.

制御部22は、CPU(Central Processing Unit)、ROM(Read Only Memory)、RAM(Random Access Memory)等から構成され、仮想マシン管理サーバ2全体を制御する。 Control unit 22, CPU (Central Processing Unit), ROM (Read Only Memory), is a RAM (Random Access Memory), and controls the entire virtual machine management server 2. 制御部22は、記憶部21に予め記憶された動作プログラム等を読み出して実行することにより、VM(仮想マシン:Vertual Machine)サーバ管理部221、VM最適配置部222、VM自動作成部223等を論理的に実現する。 Control unit 22 by reading and executing pre-stored operating programs and the storage unit 21, VM (Virtual Machine: Vertual Machine) server management unit 221, VM optimal placement unit 222, VM automatic creation unit 223 and the like logically realized.

VMサーバ管理部221は、クライアント端末1からの仮想マシン一覧要求を受信すると、各仮想マシンサーバ3に配置されている全仮想マシンのID(仮想マシンID)を記憶部21のVMサーバ管理DB211から読み出す。 VM server management unit 221 receives the virtual machine list request from the client terminal 1, the ID (VM ID) of all virtual machines that are positioned on each virtual machine server 3 from the VM server management DB211 of the storage unit 21 read out. そして、読み出した各仮想マシンIDに対応する仮想マシン情報をVM管理DB213から読み出し、読み出した仮想マシン情報の全部又は一部を表示する画面データを生成して要求元のクライアント端末1に送信する。 Then, it transmits a virtual machine information corresponding to each virtual machine ID read read from the VM management DB 213, the read-out all or to the requesting client terminal 1 to generate screen data for displaying a portion of the virtual machine information.

VM最適配置部222は、稼働状況管理DB215に記憶されている各仮想マシンのパフォーマンスデータに基づいて、各仮想マシンのパフォーマンスが最大になるような仮想マシンサーバ3と仮想マシンの組み合わせを算出し、算出した組み合わせに基づいて各仮想マシンを再配置する最適配置処理を行う。 VM optimal placement unit 222, based on performance data for each virtual machine that is stored in the operating state management DB 215, the performance of each virtual machine calculates the combination of the virtual machine server 3 and the virtual machine that maximizes, based on the calculated combining performs optimal arrangement processing for rearranging each virtual machine. 通常、ユーザが仮想マシンを使用する場合、ユーザ毎に利用する時間帯が異なることが想定されるため、この最適配置処理では、各仮想マシンの稼働する時間帯が異なることに着目した最適配置を行うものである。 Normally, when the user uses the virtual machine, because the time zone to be used for each user are different it is assumed, in this optimal arrangement processing, the optimal placement of the time zone that runs in the virtual machine has focused on different is performed.

具体的には、まず、各仮想マシンのパフォーマンスが最大となるような仮想マシンサーバと仮想マシンの組み合わせを求めるために、例えば、VM管理DB213に登録されている全仮想マシンM (i=1、2、・・・、N)を各仮想マシンサーバS (j=1,2,・・・,J)上に配置した場合に出来るだけ多くの仮想マシンM の性能a が、出来るだけ多くの時間t(t=1,2,・・・,23(時))で最大となる組み合わせを、以下の(1)〜(3)に示す算出方法に従って算出する。 Specifically, first, in order to obtain the combination of virtual machine performance and virtual machine servers, such as the maximum virtual machine, for example, all virtual machines registered in the VM management DB213 M i (i = 1 , 2, ..., each virtual machine N) server S j (j = 1,2, ··· , performance a i of as many virtual machines M i can when placed on the J) is possible as many time t (t = 1,2, ···, 23 (h)) a combination of the maximum is calculated according to the calculation method shown in the following (1) to (3). なお、仮想マシンM のハードディスク容量をh (i=1,2,・・・)、メモリ容量をr (i=1,2,・・・)、仮想マシンサーバS のハードディスク容量をH (j=1,2,・・・)、メモリ容量をR (j=1,2,・・・)、性能をA (j=1,2,・・・)とし、これらのデータは記憶部21に記憶されている。 In addition, the hard disk capacity of the virtual machine M i h i (i = 1,2 , ···), the memory capacity r i (i = 1,2, ··· ), the hard disk capacity of the virtual machine server S j H j (j = 1,2, ··· ), a memory capacity R j (j = 1,2, ··· ), the performance a j (j = 1,2, ··· ) and, of these data is stored in the storage unit 21. また、性能A は例えばベンチマークテストの実行結果等である。 Moreover, the performance A j is the execution results of the benchmark test, for example. また、x ijは、仮想マシンサーバS における仮想マシンM の配置の有無を示すものであり、仮想マシンM を仮想マシンサーバS に配置する場合にはx ij =1とし、配置しない場合にはx ij =0とする。 Further, x ij is for indicating the presence or absence of virtual machine placement M i in the virtual machine server S j, and x ij = 1 in the case of arranging the virtual machine M i to a virtual machine server S j, do not place and x ij = 0 in the case.
また、Y ijは、仮想マシンサーバS における仮想マシンM の電源ON/OFFを示すものであり、仮想マシンM の電源が入っている場合には、Y ij =1とし、入っていない場合には、、Y ij =0とする。 Further, Y ij is for indicating the power ON / OFF of the virtual machines M i in the virtual machine server S j, if they turned virtual machine M i is the Y ij = 1, does not contain and ,, Y ij = 0 in the case. また、再配置後における仮想マシンM の稼働時の性能a は、予め設定されている仮想マシンの最低性能a min以上であることとする。 Moreover, the performance a i during operation of the virtual machine M i after relocation and not less than minimum performance a min of virtual machines that are set in advance.

(1)仮想マシンサーバS (j=1,2,・・・)上において、各時間(時刻)tに稼働している仮想マシン数n jtを、各時間における仮想マシンのパフォーマンスの実測データに基づいて算出する。 (1) virtual machine server S j (j = 1,2, ··· ) on, each time (time) virtual machine number n jt running in t, the measured data of the performance of the virtual machine at each time It is calculated on the basis of the. この稼働マシン数n jtの算出処理の詳細については後述する。 It will be described in detail later process for calculating the running machine number n jt.
(2)(数6)式の条件を満たす仮想マシンM のt時(t=0,1,・・・,23)での性能a itを(数1)式により求める。 (2) (6) when t satisfies the condition virtual machine M i of equation (t = 0,1, ···, 23 ) determined by the performance a it (number 1) in.
(3)(数1)式、(数3)式、(数4)式、(数5)式の条件下で、(数2)式の値が最大となる組み合わせを組み合わせ最適化アルゴリズム等を用いて算出する。 (3) (number 1), equation (3), (Equation 4), under the conditions of equation (5), an optimization algorithm such as combining the combination with the maximum value of equation 2 using calculated. 使用する組み合わせ最適化アルゴリズムは任意であり、例えば、遺伝的アルゴリズムやシミュレーティッド・アニーリング手法等を用いてもよい。 Combinatorial optimization algorithm used is arbitrary, for example, may be used a genetic algorithm and simulated annealing method or the like.

(数1) (Number 1)
(数2) (Number 2)
(数3) (Number 3)
(数4) (Number 4)
(数5) (Number 5)
(数6) (Number 6)

VM最適配置部222は、上記(1)〜(3)に示す算出方法に従って算出した組み合わせに基づいて、ファイルサーバ4をテンポラリ領域として利用する等して、各仮想マシンのイメージファイルを当該仮想マシンに対応する仮想マシンサーバ3の記憶領域にコピーすることにより、各仮想マシンの再配置を行う。 VM optimal placement unit 222, the (1) based on the combination calculated according to the calculation method shown in - (3), and the like utilizing the file server 4 as a temporary area, the virtual machine the virtual machine image file by copying the storage area of ​​the virtual machine server 3 corresponding to rearranges each virtual machine.
また、VM最適配置部222は、各仮想マシンサーバ3からパフォーマンスデータを受信し、稼働状況管理DB215に記録する。 Also, VM optimum arrangement unit 222 receives the performance data from the virtual machine server 3, and records the operating state management DB 215.

VM自動作成部223は、クライアント端末1からの仮想マシンの作成要求に応答して、仮想マシンを自動作成する処理を行う。 VM automatic creation unit 223, in response to creation request a virtual machine from the client terminal 1, performs processing for automatically creating a virtual machine. 具体的には、クライアント端末1からの仮想マシンの作成要求を受信すると、VMイメージファイル管理DB214に登録されているイメージファイル情報を読み出し、その全部又は一部を表示する画面データを生成してクライアント端末1に送信する等して、ユーザ(管理者)によるイメージファイル名の入力を受け付ける。 Specifically, when receiving the virtual machine creation request from the client terminal 1, reads the image file information registered in the VM image file management DB 214, and generates screen data to be displayed in whole or in part by the client is equal to the terminal 1, the user (administrator) accepts the input of the image file name by. そして、入力されたイメージファイル名のイメージファイルについて、イメージファイル情報からイメージファイル保存先のファイルサーバ4のIPアドレス、当該イメージファイル保存先のファイルパス等のデータを取得し、選択されたイメージファイルのコピー先の仮想マシンサーバ3を決定し、ファイルサーバ4から該当するイメージファイルを読み出して仮想マシンサーバ3にコピーする。 Then, the input image file name image file, the image file of the image file storage destination IP address of the file server 4 to acquire data, such as the image file destination file path of the image file selected to determine the virtual machine server 3 of the copy destination, read the image file to be applicable from the file server 4 to copy the virtual machine server 3.

通信制御部23は、ネットワーク10を介して他のコンピュータとの間でデータ通信を行うためのものである。 The communication control unit 23 is for performing data communication with other computers via a network 10.

仮想マシンサーバ3は、仮想マシンを動作させるためのサーバであり、制御部、記憶部、通信制御部等を備えるコンピュータから構成される。 Virtual machine server 3 is a server for operating a virtual machine, the control unit, storage unit, and a computer having a communication control unit or the like.
制御部は、CPU、ROM、RAM等から構成され、ハードディスク等の記憶部に予め記憶された各種プログラム等を読み出して実行することにより、複数の仮想マシンを論理的に実現する。 Control unit, CPU, ROM, a RAM or the like, by reading and executing prestored various programs in a storage unit such as a hard disk, which realizes a plurality of virtual machines logically. 仮想マシンサーバ3の論理構成の概略図の一例を図8に示す。 An example of a schematic diagram of a logical configuration of the virtual machine server 3 shown in FIG. 図示されるように、物理マシン(CPU、メモリ、ハードディスク等)を制御するOS(ホストOS)等の上に、仮想マシンを制御するソフトウェア(仮想マシン制御プログラム)があり、例えば、この仮想マシン制御プログラムが、仮想マシンサーバ3の資源(プロセッサ、メモリ、ハードウェア等)を分割し、分割された資源を独立して使用する各仮想マシンを実現する。 As shown, the physical machine (CPU, memory, hard disk, etc.) on such OS (host OS) for controlling, there is software to control a virtual machine (VM control program), for example, the virtual machine control program divides the resources of the virtual machine server 3 (processor, memory, hardware, etc.), it implements each virtual machine to independently use the divided resource. 各仮想マシンの記憶部(割り当てられたメモリ又はハードディスク)には、OS、アプリケーション等の各種プログラム、仮想マシンID等の各種データが記憶される。 The storage unit of each virtual machine (allocated memory or a hard disk), OS, various programs such as applications, various data such as the virtual machine ID is stored. 各仮想マシンは、パフォーマンスデータを取得するプログラム(パフォーマンス取得プログラム)を所定時間毎(本実施例では1時間間隔)に実行し、実行結果(パフォーマンスデータ)を仮想マシンID、時刻データ(実行時刻等)等の情報とともに、仮想マシン管理サーバ2に送信する。 Each virtual machine may execute a program for acquiring performance data (performance acquisition program) a predetermined time (1 hour intervals in this embodiment), the execution result (performance data) virtual machine ID, time data (execution time, etc. ) along with information such as, it is sent to the virtual machine management server 2. なお、パフォーマンスデータは仮想マシンの性能を表すデータであればよく、その内容は任意であり、例えばCPU稼働率でもよく、また、所定の計算処理を実行させて結果が出力されるまでの時間でもよい。 Incidentally, the performance data may be any data indicating the performance of virtual machines, the contents of which are optional, for example, may be a CPU operating ratio, also any time to results by executing a predetermined calculation process is output good.

ファイルサーバ4は、制御部、記憶部、通信制御部等を備えるコンピュータから構成される。 The file server 4, the control unit, storage unit, and a computer having a communication control unit or the like. ファイルサーバ4の記憶部は、仮想マシンのイメージファイルを記憶しており、仮想マシン管理サーバ2からの要求に応じて、指定されたイメージファイルを読み出して送信する。 Storage of the file server 4 may store the image file of the virtual machine, in response to a request from the virtual machine management server 2, and transmits the read out specified image file.

次に、本実施形態に係る仮想マシンシステムの動作について説明する。 Next, the operation of the virtual machine system of this embodiment.
まず、仮想マシンを自動的に作成する自動作成処理について図9のフローチャートを参照して説明する。 First, with reference to the flowchart of FIG. 9 for automatic creation process of creating a virtual machine automatically.
まず、仮想マシン管理サーバ2の制御部22は、クライアント端末1からの仮想マシンの作成要求に応じて、VMイメージファイル管理DB214に登録されているイメージファイル情報を表示するとともに、イメージファイルを特定する情報(例えば、イメージファイル名等)の入力を受け付ける画面のデータをクライアント端末1に供給し、ユーザ(管理者)により入力されたイメージファイル名等のデータを受信する(ステップS1)。 First, the control unit 22 of the virtual machine management server 2 in response to the virtual machine creation request from the client terminal 1, and displays the image file information registered in the VM image file management DB 214, identifies the image file information (e.g., image file name, etc.) supplies data of a screen for receiving input of the client terminal 1 receives the data of the image file name or the like input by the user (administrator) (step S1). そして、入力されたイメージファイル名等に対応するイメージファイル情報をVMイメージファイル管理DB214から読み出し、指定されたイメージファイルが保存されているファイルサーバ4のIPアドレス、ファイルパス等を取得する(ステップS2)。 Then, the read image file information corresponding to the input image file name, etc. from the VM image file management DB 214, IP address of the file server 4 specified image file is stored, and acquires the file path, etc. (step S2 ).

次に、制御部22は、仮想マシンサーバテーブルを初期化する(ステップS3)。 Next, the control unit 22 initializes the virtual machine server table (step S3). 仮想マシンサーバテーブルとは、仮想マシンサーバ3のIPアドレスと、各IPアドレスに対応する候補フラグと、が設定されるサーバ決定テーブルであり、この初期化処理では、VMサーバ管理DB211に登録されている全ての仮想マシンサーバ3のIPアドレスをテーブルに設定するとともに、全てのIPアドレスに対応する候補フラグに”0”を設定する。 The virtual machine server table, the IP address of the virtual machine server 3, and the candidate flag corresponding to each IP address, a server determination table is set, in the initialization process, it is registered in the VM server management DB211 and it sets all the IP address of the virtual machine server 3 being in the table, "0" is set to the candidate flags corresponding to all the IP addresses.

次に、制御部22は、サーバ決定テーブルからランダムにIPアドレスを選択し、選択したIPアドレスの仮想マシンサーバ3の仮想マシン情報をVMサーバ管理DB211を検索して参照し、その仮想マシンサーバ3に、ユーザから指定されたイメージファイルをコピーできるリソースが残っているか否か(即ち、仮想マシンサーバ3のハードディスクの空き容量のデータを取得し、その空き容量がイメージファイルのサイズよりも大きいか等)を判定する(ステップS4)。 Next, the control unit 22 selects an IP address randomly from server determination table, referring to the virtual machine information of the virtual machine server 3 of the selected IP address by searching the VM server management DB 211, the virtual machine server 3 to, whether there are any remaining resources to copy the image file designated by the user (i.e., acquires data of free space of the virtual machine server 3 hard, and whether the free space is larger than the size of the image file ) (step S4). そして、選択された仮想マシンサーバ3に、イメージファイルをコピーできるリソースが残っていると判定された場合(ステップS4:YES)、その仮想マシンサーバ3にイメージファイルをコピーして(ステップS5)、本処理を終了する。 Then, the virtual machine server 3 selected, if it is determined that there remains a resource that can copy an image file (step S4: YES), then copy the image file to the virtual machine server 3 (step S5), and the present process is terminated.

また、選択された仮想マシンサーバ3に、イメージファイルをコピーできるリソースが残っていないと判定された場合(ステップS4:NO)、その仮想マシンサーバ3に対応する候補フラグに”1”を設定し(ステップS6)、サーバ決定テーブルの候補フラグが全て”1”に設定されているかを判定し(ステップS7)、全て”1”に設定されている場合には(ステップS7:YES)、例えば「仮想マシンサーバを追加してください」等のエラーメッセージの表示画面をクライアント端末1に送信して表示させ(ステップS8)、本処理を終了する。 Further, the virtual machine server 3 selected, if it is determined that there are no remaining resources to copy the image file (step S4: NO), "1" is set in the candidate flag corresponding to the virtual machine server 3 (step S6), and determines whether the candidate flag in the server determining table is set to all "1" (step S7), and if it is set to all "1" (step S7: YES), for example " by sending a display screen of an error message such as Please add virtual machine server "to the client terminal 1 is displayed (step S8), and terminates the process.

また、サーバ決定テーブルの候補フラグが全て”1”に設定されていない場合には(ステップS7:NO)、ステップS4に戻り、次の仮想マシンサーバ3をランダムに決定し、イメージファイルをコピーできるリソースが残っているか否かの判定等を行う処理等を繰り返す。 Further, if the candidate flag server determination table is not set to all "1" (step S7: NO), the process returns to step S4, the next virtual machine server 3 determines at random, you can copy the image file the process is repeated such that it is determined whether or not such resources remain.
なお、ステップS4における仮想マシンサーバ3を選択する処理では、対応する候補フラグに”1”が設定されていないIPアドレスを選択するものとする。 In the process of selecting the virtual machine server 3 at step S4, it is assumed to select the IP address of the corresponding candidate flag "1" is not set. 具体的には、ランダムに選択したIPアドレスに対応するフラグが”1”の場合にはそのIPアドレスを棄てて、再度IPアドレスをランダムに選択することを繰り返すようにしてもよく、また、対応する候補フラグに”0”が設定されているIPアドレスを先に抽出し、その中からランダムに選択するようにしてもよい。 Specifically, randomly when the flag is "1" corresponding to the selected IP address is discarded and the IP address, may be repeated to select randomly the IP address again, also the corresponding candidate flag is "0" the previously extracted an IP address that is set to be, may be selected at random from among them.

次に、複数の仮想マシンサーバ3に対して複数の仮想マシンを最適配置するための最適配置処理について図10のフローチャートを参照して説明する。 Next, with reference to the flowchart of FIG. 10 for optimal arrangement processing for optimally arranging a plurality of virtual machines for a plurality of virtual machine servers 3.
まず、仮想マシン管理サーバ2の制御部22は、各仮想マシンのパフォーマンスデータを稼働状況管理DB215から読み出す(ステップS11)。 First, the control unit 22 of the virtual machine management server 2 reads the performance data of each virtual machine from operating state management DB 215 (step S11).
次に、制御部22は、仮想マシンサーバS (j=1,2,・・・)上において、各時間(時刻)tに稼働している仮想マシン数n jtを算出する(ステップS12)。 Next, the control unit 22, a virtual machine server S j (j = 1,2, ··· ) on, calculating each time (time) number of virtual machines n jt running to t (step S12) .

この稼働マシン数n jtを算出する稼働マシン算出処理の詳細を図11のフローを参照して説明する。 Running machine calculation processing details for calculating the operating machine number n jt be described with reference to the flowchart in FIG. 11.
制御部22は、所定の初期化処理(t時にサーバS 上で稼働している仮想マシンの数n jt =0,時間t=0、仮想マシンの電源Y ij =0等)を行う(ステップS21)。 Control unit 22 (the number n jt = 0 of the virtual machines running on t at the server S j, the time t = 0, the power supply Y ij = 0, etc. of the virtual machine) predetermined initialization process is performed (steps S21).
そして、VMサーバ管理DB211に登録されている仮想マシンサーバS の仮想マシンサーバ情報中の仮想マシンIDを1つ取り出し、取り出した仮想マシンIDに対応するパフォーマンスIDをVM管理DB213から取得し、そのパフォーマンスIDにより特定されるパフォーマンスデータを稼働状況管理DB215から読み出す(ステップS22) Then, acquires the virtual machine ID in the virtual machine server information of the virtual machine server S j registered in the VM server management DB 211 1 single extraction, the performance ID corresponding to the virtual machine ID extracted from the VM management DB 213, the reading the performance data specified by the performance ID from operating state management DB 215 (step S22)

次に、ステップS22で読み出したパフォーマンスデータに基づいて、その仮想マシンM のd日(例えば、1,2,・・・,30)におけるt時(t=0,1,2,・・・,23)のパフォーマンスデータの値をP idt 、各時間(時刻)tにおけるパフォーマンスデータの1ヶ月の平均値をP itとして、(数7)式により、時間(時刻)tにおける仮想マシンM のパフォーマンスの平均値P itを算出する(ステップS23)。 Then, based on the read performance data in step S22, d date of the virtual machine M i (e.g., 1, 2, ..., 30) at t in (t = 0, 1, 2, ... , the value of the performance data of the P idt of 23), the average value of one month's performance data at each time (time) t as P it, (the number 7), of the virtual machine M i at time (time) t It calculates an average value P it performance (step S23).

(数7) (Number 7)

そして、ステップS23で算出された平均値P itが予め設定された最低パフォーマンス値P th以上であるか否かを判別し(ステップS24)、最低パフォーマンス値P th以上である場合には、その仮想マシンM が稼働しているとみなし、稼働マシン数n jtに1だけ加算するとともに、Y ij =1とする(ステップS25)。 Then, the average value P it calculated in step S23, it is determined whether or not a preset minimum performance value P th or more (step S24), and if it is the lowest performance value P th or more, the virtual deemed machine M i is running, as well as adding only 1 in the operational machine number n jt, and Y ij = 1 (step S25).

ステップS25の処理の後、又は、ステップS24において平均値P itが最低パフォーマンス値P thより小さいと判別された場合には、仮想マシンサーバS の仮想マシンサーバ情報に登録されている全仮想マシンIDについて処理が完了したかを判定し(ステップS26)、完了していない場合には、ステップS22に戻って、次の未処理の仮想マシンIDを取り出し、それについて上記の処理(その仮想マシンM が稼働しているかを判定して、稼働している場合には稼働マシン数n jtに1を加算する処理)を行う。 After the process of step S25, or if the average value P it is determined that the minimum performance value P th is smaller than in step S24, all virtual machines that are registered in the virtual machine server information of the virtual machine server S j determines whether the processing for ID is completed (step S26), if not completed, the process returns to step S22, takes out a virtual machine ID of the next unprocessed, the above process about it (the virtual machine M i is judged whether the running, if running performs processing) of adding 1 to the working machine number n jt.
また、ステップS26において仮想マシンサーバ情報に登録されている全仮想マシンIDについて処理が完了したと判定された場合には、t=23であるか、即ち、全時間(0〜23時)について稼働マシン数n jtを計数する処理が完了したかを判定し(ステップS27)、完了していない場合(t≠23の場合)には、tに1だけ加算して(ステップS28)ステップS23に戻り、次の時間tについて上記の処理を行う。 Also, when the processing for all the virtual machine ID registered in the virtual machine server information is determined to have been completed in step S26, whether the t = 23, i.e., operation for all time (time 0 to 23) determines whether the processing for counting the number of machine n jt is completed (step S27), the case is not completed (case of t ≠ 23), by adding only 1 to t returns to (step S28) step S23 , performing the above-described process for the next time t.
また、ステップS27において、t=23であると判定された場合には本処理を終了する。 Further, in step S27, when it is determined that t = 23, the process is terminated.

制御部22は、上述の算出処理を各仮想マシンサーバS (j=1,2,・・・)上について実行し、各仮想マシンサーバS 上で、各時間(時刻)tに稼働している仮想マシン数n jtを算出する。 Control unit 22, the virtual machine server process for calculating the above-described S j (j = 1,2, ··· ) Perform the above, on each virtual machine server S j, runs each time (time) t and to calculate the virtual machine number n jt are.

各仮想マシンサーバS 上の仮想マシン数n jtを算出した後、制御部22は、先に示した(数6)式の条件を満たす仮想マシンM のt時(t=0,1,・・・,23)での性能a itを、先に示した(数1)式により求めるとともに、各仮想マシンのパフォーマンスが最大になる仮想マシンと仮想マシンサーバの組み合わせ、即ち、先に示した(数1)式、(数3)式、(数4)式、(数5)式の条件下で、先に示した(数2)式の値が最大となる組み合わせを、例えば、遺伝的アルゴリズムやシミュレーティッド・アニーリング手法等の組み合わせ最適化アルゴリズム等を用いて算出することにより、各仮想マシンのパフォーマンスが最大となる組み合わせを求める(ステップS13)。 After calculating the virtual machine number n jt on each virtual machine server S j, the control unit 22, shown above (6) when t satisfies the condition virtual machine M i of equation (t = 0, 1, ..., the performance a it at 23), together with the obtained by previously shown (number 1), the combination of virtual machines and virtual machine server performance of each virtual machine is maximized, i.e., previously shown (number 1), the combination of the equation (3), (equation 4), under the conditions of equation (5), the value of the previously shown (number 2) up, for example, genetic by calculation using combinatorial optimization algorithms such as algorithms or simulated annealing method or the like, it obtains a combination in which the performance of each virtual machine is maximized (step S13).

そして、制御部22は、ステップS13により各仮想マシンのパフォーマンスが最大となる組み合わせが得られたか否かを判定し(ステップS14)、組み合わせが得られた場合には、ファイルサーバ4をテンポラリ領域として利用する等して、各仮想マシンのイメージファイルを当該仮想マシンに対応する仮想マシンサーバ3の記憶領域にコピーする等して各仮想マシンの再配置を行い(ステップS15)、VMサーバ管理DB211における各仮想マシンサーバ情報における仮想マシンIDを変更登録して、本処理を終了する。 Then, the control unit 22, the performance of each virtual machine to determine whether the obtained combination as a maximum by step S13 (step S14), and if the combination is obtained, the file server 4 as a temporary area and the like utilizing, an image file for each virtual machine performs a relocation of equal to each virtual machine is copied in the storage area of ​​the virtual machine server 3 corresponding to the virtual machine (step S15), and the VM server management DB211 register change the virtual machine ID of each virtual machine server information, and the process ends.
また、ステップS14の判定において、組み合わせの解が得られなかったと判定された場合には、例えば「仮想マシンサーバを追加してください」等のエラーメッセージの表示画面をクライアント端末1に送信して表示させ(ステップS16)、本処理を終了する。 Further, in the judgment of step S14, when the solution of the combination is determined to have failed, for example by sending a display screen of an error message such as "Please add the virtual machine server" to the client terminal 1 displays It is allowed (step S16), and terminates the process.

以上説明したように、本発明によれば、全ての仮想マシンサーバ3の資源を利用して各仮想マシンのパフォーマンスが最大となるような仮想マシンと仮想マシンサーバ3の組み合わせを求め、この組み合わせに基づいて仮想マシンの配置を行うため、複数のサーバにまたがって仮想マシンの最適配置を行うことを可能とし、複数の仮想マシンを複数のサーバで効率良く稼働させることができる。 As described above, according to the present invention determines the combination of the virtual machine server 3 and all virtual machines by utilizing the resources of the server 3 for each virtual machine performance is maximized as a virtual machine, this combination to perform the placement of virtual machines based, possible to perform optimal placement of virtual machines across multiple servers, can be efficiently run multiple virtual machines on multiple servers.

この発明は上記実施の形態に限定されず、種々の変形及び応用が可能である。 The invention is not limited to the above embodiments, and various modifications and applications are possible.
例えば、上記の各数式は一例であり、各仮想マシンのパフォーマンスを最大とする仮想マシンと仮想マシンサーバの組み合わせを求めるための種々の数式が適用可能である。 For example, the formula above is an example, can be applied various formulas for calculating the combination of the virtual machine server and the virtual machine to maximize the performance of each virtual machine. また、上記説明では、仮想マシンと仮想マシンサーバの組み合わせを算出する際に、仮想マシンと仮想マシンサーバの記憶容量に関する条件式を用いているが、他の性能(例えば、ハードディスクIO帯域幅、ネットワークIO帯域幅等)に関する条件式を用いてもよい。 In the above description, when calculating the combination of virtual machines and virtual machine server, but using the condition concerning the storage capacity of the virtual machine and the virtual machine server, other performance (e.g., hard disk IO bandwidth, network it may be used conditions concerning the IO bandwidth, etc.).

なお、この発明のシステムは、専用のシステムによらず、通常のコンピュータシステムを用いて実現可能である。 It should be noted that the system of the invention not only by a dedicated system can be realized using a normal computer system. 例えば、上述の動作を実行するためのプログラムをコンピュータ読み取り可能な記録媒体(FD、CD−ROM、DVD等)に格納して配布し、該プログラムをコンピュータにインストールすることにより、上述の処理を実行する仮想マシン管理サーバ2等を構成してもよい。 For example, by installing a program for executing the above operation computer-readable recording medium (FD, CD-ROM, DVD, etc.) and distributed and stored in, the program on the computer, executes the above-described processing the virtual machine management server 2 or the like which may be constituted. また、インターネット等のネットワーク10上のサーバ装置が有するディスク装置に格納しておき、例えばコンピュータにダウンロード等するようにしてもよい。 Also, be stored in a disk device of a server device over a network 10 such as the Internet, may be downloaded or the like, for example, in a computer.
また、上述の機能を、OSが分担又はOSとアプリケーションの共同より実現する場合等には、OS以外の部分のみを媒体に格納して配布してもよく、また、コンピュータにダウンロード等してもよい。 Further, the above functions, the like if the OS is to realize than joint sharing or OS and applications may be distributed by storing only the portion other than the OS in the medium, also be downloaded to a computer good.

本発明の第1の実施形態の仮想マシンシステムの構成を示す図である。 It is a diagram showing a configuration of a virtual machine system of the first embodiment of the present invention. 仮想マシン管理サーバの構成を示す図である。 It is a diagram showing a configuration of a virtual machine management server. 仮想マシンサーバ情報のデータ構造の一例を示す図である。 Is a diagram illustrating an example of the data structure of the virtual machine server information. ファイルサーバ情報のデータ構造の一例を示す図である。 Is a diagram illustrating an example of the data structure of the file server information. 仮想マシン情報のデータ構造の一例を示す図である。 Is a diagram illustrating an example of the data structure of the virtual machine information. イメージファイル情報のデータ構造の一例を示す図である。 Is a diagram illustrating an example of a data structure of image file information. パフォーマンスデータのデータ構造の一例を示す図である。 Is a diagram illustrating an example of a data structure of the performance data. 仮想マシンサーバの論理構成の概略図の一例をである。 It is an example of a schematic diagram of a logical configuration of the virtual machine server. 自動作成処理を説明するためのフローチャートである。 Is a flowchart illustrating the automatic creation processing. 最適配置処理を説明するためのフローチャートである。 Is a flow chart for explaining the optimal arrangement processing. 稼働マシン算出処理を説明するためのフローチャートである。 It is a flowchart for explaining the operation machine calculation process.

符号の説明 DESCRIPTION OF SYMBOLS

1 クライアント端末 2 仮想マシン管理サーバ 3 仮想マシンサーバ 4 ファイルサーバ 10 ネットワーク 21 記憶部 211 VMサーバ管理DB 1 client terminal 2 virtual machine management server 3 virtual machine server 4 file server 10 network 21 storage unit 211 VM server management DB
212 ファイルサーバ管理DB 212 file server management DB
213 VM管理DB 213 VM management DB
214 VMイメージファイル管理DB 214 VM image file management DB
215 稼働状況管理DB 215 operating state management DB
22 制御部 221 VMサーバ管理部 222 VM最適配置部 223 VM自動作成部 23 通信制御部 22 control unit 221 VM server management unit 222 VM optimal placement unit 223 VM automatic creation unit 23 communication control unit

Claims (4)

  1. 複数の仮想マシンを稼働させる複数のサーバとネットワークを介して接続される仮想マシン管理装置であって、 A virtual machine management apparatus connected via a plurality of servers and network to run multiple virtual machines,
    第1の所定期間において、それぞれの仮想マシン毎に、所定時間毎に取得されたパフォーマンスを示す実測データを記憶する稼働情報管理データベースと、 At a first predetermined time period, for each of the virtual machines, and operation information management database for storing actual data indicating to performance it acquired every predetermined time,
    各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを前記稼働情報管理データベースから読み出す読出手段と、 Reading means for reading out actual measurement data indicating the performance of a predetermined time of each of the virtual machine from the operation information management database,
    前記読み出した各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを用いて、 前記所定時間毎の、各仮想マシンを複数のサーバのいずれかで稼働させた場合の各時間における各仮想マシンのパフォーマンス値を求め、前記求められた所定時間毎の前記仮想マシンのパフォーマンス値が前記所定時間を複数集めた第2の所定期間において最大となる、仮想マシンとサーバの組み合わせを算出する組み合わせ算出手段と、 Using measured data that indicates performance of each predetermined time of the read each said virtual machine, wherein the predetermined time intervals of, for each virtual machine at each time when allowed to run on any of the virtual machine a plurality of servers calculated performance values, the maximum in a second predetermined period of performance values is collected a plurality of the predetermined time of the virtual machine for each of the determined predetermined time, and a combination calculating means for calculating a combination of virtual machines and the server ,
    前記組み合わせ算出手段により算出された仮想マシンとサーバの組み合わせに従って、各仮想マシンのファイルを当該仮想マシンに対応するサーバの記憶領域に格納して各仮想マシンの再配置を行う手段と、 According to the combination of virtual machines and the server calculated by the combination calculating means, and means for performing re-arrangement of the virtual machine file stored in the storage area of ​​the server corresponding to the virtual machines each virtual machine,
    を備えることを特徴とする仮想マシン管理装置。 Virtual machine management system, characterized in that it comprises a.
  2. 前記読出手段は、各前記サーバの記憶容量に関するデータと、各前記仮想マシンの記憶容量に関するデータと、を前記稼働情報管理データベースからさらに読み出し、 The reading means further reads a data relating to the storage capacity of each said server, data relating to the storage capacity of each said virtual machine, from the operation information management database,
    前記組み合わせ算出手段は、前記読出手段により読み出した、各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データと、各前記サーバの記憶容量に関するデータと、各前記仮想マシンの記憶容量に関するデータと、を算出条件に用いて、前記仮想マシンとサーバの組み合わせを算出する、 Wherein the combination calculation means read by the reading means, the measured data indicating the performance of a predetermined time of each of the virtual machines, and the data relating to the storage capacity of each said server, data relating to the storage capacity of each said virtual machine, using the calculation conditions, it calculates the combination of the virtual machines and the server,
    ことを特徴とする請求項に記載の仮想マシン管理装置。 Virtual machine management system according to claim 1, characterized in that.
  3. 仮想マシンの作成要求を受信する手段と、 It means for receiving a request to create a virtual machine,
    各前記サーバの記憶領域の使用量と、前記受信した作成要求が示す仮想マシンのファイル容量と、に基づいて、前記作成要求が示す仮想マシンのファイルを記憶領域に格納可能なサーバを決定する手段と、 And usage of the storage area of ​​each of the servers, and the file capacity of the virtual machine indicated by the creation request thus received, based on means for determining a server capable of storing files of the virtual machine to a storage area where the creation request is shown When,
    前記決定したサーバの記憶領域に、前記作成要求が示す仮想マシンのファイルを格納する手段と、 In a storage area of ​​the server that the determined, means for storing the file of the virtual machine the creation request is shown,
    を備えることを特徴とする請求項1 または2に記載の仮想マシン管理装置。 Virtual machine management system according to claim 1 or 2, characterized in that it comprises a.
  4. 複数の仮想マシンを稼働させる複数のサーバとネットワークを介して接続されるコンピュータに、 A computer connected through a plurality of servers and network to run multiple virtual machines,
    第1の所定期間において、それぞれの仮想マシン毎に、所定時間毎に取得されたパフォーマンスを示す実測データを稼働情報管理データベースに記憶する記憶ステップ、 At a first predetermined time period, for each of the virtual machines, storage step of storing the measured data indicating the by performance acquired at predetermined time intervals in the operational information management database,
    各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを前記稼働情報管理データベースから読み出す読出ステップ、 Reading step of reading the actual measurement data indicating the performance of a predetermined time of each of the virtual machine from the operation information management database,
    前記読出ステップにより読み出した、各前記仮想マシンの所定時間毎のパフォーマンスを示す実測データを用いて、 前記所定時間毎の、各仮想マシンを複数のサーバのいずれかで稼働させた場合の各時間における各仮想マシンのパフォーマンス値を求め、前記求められた所定時間毎の前記仮想マシンのパフォーマンス値が前記所定時間を複数集めた第2の所定期間において最大となる、仮想マシンとサーバの組み合わせを算出する組み合わせ算出ステップ、 Said read by the read step, each said using measured data that indicates performance of each predetermined time of a virtual machine, for each of the predetermined time, at each time when is operated in any of the multiple servers each virtual machine calculated performance values for each virtual machine, the maximum in a second predetermined period of performance values is collected a plurality of the predetermined time of the virtual machine for each of the determined predetermined time, calculates the combination of virtual machines and the server combination calculation step,
    前記組み合わせ算出ステップにより算出された仮想マシンとサーバの組み合わせに従って、各仮想マシンのファイルを当該仮想マシンに対応するサーバの記憶領域に格納させて各仮想マシンの再配置を行うステップ、 Wherein according to the combination of virtual machines and the server calculated by the combination calculating step, the step of the file for each virtual machine to re-arrangement of the virtual machine is stored in a storage area of ​​the server corresponding to the virtual machine,
    を実行させるプログラム。 Program to be run.
JP2003349017A 2003-10-08 2003-10-08 The virtual machine management system and program Active JP3861087B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2003349017A JP3861087B2 (en) 2003-10-08 2003-10-08 The virtual machine management system and program

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2003349017A JP3861087B2 (en) 2003-10-08 2003-10-08 The virtual machine management system and program

Publications (2)

Publication Number Publication Date
JP2005115653A true JP2005115653A (en) 2005-04-28
JP3861087B2 true JP3861087B2 (en) 2006-12-20

Family

ID=34540997

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2003349017A Active JP3861087B2 (en) 2003-10-08 2003-10-08 The virtual machine management system and program

Country Status (1)

Country Link
JP (1) JP3861087B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2010109681A1 (en) 2009-03-25 2010-09-30 株式会社日立製作所 A computer system, resource management server of a computer system, and resource management method of a computer system

Families Citing this family (49)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4519098B2 (en) * 2006-03-30 2010-08-04 株式会社日立製作所 Management method of a computer, computer system, and the management program
US8112527B2 (en) 2006-05-24 2012-02-07 Nec Corporation Virtual machine management apparatus, and virtual machine management method and program
JP4609380B2 (en) * 2006-05-31 2011-01-12 日本電気株式会社 Virtual server management system and its method and management server device
JP4240062B2 (en) 2006-05-31 2009-03-18 日本電気株式会社 Computer system and performance measurement method and management server device
US8346933B2 (en) 2006-11-24 2013-01-01 Nec Corporation Virtual machine location system, virtual machine location method, program, virtual machine manager, and server
JP5218390B2 (en) * 2007-02-23 2013-06-26 日本電気株式会社 Autonomous control server, the virtual server control method, and program
JP4853717B2 (en) 2007-02-23 2012-01-11 日本電気株式会社 Server migration planning system, server migration plan how to create
JP4557178B2 (en) * 2007-03-02 2010-10-06 日本電気株式会社 Virtual machine management system, the method and program
JP4739271B2 (en) * 2007-04-19 2011-08-03 株式会社富士通アドバンストエンジニアリング Power supply control device, the virtual server control system, the power supply control method and power supply control program
JP4739272B2 (en) * 2007-04-19 2011-08-03 株式会社富士通アドバンストエンジニアリング Load balancer, the virtual server control system, a load balancing method and load balancing program
JP5206674B2 (en) * 2007-05-24 2013-06-12 日本電気株式会社 The virtual machine management system, virtual machine management method, and a virtual machine management program
US8069341B2 (en) * 2007-06-29 2011-11-29 Microsoft Corporation Unified provisioning of physical and virtual images
JP5229590B2 (en) * 2007-09-18 2013-07-03 日本電気株式会社 Server reclassifications support system, server reclassifications support method
JP5056346B2 (en) * 2007-10-29 2012-10-24 日本電気株式会社 The information processing apparatus, an information processing system, a control method of the movement process of the virtual server, and a program
JP4906686B2 (en) * 2007-11-19 2012-03-28 三菱電機株式会社 Virtual machine server sizing apparatus, and a virtual machine server sizing method, and a virtual machine server sizing program
US8719624B2 (en) 2007-12-26 2014-05-06 Nec Corporation Redundant configuration management system and method
US9141490B2 (en) 2007-12-26 2015-09-22 Nec Corporation Graceful degradation designing system and method
JP4577384B2 (en) 2008-03-14 2010-11-10 日本電気株式会社 Management machine, management system, management program, and how to manage
JP2009237859A (en) * 2008-03-27 2009-10-15 Nec Corp Virtual machine management system
JP2009244999A (en) 2008-03-28 2009-10-22 Fujitsu Ltd Virtual machine management program and management server device
JP5006280B2 (en) * 2008-07-17 2012-08-22 Kddi株式会社 Network operations management method and apparatus
EP2345964A4 (en) * 2008-10-13 2013-11-20 Mitsubishi Electric Corp Resource allocation device, resource allocation program, recording medium, and resource allocation method
US8799895B2 (en) 2008-12-22 2014-08-05 Electronics And Telecommunications Research Institute Virtualization-based resource management apparatus and method and computing system for virtualization-based resource management
KR101259548B1 (en) 2008-12-22 2013-04-30 한국전자통신연구원 System and Method for Resource Management base of Virtualization and Computing System for Resource Management base of Virtualization
JP5257077B2 (en) * 2009-01-06 2013-08-07 日本電気株式会社 Resource allocation device, its method and program
JP5245852B2 (en) * 2009-01-17 2013-07-24 日本電気株式会社 Server process distribution system, the server processing distribution method and server process distribution program
JP5359328B2 (en) * 2009-02-02 2013-12-04 日本電気株式会社 Virtual machine start-up control system, the startup control method, information processing apparatus, a program and a recording medium
JP5504651B2 (en) * 2009-03-06 2014-05-28 日本電気株式会社 Virtual machine system, an information processing apparatus, the resource management method, program and recording medium
CN102449603B (en) 2009-06-01 2014-10-08 富士通株式会社 Server hypervisor, management server and virtual server configuration
WO2010140194A1 (en) * 2009-06-05 2010-12-09 富士通株式会社 Information processing system management method, information processing system, recording medium, and management program
GB2477092A (en) * 2010-01-20 2011-07-27 Nec Corp Selecting virtual machine host servers based on client device location
JP5556393B2 (en) 2010-06-04 2014-07-23 富士通株式会社 Network system, the arrangement method of the management server and the virtual machine
JP5360000B2 (en) * 2010-06-22 2013-12-04 日本電気株式会社 Virtual server management system and its method and management server device
JP2012018515A (en) 2010-07-07 2012-01-26 Fujitsu Ltd Information processor, control method, and control program
JP5678508B2 (en) * 2010-07-29 2015-03-04 日本電気株式会社 Thin client system, management server, virtual machine creation management method and the virtual machine creation management program
JP5870927B2 (en) * 2010-10-07 2016-03-01 日本電気株式会社 Server system, the management apparatus, a server management method, and a program
JPWO2012053393A1 (en) * 2010-10-19 2014-02-24 株式会社日立製作所 How to place a virtual machine and apparatus
JP5506653B2 (en) * 2010-12-27 2014-05-28 三菱電機株式会社 License management system, a license management method, and a license management program
JP5417553B2 (en) 2011-02-28 2014-02-19 株式会社日立製作所 Management method of the management computer and a computer system
JP5577283B2 (en) * 2011-03-29 2014-08-20 株式会社エヌ・ティ・ティ・データ Virtual machine start-up device, the virtual machine start-up method, the virtual machine start-up program
JP5773142B2 (en) * 2011-06-22 2015-09-02 株式会社日立製作所 Calculating apparatus calculating method and arrangement pattern of the arrangement pattern of the computer system
US9374314B2 (en) * 2012-02-26 2016-06-21 Palo Alto Research Center Incorporated QoS aware balancing in data centers
JP5827594B2 (en) * 2012-05-17 2015-12-02 日本電信電話株式会社 Virtual machine placement device and the virtual machine placement method
JP6044131B2 (en) 2012-06-25 2016-12-14 富士通株式会社 Program, the management server and virtual machine movement control method
WO2014045413A1 (en) 2012-09-21 2014-03-27 株式会社東芝 System management device, network system, system management method, and program
WO2014087545A1 (en) * 2012-12-07 2014-06-12 株式会社日立製作所 Virtual machine deployment method and computer system
US9762506B2 (en) 2013-02-06 2017-09-12 Hitachi, Ltd. Virtual guest management system and virtual guest management method
JP5477497B2 (en) * 2013-05-17 2014-04-23 日本電気株式会社 Virtual server management system and its method and management server device
JP6031462B2 (en) * 2014-02-12 2016-11-24 日本電信電話株式会社 Virtual machine placement apparatus and method, and program

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2010109681A1 (en) 2009-03-25 2010-09-30 株式会社日立製作所 A computer system, resource management server of a computer system, and resource management method of a computer system
JP5130375B2 (en) * 2009-03-25 2013-01-30 株式会社日立製作所 Computer system, computer system resources resource management server, and the resource management method of a computer system

Also Published As

Publication number Publication date Type
JP2005115653A (en) 2005-04-28 application

Similar Documents

Publication Publication Date Title
US20060047813A1 (en) Provisioning manager for optimizing selection of available resources
US8719415B1 (en) Use of temporarily available computing nodes for dynamic scaling of a cluster
US8321558B1 (en) Dynamically monitoring and modifying distributed execution of programs
US20050193115A1 (en) System and method for describing and automatically managing resources
US20020156884A1 (en) Method and system for providing and viewing performance analysis of resource groups
US20130019242A1 (en) Cloud-Based Test System and Method and Computer-Readable Storage Medium with Computer Program to Execute the Method
US20050262505A1 (en) Method and apparatus for dynamic memory resource management
US20120089980A1 (en) Allocating virtual machines according to user-specific virtual machine metrics
US20050154852A1 (en) Method, device and program for managing volume
US8260840B1 (en) Dynamic scaling of a cluster of computing nodes used for distributed execution of a program
US7171459B2 (en) Method and apparatus for handling policies in an enterprise
US20050262504A1 (en) Method and apparatus for dynamic CPU resource management
US20070245338A1 (en) Virtual machine management program and virtual machine management method
US20120096460A1 (en) Apparatus and method for controlling live-migrations of a plurality of virtual machines
US20070118710A1 (en) Storage system and data migration method
US20080133741A1 (en) Computer program and apparatus for controlling computing resources, and distributed processing system
US7444395B2 (en) Method and apparatus for event handling in an enterprise
US20080263401A1 (en) Computer application performance optimization system
US7827286B1 (en) Providing enhanced access to stored data
US20060010289A1 (en) Volume management system and method
US20090006527A1 (en) Autonomic control of a distributed computing system using dynamically assembled resource chains
US20070101334A1 (en) Dynamic policy manager method, system, and computer program product for optimizing fractional resource allocation
JP2007323245A (en) Computer system, performance measuring method, and management server device
EP2228719A1 (en) Method of executing a virtual machine, computing system and computer program
US20140040892A1 (en) Facilitating Customer-Initiated Virtual Machine Migration and Swapping

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20050705

A871 Explanation of circumstances concerning accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A871

Effective date: 20050811

A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20051026

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20051108

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20060131

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20060403

A911 Transfer of reconsideration by examiner before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20060412

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20060912

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20060925

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20090929

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100929

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110929

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120929

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130929

Year of fee payment: 7

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250