JP6327810B2 - モビリティ動作リソース割り当てのための方法、システム、コンピュータ・プログラム - Google Patents

モビリティ動作リソース割り当てのための方法、システム、コンピュータ・プログラム Download PDF

Info

Publication number
JP6327810B2
JP6327810B2 JP2013171848A JP2013171848A JP6327810B2 JP 6327810 B2 JP6327810 B2 JP 6327810B2 JP 2013171848 A JP2013171848 A JP 2013171848A JP 2013171848 A JP2013171848 A JP 2013171848A JP 6327810 B2 JP6327810 B2 JP 6327810B2
Authority
JP
Japan
Prior art keywords
mobility
machine
resource allocation
configuration
memory
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.)
Expired - Fee Related
Application number
JP2013171848A
Other languages
English (en)
Other versions
JP2014096136A (ja
Inventor
マリア・ドゥルルド・ガルツァ
ナサニエル・スコット・トムシク
ヴァス・ヴァラバネニ
ニール・リチャード・マリオン
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
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 International Business Machines Corp filed Critical International Business Machines Corp
Publication of JP2014096136A publication Critical patent/JP2014096136A/ja
Application granted granted Critical
Publication of JP6327810B2 publication Critical patent/JP6327810B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • 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/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/485Task life-cycle, e.g. stopping, restarting, resuming execution
    • G06F9/4856Task life-cycle, e.g. stopping, restarting, resuming execution resumption being on a different machine, e.g. task migration, virtual machine migration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • 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/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
    • G06F9/5016Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals the resource being the memory
    • 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/5061Partitioning or combining of resources
    • G06F9/5077Logical partitioning of resources; Management or configuration of virtualized resources
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/4557Distribution of virtual machine instances; Migration and load balancing

Description

本発明は、モビリティ動作リソース割り当てのための方法に関する。
いくつかのデータ処理環境においては、あるコンピューティング環境から別のコンピューティング環境に、アプリケーションまたは作業負荷あるいはその両方をマイグレートする場合がある。例えば、システム仮想化は、単一のホスト(例えばコンピュータ、サーバ等)を、各々がオペレーティング・システムの別個のインスタンスまたはイメージを実行する多数のパーツまたはパーティションに分割することができる技術である。オペレーティング・システムのインスタンスまたはパーティションは、いくつかの方法で相互に分離または隔離されている。例えばパーティションは、それぞれ別個のファイル・システム、別個のユーザ、別個のアプリケーション、および別個のプロセスを有する。しかしながら、パーティションはホストのいくつかのリソースを共有することもある。例えばパーティションは、ホストのメモリ、カーネル、プロセッサ、ハード・ドライブ、または他のソフトウェア、ファームウェア、またはハードウェアあるいはそれら全てを共有することができる。このため、各パーティションまたはオペレーティング・システムのインスタンスは、そのユーザの観点からは別個のサーバまたはマシンのように見て感じることができる。これらのインスタンスは一般に「仮想」または「仮想化」マシンと称され、各パーティションは論理パーティション(LPAR:logical partition)と称することができる。
一般に、1つのサーバまたはデータ処理は多数のLPARのホストになることができる。また、これらのLPAは、あるサーバまたはシステムから別のものに転送またはマイグレートされる場合がある。例えば、ハードウェアの更新または他のタイプの保守サービスを容易にするために、LPARをあるサーバから別のものにマイグレートし、この際にマイグレートしているLPARのオペレーティング・システムおよびホストされるアプリケーションの実行を中断することがないので、中断なしにサービスの運用性を維持することができる。
従って、本発明が解決しようとする課題は、モビリティ動作リソース割り当てのための方法、システム、コンピュータ・プログラムを提供することである。
本開示の一態様によれば、モビリティ動作リソース割り当てのための方法および技法が開示される。この方法は、第1のマシンから第2のマシンに実行中のアプリケーションをマイグレートする要求を受信することと、少なくとも1つの性能ベースのモビリティ設定および少なくとも1つの同時実行性ベースのモビリティ設定を含む複数のモビリティ設定を示す調節可能リソース割り当てモビリティ設定インタフェースを表示することと、インタフェースを介して、マイグレーションに利用するリソース割り当てを規定するモビリティ設定の選択を受信することと、選択されたモビリティ設定によって設定されたようにリソースを用いて第1のマシンから第2のマシンに実行中のアプリケーションをマイグレートすることと、を含む。
本出願、その目的および利点を更に完全に理解するため、これより添付図面と組み合わせて以下の記載を参照する。
本開示の例示的な実施形態を実施可能であるデータ処理システムのネットワークの一実施形態である。 本開示の例示的な実施形態を実施可能であるデータ処理システムの一実施形態である。 本開示の例示的な実施形態を実施可能である、モビリティ動作リソース割り当てのためのデータ処理システムの一実施形態を示す図である。 本開示の例示的な実施形態を実施可能である、モビリティ動作リソース割り当てのためのデータ処理システムの別の実施形態を示す図である。 本開示に従った、モビリティ動作リソース割り当てのための方法の一実施形態を示すフロー図である。
本開示の実施形態は、モビリティ動作リソース割り当てのための方法、システム、およびコンピュータ・プログラムを提供する。例えば、いくつかの実施形態において、この方法および技法は、第1のマシンから第2のマシンに実行中のアプリケーションをマイグレートする要求を受信することと、少なくとも1つの性能ベースのモビリティ設定および少なくとも1つの同時実行性ベースのモビリティ設定を含む複数のモビリティ設定を示す調節可能リソース割り当てモビリティ設定インタフェースを表示することと、インタフェースを介して、マイグレーションに利用するリソース割り当てを規定するモビリティ設定の選択を受信することと、選択されたモビリティ設定によって設定されたようにリソースを用いて第1のマシンから第2のマシンに実行中のアプリケーションをマイグレートすることと、を含む。本開示の実施形態によって、性能または同時実行性ありはその両方の要求に基づいて、アプリケーションのマイグレーションに用いるリソースを柔軟に選択することが可能となる。本開示の実施形態は、ユーザ/管理者がアプリケーションのマイグレーションのために性能ベースまたは同時実行性ベースあるいはその両方の設定を選択することができるインタフェースを利用し、これによって、性能が重要である場合に大きいパーティションの迅速な移動を行うこと、または、性能が重要でない場合に多数のアクティブでないパーティションを同時にマイグレートすること、あるいはその両方を実行する。本開示の実施形態によって、ユーザ/管理者がパーティションごとにモビリティ設定(複数の設定)を適用すること、更に、いくつかのパーティションのマイグレーションに優先順位を付けることを可能とする。
当業者には認められるであろうが、本開示の態様は、システム、方法、またはコンピュータ・プログラムとして具現化することができる。従って、本開示の態様は、全体的にハードウェアの実施形態、全体的にソフトウェアの実施形態(ファームウェア、常駐ソフトウェア、マイクロコード等を含む)、または、ソフトウェアおよびハードウェアの態様を組み合わせた実施形態という形態を取ることができ、それらは全て本明細書において、「回路」、「モジュール」、または「システム」と一般的に称することができる。更に、本開示の態様は、具現化されたコンピュータ読み取り可能プログラム・コードを有する1つ以上のコンピュータ読み取り可能媒体(複数の媒体)において具現化されたコンピュータ・プログラムの形態を取ることも可能である。
1つ以上のコンピュータ使用可能媒体(複数の媒体)またはコンピュータ読み取り可能媒体(複数の媒体)のあらゆる組み合わせを利用することができる。コンピュータ読み取り可能媒体は、コンピュータ読み取り可能信号媒体またはコンピュータ読み取り可能記憶媒体とすることができる。コンピュータ読み取り可能記憶媒体は例えば、限定ではないが、電子、磁気、光、電磁、赤外線、または半導体のシステム、装置、デバイス、または前述のもののいずれかの適切な組み合わせとすることができる。コンピュータ読み取り可能記憶媒体の更に具体的な例(非網羅的な列挙)は、以下を含む。すなわち、1本以上のワイヤを含む電気的接続、携帯型コンピュータ・ディスケット、ハード・ディスク、ランダム・アクセス・メモリ(RAM)、読み取り専用メモリ(ROM)、消去可能プログラマブル読み取り専用メモリ(EPROMまたはフラッシュ・メモリ)、光ファイバ、携帯型コンパクト・ディスク読み取り専用メモリ(CD−ROM)、光記憶デバイス、磁気記憶デバイス、または前述のもののいずれかの適切な組み合わせである。この文書の文脈において、コンピュータ読み取り可能記憶媒体は、命令実行システム、装置、またはデバイスによってまたはそれと接続して用いるためにプログラムを含有または記憶することが可能ないずれかのタンジブルな媒体とすることができる。
コンピュータ読み取り可能信号媒体は、例えばベースバンドにおいてまたは搬送波の一部として、具現化されたコンピュータ読み取り可能プログラム・コードを有する伝播データ信号を含むことができる。かかる伝播信号は様々な形態のいずれかを取ることができ、それらは限定ではないが、電磁、光、またはそれらのいずれかの適切な組み合わせを含む。コンピュータ読み取り可能信号媒体は、コンピュータ読み取り可能記憶媒体でないが、命令実行システム、装置、またはデバイスによってまたはそれと接続して用いるためにプログラムを伝達、伝播、または転送することが可能ないずれかのコンピュータ読み取り可能媒体とすることができる。
コンピュータ読み取り可能媒体上で具現化されるプログラム・コードは、限定ではないが、無線、有線、光ファイバ・ケーブル、RF等、または前述のもののいずれかの適切な組み合わせを含むいずれかの適切な媒体を用いて伝送することができる。
本開示の態様の動作を実行するためのコンピュータ・プログラム・コードは、Java、Smalltalk、C++等のオブジェクト指向プログラミング言語、および「C」プログラミング言語または同様のプログラミング言語等の従来の手順プログラミング言語を含む1つ以上のプログラミング言語のいずれかの組み合わせにおいて記述することができる。プログラム・コードは、全体的にユーザのコンピュータ上で、部分的にユーザのコンピュータ上で、スタンドアロンのソフトウェア・パッケージとして、部分的にユーザのコンピュータ上でおよび部分的にリモート・コンピュータ上で、または全体的にリモート・コンピュータもしくはサーバ上で、実行することができる。後者の場合、リモート・コンピュータは、ローカル・エリア・ネットワーク(LAN)またはワイド・エリア・ネットワーク(WAN)を含むいずれかのタイプのネットワークを介してユーザのコンピュータに接続することができ、または、接続は、(例えばインターネット・サービス・プロバイダを用いてインターネットを介して)外部コンピュータに対して行うことができる。
本開示の実施形態に従った方法、装置(システム)、およびコンピュータ・プログラムのフローチャート図またはブロック図あるいはその両方を参照して、本開示の態様について以下に記載する。フローチャート図またはブロック図あるいはその両方の各ブロック、およびフローチャート図またはブロック図あるいはその両方におけるブロックの組み合わせは、コンピュータ・プログラム命令によって実施可能であることは理解されよう。これらのコンピュータ・プログラム命令は、汎用コンピュータ、特殊目的コンピュータ、または他のプログラマブル・データ処理装置のプロセッサに提供されて機械を生成することができ、これによって、コンピュータまたは他のプログラマブル・データ処理装置のプロセッサによって実行される命令が、フローチャートまたはブロック図あるいはその両方のブロックまたは複数のブロックに規定された機能/行為を実施するための手段を生成するようになっている。
また、これらのコンピュータ・プログラム命令はコンピュータ読み取り可能媒体に記憶することができ、これによって、コンピュータまたは他のプログラマブル・データ処理装置に特定の方法で機能するように指示することができ、これにより、コンピュータ読み取り可能媒体に記憶された命令が、フローチャートまたはブロック図あるいはその両方のブロックまたは複数のブロックに規定された機能/行為を実施する命令手段を含む製造品を生成するようになっている。
また、コンピュータ・プログラム命令を、コンピュータまたは他のプログラマブル・データ処理装置にロードして、そのコンピュータまたは他のプログラマブル装置上で一連の動作ステップを実行させてコンピュータ実施プロセスを生成することができ、これによって、コンピュータまたは他のプログラマブル装置上で実行する命令が、フローチャートまたはブロック図あるいはその両方のブロックまたは複数のブロックに規定された機能/行為を実施するためのプロセスを提供するようになっている。
これより図面、具体的には図1および図2を参照して、本開示の例示的な実施形態を実施可能であるデータ処理環境の例示的な図を与える。図1および図2は単なる例示であり、異なる実施形態を実施可能である実施形態に関していかなる限定の主張も暗示も意図していないことは認められよう。図示する実施形態に対して多くの変更を行うことができる。
図1は、本開示の例示的な実施形態を実施可能であるデータ処理システムのネットワークを図で表したものである。ネットワーク・データ処理システム100は、本開示の例示的な実施形態を実施可能であるコンピュータのネットワークである。ネットワーク・データ処理システム100はネットワーク130を含む。これは、ネットワーク・データ処理システム100内で相互接続された様々なデバイスおよびコンピュータの間の通信リンクを提供するために用いられる媒体である。ネットワーク130は、有線通信リンク、無線通信リンク、または光ファイバ・ケーブル等の接続を含むことができる。
いくつかの実施形態においては、サーバ140およびサーバ150が、データ記憶160と共に、ネットワーク130に接続する。サーバ140およびサーバ150は、例えばIBM(登録商標)Power Systems(商標)サーバとすることができる。更に、クライアント110およびクライアント120がネットワーク130に接続する。クライアント110および120は、例えばパーソナル・コンピュータまたはネットワーク・コンピュータとすることができる。図示する例では、サーバ140は、限定ではないが、データ・ファイル、オペレーティング・システム・イメージ、およびアプリケーション等のデータまたはサービスあるいはその両方を、クライアント110および120に提供する。ネットワーク・データ処理システム100は、追加のサーバ、クライアント、および他のデバイスを含むことも可能である。
図示する例において、ネットワーク・データ処理システム100はインターネットであり、ネットワーク130は、TCP/IP(Transmission Control Protocol/Internet Protocol)プロトコル・スイートを用いて相互に通信を行うネットワークおよびゲートウェイの全世界的な集合を表す。インターネットの中心にあるのは、主要なノードまたはホスト・コンピュータ間の高速データ通信ラインのバックボーンであり、データおよびメッセージをルーティングする何千もの民生用、政府用、教育用、および他のコンピュータ・システムから成る。むろん、ネットワーク・データ処理システム100は、例えばイントラネット、ローカル・エリア・ネットワーク(LAN)、またはワイド・エリア・ネットワーク(WAN)等の多数の異なるタイプのネットワークとして実施することも可能である。図1は、異なる例示的な実施形態のためのアーキテクチャの限定としてではなく、一例として意図するものである。
図2はデータ処理システム200の一実施形態であり、これは例えば、限定ではないが、本開示に従ったモビリティ動作リソース割り当てのためのシステムの一実施形態を実施可能であるクライアント110またはサーバ140あるいはその両方である。この実施形態において、データ処理システム200はバスまたは通信機構(fabric)202を含み、これは、プロセッサ・ユニット204、メモリ206、永続性記憶装置208、通信ユニット210、入出力(I/O)ユニット212、およびディスプレイ214間の通信を提供する。
プロセッサ・ユニット204は、メモリ206にロードすることができるソフトウェアのための命令を実行するように機能する。プロセッサ・ユニット204は、特定の実施に応じて、1つ以上のプロセッサのセットとすることができ、またはマルチプロセッサ・コアとすることができる。更に、プロセッサ・ユニット204は、メイン・プロセッサが二次プロセッサと共に単一チップ上に存在する1つ以上のヘテロジーニアス・プロセッサ・システムを用いて実施することができる。別の例示的な例では、プロセッサ・ユニット204は、同一のタイプのプロセッサを多数含む対称型マルチプロセッサ・システムとすることも可能である。
いくつかの実施形態において、メモリ206は、ランダム・アクセス・メモリまたは他のいずれかの適切な揮発性もしくは不揮発性記憶デバイスとすることができる。永続性記憶装置208は、特定の実施に応じて様々な形態を取ることができる。例えば、永続性記憶装置208は、1つ以上のコンポーネントまたはデバイスを含むことができる。永続性記憶装置208は、ハード・ドライブ、フラッシュ・メモリ、書き換え可能光ディスク、書き換え可能磁気テープ、または上記のものの何らかの組み合わせとすることができる。また、永続性記憶装置208によって用いられる媒体は、限定ではないが、着脱可能ハード・ドライブ等、着脱可能なものとすることも可能である。
通信ユニット210は、他のデータ処理システムまたはデバイスとの通信を可能とする。これらの例では、通信ユニット210はネットワーク・インタフェース・カードである。現在利用可能なタイプのネットワーク・インタフェース・アダプタのいくつかの例として、モデム、ケーブル・モデム、およびイーサネット・カードが挙げられる。通信ユニット210は、物理通信リンクおよび無線通信リンクの一方または双方を用いることで通信を行うことを可能とする。
入出力ユニット212は、データ処理システム200に接続することができる他のデバイスとの間でデータの入出力を可能とする。いくつかの実施形態において、入出力ユニット212は、キーボードおよびマウスによってユーザ入力のための接続を提供することができる。更に、入出力ユニット212はプリンタに出力を送信することができる。ディスプレイ214は、ユーザに情報を表示するための機構を提供する。
永続性記憶装置208上に、オペレーティング・システムおよびアプリケーションまたはプログラムのための命令が位置している。これらの命令は、プロセッサ・ユニット204によって実行するためにメモリ206にロードすることができる。メモリ206等のメモリに位置することができるコンピュータ実施命令を用いて、プロセッサ・ユニット204によって、異なる実施形態のプロセスを実行することができる。これらの命令は、プログラム・コード、コンピュータ使用可能プログラム・コード、またはコンピュータ読み取り可能プログラム・コードと称され、プロセッサ・ユニット204におけるプロセッサにより読み取って実行することができる。異なる実施形態におけるプログラム・コードは、メモリ206または永続性記憶装置208等の異なる物理的またはタンジブルなコンピュータ読み取り可能媒体上に具現化することができる。
プログラム・コード216は、選択的に着脱可能なコンピュータ読み取り可能媒体218上に関数の形態で位置しており、プロセッサ・ユニット204により実行するためにデータ処理システム200にロードまたは転送することができる。これらの例において、プログラム・コード216およびコンピュータ読み取り可能媒体218がコンピュータ・プログラム220を形成する。一例では、コンピュータ読み取り可能媒体218は、例えば光ディスクまたは磁気ディスク等のタンジブルな形態とすることができ、永続性記憶装置208の一部であるハード・ドライブ等の記憶デバイス上に転送するために永続性記憶装置208の一部であるドライブまたは他のデバイスに挿入または配置される。タンジブルな形態では、コンピュータ読み取り可能媒体218は、データ処理システム200に接続されたハード・ドライブ、サム・ドライブ、またはフラッシュ・メモリ等の永続性記憶装置の形態を取ることも可能である。コンピュータ読み取り可能媒体218のタンジブルな形態は、コンピュータ記録可能記憶媒体とも称される。いくつかの例では、コンピュータ読み取り可能媒体218は着脱可能でない場合がある。
あるいは、プログラム・コード216のデータ処理システム200への転送は、コンピュータ読み取り可能媒体218から、通信ユニット210への通信リンクを介して、または入出力ユニット212への接続を介して行うことができる。記載した例では、通信リンクまたは接続あるいはその両方は物理的または無線とすることができる。
データ処理システム200について例示した様々なコンポーネントは、異なる実施形態を実施可能な方法についてアーキテクチャの限定を加えることを意図していない。異なる例示的な実施形態は、データ処理システム200について例示したものに対する追加のまたは代替のコンポーネントを含むデータ処理システムにおいて実施することができる。図2に示す他のコンポーネントは、図示する例示的な例から変更することができる。例えば、データ処理システム200における記憶デバイスは、データを記憶することができるあらゆるハードウェア装置である。メモリ206、永続性記憶装置208、およびコンピュータ読み取り可能媒体218は、タンジブルな形態の記憶デバイスの例である。
図3は、モビリティ動作リソース割り当てのためのシステム300の例示的な実施形態である。システム300は、限定ではないが、サーバ140または150あるいはその両方、クライアント110または120あるいはその両方等のデータ処理システムもしくはプラットフォーム上で、または他のデータ処理システム位置において実施することができる。図3に示す実施形態においては、システム300は、サーバ・システム310およびサーバ・システム312を含む。コンピュータ・システムのサーバ・システム310および312のプロセッサ、メモリ、および他のハードウェア・リソースは、別個に動作可能である論理パーティション(LPAR)に配分することができる。各LPARは、それ自体のオペレーティング・システムおよびアプリケーションを実行する。例示する実施形態において、サーバ・システム310はLPAR320および322を含むが、もっと多数または少数のLPARを提供可能であることは理解されよう。LPARは、コンピュータの物理ハードウェア・リソースのサブセット(すなわちサーバ環境の基礎にあるハードウェアのサブセット)が割り当てられ、サーバ環境内で別個のコンピュータ/仮想マシンとして仮想化されている。プロセッサ容量、メモリ等のリソース、または他のいずれかのタイプのリソースは、特定のLPARに割り当てることができる。各LPARは、それ自体の仮想オペレーティング・システム(OA)・インスタンス(例えば各LPAR320および322におけるオペレーティング・システム324および326)、アプリケーション・プログラム(例えばLPAR320および322におけるアプリケーション(複数のアプリケーション)328および330)、または関連ファイルあるいはそれら全てを有するので、多数のオペレーティング・システムがサーバ環境内で同時に実行することが可能となる。
(サーバ・システム310内の)LPAR340および(サーバ・システム312内の)LPAR342は、入出力機能性の実施に専用のものであり、仮想入出力サーバ(VIOS:virtual I/O server)・ソフトウェア/ファームウェアを実行する(本明細書に記載するような様々な機能を実行するためのソフトウェア、論理、または実行可能コードあるいはそれら全て(例えばプロセッサまたは他のタイプの論理チップに常駐するプロセッサ・ユニット、ハードウェア論理上で実行するソフトウェアまたはアルゴリズムあるいはその両方として常駐し、データ処理システム内の単一の集積回路に集中化するかまたは異なるチップ間に分散している))。VIOSソフトウェア/ファームウェアを実行するLPAR340/342を、本明細書において、VIOS LPARまたはVIOSパーティション340/342と称することができる。同様に、VIOS機能性を提供する実行対象のVIOSソフトウェア/ファームウェアを、本明細書ではVIOSと称することができる。論理パーティション処理は、各サーバ・システム310および312内のソフトウェア346および348(「ハイパーバイザ」)によって容易になる。これらは、コンピュータ・システムのハードウェアを制御し、LPARのオペレーティング・システムを監視する。ハイパーバイザ346/348は、論理パーティションのオペレーティング・システム・レベルとサーバ・システム物理ハードウェアとの間のレベルで動作する。ハイパーバイザ346/348は、実施に応じて、直接コンピュータ・システムのハードウェア上で、または従来のオペレーティング・システム環境内で動作することができる。
図3に示す実施形態において、LPAR320および322は、サーバ・システム310からサーバ・システム312にマイグレートされている。異なるハードウェア・プラットフォーム間で、単一のLPARまたは多数のLPARをマイグレートすることが可能であることは理解されよう。更に、多数のLPARを直列にまたは同時にマイグレートすることができる。サーバ・システム310からサーバ・システム312へのLPARの転送またはマイグレーションは、ハードウェア管理コンソール(HMC:hardware management console)350によって調整される。HMC350またはその部分は、ハードウェア・ベース、ソフトウェア・ベース、またはそれら双方の何らかの組み合わせとすることができる既知の技法を用いて、いずれかの適切な方法で実施することができる。例えばHMC350は、本明細書に記載するような様々な機能を実行するためのソフトウェア、論理、または実行可能コードあるいはそれら全てを含むことができる(例えばプロセッサまたは他のタイプの論理チップに常駐するプロセッサ・ユニット、ハードウェア論理上で実行するソフトウェアまたはアルゴリズムあるいはその両方として常駐し、データ処理システム内の単一の集積回路に集中化するかまたは異なるチップ間に分散している))。パーティションの転送は、イーサネット352で(例えばiSCIプロトコルを用いて)、または各サービス・プロセッサ360および362を介してプライベート・イーサネット354で実行することができる。また、サーバ・システム310および312は、各VIOSパーティション340および342によって、SAN(storage area network)368を介して外部記憶サブシステム366にアクセスするように構成することができる。本明細書において行う記載はサーバ・システム310からサーバ・システム312へのLPARのマイグレーションを対象とすることができるが、サーバ・システム310および312の各々を同様に構成して本明細書に記載する機能を可能とすることができる。
作動中のLPARモビリティによって、OSおよびアプリケーションを有する動作中のLPAR(複数のLPAR)を、ある物理ハードウェア・プラットフォームから異なるハードウェア・プラットフォームに転送することができる。VIOSパーティション340および342は、あるハードウェア・プラットフォームから別のハードウェア・プラットフォームにパーティション状態を転送する機能を提供するためのコードまたはルーチンあるいはその両方を用いて構成されている。モビリティ機能がイネーブルになっているVIOSパーティションは、ムーバー・サービス・パーティション(MSP:mover service partition)と称することができる場合がある。MSPの少なくとも1つの仮想非対称サービス・インタフェース(VASI:virtual asynchronous services interface)デバイスによって、MSPは各ハイパーバイザと通信を行うことができる。ハイパーバイザ346/348は、パーティションのメモリを含む、パーティションの状態に対応した情報を維持する。マイグレーションの間、ハイパーバイザ346および348は、MSPパーティション間でパーティション情報(例えば状態情報およびメモリ・イメージ)を転送するためのサポートを与える。ソースおよび宛先のムーバー・サーバ・パーティションは、ネットワークを介して相互に通信を行う。ソースおよび宛先のサーバ・システムの双方で、VASIデバイスがMSPとハイパーバイザとの間の通信を提供する。パーティションのメモリ・イメージを移動させるため、ハイパーバイザは、中央処理ユニット(CPU)およびメモリ・リソースを提供するソースおよび宛先のMSPを利用して、パーティションのメモリ・ページを送信し追跡する。マイグレートしているパーティションの情報が宛先MSPに送信された後に、そのパーティションがメモリ・ページに書き込むと、ハイパーバイザは、更新された書き込み内容を用いたメモリ・ページの再送信を管理するので、パーティションはモビリティ動作中に実行を継続することができる。このため、データは、ソース・サーバ・システム上のソース・ハイパーバイザからソースMSPを介して宛先MSPに、更に宛先サーバ・システム上のハイパーバイザに向かう。
場合によっては、パーティションのメモリ・ページが極めて大きいことがある(例えばデータベース実行)。更に、MSPが、大きいパーティションのモビリティまたは比較的多数の同時パーティション・モビリティ動作をサポートする必要がある場合、ハイパーバイザによって利用されるVIOS CPUサイクル量は増大する。従って、モビリティ動作のためのデータ転送の時間長および速度は、MSPがハイパーバイザに与えるメモリ量およびCPUサイクルによって限定される。
本開示の実施形態によって、パーティション・モビリティ動作に用いるリソースの選択または構成あるいはその両方を行う際に、性能および同時実行性を考慮することまたはそれらのバランスを取ることあるいはその両方が可能となる。上述のように、モビリティ動作のためのデータ転送の時間長および速度は、パーティションのメモリをマイグレートするためにハイパーバイザがアクセスすることができるメモリ量およびメモリ・バッファを管理するために用いられるCPUスレッドの数に依存する。メモリ量は、モビリティ動作当たりの割り当てられたメモリ・バッファのサイズおよび数の双方に依存する。更に、モビリティ動作当たりのCPUの使用量は、用いられるスレッド数および実行されるスレッドの時間長に依存する。本開示の実施形態によって、パーティション・モビリティ動作の同時実行性対性能のニーズに合うように、メモリ・リソースおよびCPUスレッド構成(例えば数および実行時間)を柔軟に選択することが可能となる。例えば、比較的メモリ使用が少ないパーティションでは、多数の同時実行動作を低速で実行するか、または少数の同時実行動作を高速で実行することができる。
図3に示す実施形態において、HMC350は、割り当てモジュール370、インタフェース372、およびモビリティ構成データ374を含む。割り当てモジュール370を用いて、パーティション・モビリティ動作のための所望のリソース割り当ての選択または設定あるいはその両方を行う。割り当て設定は、特定のモビリティ動作またはモビリティ動作のセットに適用することができる。例えば、割り当て設定は、多数のパーティションを扱うモビリティ動作では各パーティションに適用するように選択することができる。また、割り当て設定は、いくつかのパーティションについて適用または変更あるいはその両方を行うように選択することも可能である(モビリティ動作が多数のパーティションを扱うことができる場合であっても)。例えば、いくつかの実施形態において、1つのモビリティ動作が5つの異なるパーティション(LPAR〜LPAR)を対象とする場合がある。LPAR、LPAR、およびLPARに特定のパーティション割り当て設定を設定/適用することができ、LPARおよびLPARには異なる割り当て設定を設定/適用することができる。モビリティ動作を開始し、異なる割り当て設定を自動的にパーティションごとに適用することができる(例えばあるLPARセットにある設定を適用し、異なるLPARセットに異なる設定を適用する)。割り当てモジュール370は、ハードウェア・ベース、ソフトウェア・ベース、またはそれら双方の何らかの組み合わせとすることができる既知の技法を用いて、いずれかの適切な方法で実施することができる。例えば割り当てモジュール370は、本明細書に記載するような様々な機能を実行するためのソフトウェア、論理、または実行可能コードあるいはそれら全てを含むことができる(例えばプロセッサまたは他のタイプの論理チップに常駐するプロセッサ・ユニット、ハードウェア論理上で実行するソフトウェアまたはアルゴリズムあるいはその両方として常駐し、データ処理システム内の単一の集積回路に集中化するかまたは異なるチップ間に分散している))。
モビリティ構成データ374は、パーティション・モビリティ動作に適用するメモリまたはCPUあるいはその両方のリソースの割り当てに関連付けた情報を含む。例えば例示の実施形態では、モビリティ構成データ374は、メモリ構成データ382およびスレッド構成データ384を含む1つ以上のモビリティ設定380を含む。メモリ構成データ382およびスレッド構成データ384のための特定の値または設定あるいはその両方は、モビリティ動作のための特定の各メモリ・バッファおよびCPUスレッドの構成設定に対応することができる。メモリ構成データ382は、メモリ・リソースの量またはサイズあるいはその両方に対応することができる。スレッド構成データ384は、CPUスレッドの量、スレッドの実行時間、またはスレッド優先順位付けあるいはそれら全てに対応することができる。性能または同時実行性あるいはその両方の要求に対処するように、他のタイプのリソースまたはリソース属性を同様にモビリティ動作のために設定する/割り当てることも可能であることは理解されよう。
インタフェース372を用いて、グラフィカル・ユーザ・インタフェース(GUI)または他のタイプのインタフェースを提供して、ユーザ/管理者がパーティション・モビリティ動作に適用するリソース割り当て構成設定を選択することを可能とする。インタフェース372は、ハードウェア・ベース、ソフトウェア・ベース、またはそれら双方の何らかの組み合わせとすることができる既知の技法を用いて、いずれかの適切な方法で実施することができる。例えばインタフェース372は、本明細書に記載するような様々な機能を実行するためのソフトウェア、論理、または実行可能コードあるいはそれら全てを含むことができる(例えばプロセッサまたは他のタイプの論理チップに常駐するプロセッサ・ユニット、ハードウェア論理上で実行するソフトウェアまたはアルゴリズムあるいはその両方として常駐し、データ処理システム内の単一の集積回路に集中化するかまたは異なるチップ間に分散している)。
いくつかの実施形態において、インタフェース372は、ユーザ/管理者によって選択された特定の設定380に基づいてメモリ構成データ382およびスレッド構成データ384に適用されるデフォルト値を識別するように構成することができる。例えば、いくつかの実施形態では、インタフェース372がスライダ・バーまたは他のタイプのGUIを含み、このスライダ・バー/GUI上の特定の値/設定が特定のメモリ構成データ382またはスレッド構成データ384あるいはその両方の設定に対応することができる。この実施形態では、スライダ・バー/GUIの値または設定が低いことは性能が高いことに相当するので、大量または大きいサイズあるいはその両方のメモリ・リソースをハイパーバイザに対して割り当てまたは提供あるいはその両方を行うようにすることができる。また、メモリ情報のマイグレーションを管理するために追加のスレッドを用いることも可能である。この設定を用いると、ハイパーバイザがモビリティ動作のためにアクセスすることができるメモリおよびスレッドのリソースが増大するので、大きいアクティブなパーティションを高速でマイグレートすることができる。これに対応して、スライダ・バー/GUIの値または設定が高いことは同時実行性が高い/最大であることに相当するので、小さいサイズのメモリ・リソースをハイパーバイザに割り当て、場合によっては1つのスレッドを用いてメモリ・リソースを管理するようにすることができる。この設定を用いると、ハイパーバイザがアクセスすることができるメモリ・リソースが少ないので、多くのアクティブでないパーティションを同時にマイグレートすることができ、他のVIOS動作に影響を与えることなく多くの動作を処理することができる。いくつかの実施形態では、インタフェース372は、ユーザ/管理者がモビリティ動作のために特定のメモリまたはスレッドの割り当て設定を選択することができるように構成され、これによってモビリティ動作のためのリソース割り当てをカスタマイズすることを可能とする。このため、特定の設定380の選択に応答して、割り当てモジュール370は、対応するメモリおよびCPUリソースをモビリティ動作に用いるために割り当てる。更に、いくつかの実施形態においては、割り当てモジュール370を用いてLPARのマイグレーションに優先順位を付けることができる。例えば、いくつかの実施形態では、ユーザ/管理者が、いくつかのLPARについていくつかのマイグレーション動作に優先順位を付けたいという場合がある。割り当てモジュールは、設定した優先順位に応じてモビリティ動作を実行するように構成されている。
図3においては、割り当てモジュール370およびモビリティ構成データ374は、HMC350の一部として図示されている。図4は、モビリティ動作リソース割り当てのためのシステム300の代替的な実施形態の例示である。図4において、割り当てモジュール370およびモビリティ構成データ374、およびそれらの対応する機能は、VIOSパーティション340および342内で実施される。例えば、いくつかの実施形態では、HMC350のインタフェース372を用いて、パーティションのマイグレーションに利用可能である様々なモビリティ設定380を表示することができる。モビリティ設定380または適用可能LPARあるいはその両方の選択が受信されると、選択された設定380または適用可能LPAR情報あるいはその両方を、HMC350からVIOSパーティション340または342あるいはその両方に伝達することができる。この実施形態では、割り当てモジュール370(VIOSパーティション340または342の一部として実施される)は、選択された設定380に基づいてマイグレーションに望まれるリソース要求を識別し(例えばメモリ構成データ382またはスレッド構成データ384あるいはその両方を用いて)、かかるリソースの利用可能性を判定し、モビリティ設定(複数の設定)380および割り当てられたリソースに基づいてマイグレーション動作(複数の動作)を開始する。
図3および図4を参照すると、いくつかの実施形態において、VIOSパーティション340または342あるいはその両方は、ソースMSPと宛先MSPとの間でメモリまたはCPUあるいはその両方のリソースの割り当てをネゴシエートするように構成されている。例えば、いくつかの例では、ソースMSPに利用可能であるリソースの方が宛先MSP上で利用可能なリソースよりも多い場合があり、または逆の場合もある。この例では、ソースMSPと宛先MSPとの間で利用可能なリソースに不一致があるので、望ましいモビリティ設定380は一方のMSPの観点からは利用可能であるが他方のMSPからは利用できない(またはどちらも利用できない)場合がある。この例では、VIOSパーティション340または342あるいはその両方は(例えばVIOSパーティション340または342あるいはその両方の一部として実施されているそれぞれに構成された割り当てモジュール370によって)、MSPリソースの不一致または利用不可能性あるいはその両方を検出し、ソースMSPまたは宛先MSPあるいはその両方のリソース利用可能性に基づいてモビリティ動作のためのバランスのとれたリソース割り当てをネゴシエートするように構成することができる。例えば、特定の設定380が、モビリティ動作に専用の高いメモリ・リソース割り当てを示し得る場合であっても、VIOSパーティション340または342あるいはその両方は、所望のモビリティ設定380を考慮に入れてソース/宛先MSPのリソースの現在の利用可能性に対応するように、リソース割り当てを無効にするかまたは自動的に調節する(例えばユーザ/管理者の介入なしで)あるいはその両方を行うことができる。
図5は、モビリティ動作リソース割り当てのための方法の一実施形態を示すフロー図である。この方法はブロック502において開始し、ここでHMC350は1つ以上の実行中のアプリケーションまたはLPARをマイグレートする要求を受信する。ブロック504において、インタフェース372を表示し、LPARマイグレーション(複数のマイグレーション)に適用するための1つ以上の性能ベースまたは同時実行性ベースあるいはその両方のリソース割り当て設定を示す。ブロック506において、割り当てモジュール370は、マイグレーションのための1つ以上のモビリティ設定380を受信する(例えば全てのマイグレート対象のLPARに適用する単一の設定、またはいくつかのLPARのためのいくつかの設定、あるいはその両方)。ブロック508において、割り当てモジュール370は、選択されたモビリティ設定(複数の設定)に従ったメモリ・リソース要求を識別する。ブロック510において、割り当てモジュール370は、選択されたモビリティ設定(複数の設定)に従ったプロセッサ・リソース要求を識別する。
ブロック512において、VIOSパーティションまたは342あるいはその両方は、選択されたモビリティ設定(複数の設定)に基づいて、ソースまたは宛先あるいはその両方のMSP上の利用可能リソースを評価する。ブロック514において、VIOSパーティション340または342あるいはその両方は、(例えば同様のリソースまたは利用可能なリソースあるいはその両方の不一致のために生じ得る)ソースMSPと宛先MSPとの間のリソース割り当てに必要なバランスをネゴシエートする。ブロック516において、所望の/選択されたモビリティ設定(複数の設定)に基づいて、リソースが利用可能であるか否かを判定する。リソースが利用可能である場合、この方法はブロック520に進む。決定ブロック516において、選択されたモビリティ設定(複数の設定)に基づいてリソースが利用可能でないと判定された場合、この方法はブロック518に進み、VIOSパーティション340または342あるいはその両方は、利用可能リソースに基づいて選択されたモビリティ設定を無効にする。ブロック520において、VIOSパーティション340または342あるいはその両方は、マイグレーションのためにリソースを割り当てる。ブロック522において、割り当てたリソースを用いてLPAR(複数のLPAR)をマイグレートする。
従って、本開示の実施形態によって、性能または同時実行性あるいはその両方の要求に基づいて、アプリケーションのマイグレーションに用いるリソースを柔軟に選択することが可能となる。本開示の実施形態は、ユーザ/管理者がアプリケーションのマイグレーションのために性能ベースまたは同時実行性ベースあるいはその両方の設定を選択することができるインタフェースを利用し、これによって、性能が重要である場合に大きいパーティションの迅速な移動を行うこと、または、性能が重要でない場合に多数のアクティブでないパーティションを同時にマイグレートすること、あるいはその両方を実行する。本開示の実施形態によって、ユーザ/管理者がパーティションごとにモビリティ設定(複数の設定)を適用すること、更に、いくつかのパーティションのマイグレーションに優先順位を付けることを可能とする。
本明細書において用いた用語は、特定の実施形態を記載する目的のためだけのものであり、本開示を限定することは意図していない。本明細書において用いたように、単数形「1つの(a)、(an)、(the)」は、文脈によって明らかに他の場合が示されない限り、複数形を含むことが意図されている。また、「含む」または「含んでいる」という言葉あるいはその両方は、本明細書において用いられた場合、述べた特性、整数、ステップ、動作、要素、またはコンポーネントあるいはそれら全ての存在を規定するが、1つ以上の他の特性、整数、ステップ、動作、要素、コンポーネント、またはそれらのグループあるいはそれら全ての存在または追加を除外するものではないことは、理解されよう。
以下の特許請求の範囲における全てのミーンズまたはステップ・プラス・ファンクション要素の対応する構造、材料、行為、および均等物は、具体的に特許請求したような他の特許請求した要素と組み合わせて機能を実行するためのいずれかの構造、材料、または行為を含むことが意図されている。本開示の記載は、例示および記述の目的のために提示したが、網羅的であることや、開示した形態に本開示を限定することは、意図していない。本開示の範囲および精神から逸脱することなく、当業者には多くの変更および変形が明らかであろう。実施形態は、本開示の原理および実際的な用途を最良に説明するため、更に、想定される特定の用途に適した様々な変更と共に様々な実施形態に関して当業者が本開示を理解することを可能とするために、選択し記載したものである。
図面におけるフローチャートおよびブロック図は、本発明の様々な実施形態に従ったシステム、方法、およびコンピュータ・プログラムの可能な実施のアーキテクチャ、機能性、および動作を例示する。この点で、フローチャートまたはブロック図における各ブロックは、規定された論理機能(複数の機能)を実施するための1つ以上の実行可能命令を含むコードのモジュール、セグメント、または一部を表すことができる。また、いくつかの代替的な実施において、ブロックに明記した機能は、図面に明記した順序どおりでなく発生する場合があることに留意すべきである。例えば、関与する機能性に応じて、連続して示した2つのブロックは実際には実質的に同時に実行されることがあり、またはブロックは時に逆の順序で実行される場合がある。また、ブロック図またはフローチャート図あるいはその両方の各ブロック、およびブロック図またはフローチャート図あるいはその両方におけるブロックの組み合わせは、規定された機能もしくは行為を実行する特殊目的ハードウェア・ベースのシステム、または特殊目的ハードウェアおよびコンピュータ命令の組み合わせによって実施可能であることに留意すべきである。
100 :データ処理システム
110、120 :クライアント
130 :ネットワーク
140、150 :サーバ
160 :データ記憶
200 :データ処理システム
204、212 :ユニット
206 :メモリ
208 :永続性記憶装置
210 :通信ユニット
212 :入出力ユニット
214 :ディスプレイ
216 :コード
218 :コンピュータ読み取り可能媒体
220 :プログラム
300、310、312、324 :システム
340 :VIOSパーティション
346 :ソフトウェア
346 :ハイパーバイザ
352、354 :イーサネット
360 :プロセッサ
366 :外部記憶サブシステム
368 :SAN(記憶エリア・ネットワーク)
370 :割り当てモジュール
372 :インタフェース
374 :モビリティ構成データ
380 :設定
380 :モビリティ設定
382 :メモリ構成データ
384 :スレッド構成データ
502、504、506、508、510、512、514、516、518、520、522 :ブロック
516 :決定ブロック

Claims (14)

  1. 第1のマシンから第2のマシンに実行中のアプリケーションをマイグレートする要求を受信するステップと、
    少なくとも1つの性能ベースのモビリティ設定および少なくとも1つの同時実行性ベースのモビリティ設定を含む複数のモビリティ設定を示す調節可能リソース割り当てモビリティ設定インタフェースを表示するステップと、
    前記インタフェースを介して、前記マイグレートに利用するリソース割り当てを規定するモビリティ設定の選択を受信するステップと、
    前記選択されたモビリティ設定によって設定されたようにリソースを用いて前記第1のマシンから前記第2のマシンに前記実行中のアプリケーションをマイグレートするステップと、
    を含む、方法。
  2. 前記選択されたモビリティ設定に基づいて前記第1のマシンと前記第2のマシンとの間のリソース割り当てのバランスを調整するステップを更に含む、請求項1に記載の方法。
  3. 前記選択されたモビリティ設定に基づいて前記マイグレートのためのメモリ・リソース割り当てを識別するステップを更に含む、請求項1に記載の方法。
  4. 前記選択されたモビリティ設定に基づいて前記マイグレートのためのプロセッサ利用を決定するステップを更に含む、請求項3に記載の方法。
  5. 前記性能ベースのモビリティ設定のために、前記同時実行性ベースのモビリティ設定よりも多くのメモリ・リソースを割り当てるステップと、
    前記メモリ・リソースを管理するため、前記性能ベースのモビリティ設定のために、前記同時実行性ベースのモビリティ設定よりも多数のスレッドを割り当てるステップと、
    を更に含む、請求項1に記載の方法。
  6. 前記選択された前記モビリティ設定に基づいてリソースが利用可能であるか否かを判定するステップと、
    前記判定するステップにおいて利用不可能と判定されたことに応答して、前記モビリティ設定を無効にするステップと、
    を更に含む、請求項1に記載の方法。
  7. 請求項1〜6の何れか1項に記載の方法の各ステップを、コンピュータに実行させる、コンピュータ・プログラム。
  8. 請求項7に記載の前記コンピュータ・プログラムを、コンピュータ可読記録媒体に記録した、記録媒体。
  9. 第1のマシンから第2のマシンに複数の論理パーティションをマイグレートする要求を受信するステップと、
    複数のモビリティ設定を示す調節可能リソース割り当てモビリティ設定インタフェースを表示するステップであって、各モビリティ設定が前記マイグレートに利用する所望のリソース割り当てに対応する、ステップと、
    前記インタフェースを介して、前記複数の論理パーティションの第1の論理パーティション・セットに適用する、性能ベースのモビリティ設定である第1のモビリティ設定と、前記複数の論理パーティションの第2の論理パーティション・セットに適用する、同時実行性ベースのモビリティ設定である第2のモビリティ設定と、を受信するステップと、
    前記第1および第2のモビリティ設定の各々によって設定されたように前記リソース割り当てを用いて前記第1のマシンから前記第2のマシンへの前記第1および第2の論理パーティション・セットのマイグレートを開始するステップと、
    を含む、方法。
  10. 前記第1および第2のモビリティ設定に基づいて前記第1のマシンと前記第2のマシンとの間のリソース割り当てのバランスを調整するステップを更に含む、請求項9に記載の方法。
  11. 前記第1または第2のマシンのいずれかで利用不可能リソースが利用可能であるか否かを判定するステップと、
    前記判定するステップにおいて利用不可能と判定されたことに応答して、前記第1または第2のモビリティ設定のいずれかによって示される前記リソース割り当てを無効にするステップを更に含む、請求項10に記載の方法。
  12. 前記第1または第2のモビリティ設定に基づいて前記マイグレートのためのメモリ・リソース割り当てを識別するステップを更に含む、請求項9に記載の方法。
  13. 前記第1または第2のモビリティ設定に基づいて前記マイグレートのためのプロセッサ・リソース割り当てを識別するステップを更に含む、請求項12に記載の方法。
  14. 前記第1のモビリティ設定のために、前記第2のモビリティ設定よりも多くのメモリ・リソースを割り当てるステップと、
    前記メモリ・リソースを管理するため、前記第1のモビリティ設定のために、前記第2のモビリティ設定よりも多数のスレッドを割り当てるステップと、
    を更に含む、請求項に記載の方法。
JP2013171848A 2012-11-07 2013-08-22 モビリティ動作リソース割り当てのための方法、システム、コンピュータ・プログラム Expired - Fee Related JP6327810B2 (ja)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US13/671422 2012-11-07
US13/671,422 US9166865B2 (en) 2012-11-07 2012-11-07 Mobility operation resource allocation
US13/769593 2013-02-18
US13/769,593 US20140129716A1 (en) 2012-11-07 2013-02-18 Mobility operation resource allocation

Publications (2)

Publication Number Publication Date
JP2014096136A JP2014096136A (ja) 2014-05-22
JP6327810B2 true JP6327810B2 (ja) 2018-05-23

Family

ID=50623448

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2013171848A Expired - Fee Related JP6327810B2 (ja) 2012-11-07 2013-08-22 モビリティ動作リソース割り当てのための方法、システム、コンピュータ・プログラム

Country Status (4)

Country Link
US (3) US9166865B2 (ja)
JP (1) JP6327810B2 (ja)
CN (1) CN103810036B (ja)
TW (1) TWI567653B (ja)

Families Citing this family (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8863141B2 (en) 2011-12-14 2014-10-14 International Business Machines Corporation Estimating migration costs for migrating logical partitions within a virtualized computing environment based on a migration cost history
US9489443B1 (en) * 2013-05-24 2016-11-08 Amazon Technologies, Inc. Scheduling of splits and moves of database partitions
US20150304414A1 (en) * 2014-04-17 2015-10-22 Go Daddy Operating Company, LLC Allocating hosting server resources via migration paths
US9501211B2 (en) * 2014-04-17 2016-11-22 GoDaddy Operating Company, LLC User input processing for allocation of hosting server resources
US9660933B2 (en) * 2014-04-17 2017-05-23 Go Daddy Operating Company, LLC Allocating and accessing hosting server resources via continuous resource availability updates
US10193964B2 (en) * 2014-05-06 2019-01-29 International Business Machines Corporation Clustering requests and prioritizing workmanager threads based on resource performance and/or availability
CN105204923A (zh) 2014-06-27 2015-12-30 国际商业机器公司 用于资源预配置的方法和装置
US10051508B2 (en) * 2014-11-10 2018-08-14 Futurewei Technologies, Inc. System and method for mobility support selection
US9886296B2 (en) * 2014-12-01 2018-02-06 International Business Machines Corporation Managing hypervisor weights in a virtual environment
US9912741B2 (en) 2015-01-20 2018-03-06 International Business Machines Corporation Optimization of computer system logical partition migrations in a multiple computer system environment
US9921977B2 (en) * 2015-03-11 2018-03-20 International Business Machines Corporation Privilege based memory pinning mechanism
US9465643B1 (en) * 2015-06-04 2016-10-11 Dell Products, L.P. Systems and methods for monitoring a primary operating system (OS) and/or migrating data using an OS hypervisor
US9996377B2 (en) * 2015-06-30 2018-06-12 International Business Machines Corporation Virtual machine migration via a mobile device
US10162681B2 (en) 2015-07-24 2018-12-25 International Business Machines Corporation Reducing redundant validations for live operating system migration
CN108431773A (zh) * 2015-11-27 2018-08-21 卡丹医学成像股份有限公司 使用服务器执行用于处理数据的函数的方法和系统
WO2017116141A1 (ko) * 2015-12-29 2017-07-06 엘지전자(주) 무선 통신 시스템에서 채널 상태 정보 송수신 방법 및 이를 위한 장치
US20180032418A1 (en) * 2016-08-01 2018-02-01 Futurewei Technologies, Inc. Application-Specific, Performance-Aware Energy Optimization
US11048556B2 (en) * 2018-04-12 2021-06-29 International Business Machines Corporation Multi-channel, multi-control logical partition migration
US11317158B2 (en) * 2018-11-02 2022-04-26 Netflix, Inc. Video playback in an online streaming environment

Family Cites Families (38)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6105053A (en) * 1995-06-23 2000-08-15 Emc Corporation Operating system for a non-uniform memory access multiprocessor system
US6633916B2 (en) * 1998-06-10 2003-10-14 Hewlett-Packard Development Company, L.P. Method and apparatus for virtual resource handling in a multi-processor computer system
US6226734B1 (en) * 1998-06-10 2001-05-01 Compaq Computer Corporation Method and apparatus for processor migration from different processor states in a multi-processor computer system
US6538669B1 (en) * 1999-07-15 2003-03-25 Dell Products L.P. Graphical user interface for configuration of a storage system
US8346733B2 (en) * 2006-12-22 2013-01-01 Commvault Systems, Inc. Systems and methods of media management, such as management of media to and from a media storage library
US7181744B2 (en) * 2002-10-24 2007-02-20 International Business Machines Corporation System and method for transferring data between virtual machines or other computer entities
US7519814B2 (en) * 2003-09-15 2009-04-14 Trigence Corp. System for containerization of application sets
US7047252B2 (en) * 2003-12-02 2006-05-16 Oracle International Corporation Complex computation across heterogenous computer systems
US7814491B1 (en) * 2004-04-14 2010-10-12 Oracle America, Inc. Method and apparatus for managing system resources using a container model
US7257811B2 (en) 2004-05-11 2007-08-14 International Business Machines Corporation System, method and program to migrate a virtual machine
US7707578B1 (en) * 2004-12-16 2010-04-27 Vmware, Inc. Mechanism for scheduling execution of threads for fair resource allocation in a multi-threaded and/or multi-core processing system
EP1872211A4 (en) * 2005-04-18 2008-05-28 Research In Motion Ltd METHOD AND SYSTEM FOR EXECUTING A CONTAINER-MANAGED APPLICATION ON A PROCESSING DEVICE
TWI467491B (zh) * 2005-04-21 2015-01-01 Waratek Pty Ltd 用於使用協調物件之修正式電腦結構之方法、系統與電腦程式產品
US8429630B2 (en) * 2005-09-15 2013-04-23 Ca, Inc. Globally distributed utility computing cloud
US8104041B2 (en) * 2006-04-24 2012-01-24 Hewlett-Packard Development Company, L.P. Computer workload redistribution based on prediction from analysis of local resource utilization chronology data
JP2008102739A (ja) 2006-10-19 2008-05-01 Hitachi Ltd 在庫分析方法、在庫分析手数料算出方法、及びそのプログラム
US20100030877A1 (en) * 2007-02-23 2010-02-04 Mitsuru Yanagisawa Virtual server system and physical server selecting method
US20090132804A1 (en) * 2007-11-21 2009-05-21 Prabir Paul Secured live software migration
US20100205604A1 (en) * 2009-02-09 2010-08-12 Resilience Corporation Systems and methods for efficiently running multiple instances of multiple applications
US8595737B2 (en) * 2009-03-17 2013-11-26 Hitachi, Ltd. Method for migrating a virtual server to physical server according to a variation ratio, a reference execution time, a predetermined occupied resource amount and a occupancy amount
JP5369824B2 (ja) * 2009-03-30 2013-12-18 富士通株式会社 移動スケジュール設計装置、移動スケジュール設計プログラム、移動スケジュール設計方法
US8458284B2 (en) * 2009-06-12 2013-06-04 International Business Machines Corporation Systems and methods for efficient live application migration within bandwidth constrained networks
US8613085B2 (en) * 2009-07-22 2013-12-17 Broadcom Corporation Method and system for traffic management via virtual machine migration
US8374101B2 (en) 2009-07-30 2013-02-12 Nec Laboratories America, Inc. Multicast with joint layer resource allocation in broadband wireless networks
JP4801761B2 (ja) * 2009-08-12 2011-10-26 株式会社日立製作所 データベース管理方法およびシステム並びにその処理プログラム
TWI468057B (zh) 2009-10-06 2015-01-01 Inst Information Industry 資源分配裝置、下級站台、資源分配方法及電腦可讀取記錄媒體
US9135079B2 (en) * 2009-10-21 2015-09-15 International Business Machines Corporation Dynamically assigning a portion of physical computing resource to logical partitions based on characteristics of executing logical partitions
US8407366B2 (en) 2010-05-14 2013-03-26 Microsoft Corporation Interconnecting members of a virtual network
JP5391152B2 (ja) * 2010-05-26 2014-01-15 株式会社日立製作所 サーバシステム、及び、仮想サーバの移行方式を選択する方法
US8489699B2 (en) * 2010-08-13 2013-07-16 Vmware, Inc. Live migration of virtual machine during direct access to storage over SR IOV adapter
US9384054B2 (en) * 2010-09-22 2016-07-05 Nokia Technologies Oy Process allocation to applications executing on a mobile device
US8615579B1 (en) * 2010-12-28 2013-12-24 Amazon Technologies, Inc. Managing virtual machine migration
US9990215B2 (en) * 2011-02-22 2018-06-05 Vmware, Inc. User interface for managing a virtualized computing environment
US9891939B2 (en) * 2011-03-03 2018-02-13 Microsoft Technology Licensing, Llc Application compatibility with library operating systems
WO2013002777A1 (en) * 2011-06-29 2013-01-03 Hewlett-Packard Development Company, L.P. Application migration with dynamic operating system containers
US20130054734A1 (en) * 2011-08-23 2013-02-28 Microsoft Corporation Migration of cloud applications between a local computing device and cloud
JP5682070B2 (ja) * 2012-02-28 2015-03-11 日本電信電話株式会社 統合制御装置及び統合制御方法
JP5954074B2 (ja) * 2012-09-20 2016-07-20 富士通株式会社 情報処理方法、情報処理装置、及びプログラム。

Also Published As

Publication number Publication date
US9166865B2 (en) 2015-10-20
CN103810036B (zh) 2017-11-24
US20140129958A1 (en) 2014-05-08
US20160019088A1 (en) 2016-01-21
US20140129716A1 (en) 2014-05-08
US11237856B2 (en) 2022-02-01
JP2014096136A (ja) 2014-05-22
TW201423598A (zh) 2014-06-16
TWI567653B (zh) 2017-01-21
CN103810036A (zh) 2014-05-21

Similar Documents

Publication Publication Date Title
JP6327810B2 (ja) モビリティ動作リソース割り当てのための方法、システム、コンピュータ・プログラム
US11221884B2 (en) Hybrid virtual machine configuration management
US10048981B2 (en) Performing virtual machine live migration within a threshold time by adding available network path in multipath network
US10498664B2 (en) Hybrid cloud resource scheduling
US9135189B2 (en) Delivering GPU resources across machine boundaries
US10176004B2 (en) Workload-aware load balancing to minimize scheduled downtime during maintenance of host or hypervisor of a virtualized computing system
US8595722B2 (en) Preprovisioning virtual machines based on request frequency and current network configuration
US9274853B2 (en) Utilizing multiple memory pools during mobility operations
US20150205542A1 (en) Virtual machine migration in shared storage environment
US20120173653A1 (en) Virtual machine migration in fabric attached memory
US9495269B1 (en) Mobility validation by trial boot using snap shot
US10956195B2 (en) Virtual machine migrations across clouds assisted with content based read caching
US9928112B2 (en) Configuration of floating node boundaries
US11435939B2 (en) Automated tiering of file system objects in a computing system
CN114424180A (zh) 增加跨帧实时更新的性能
US10379912B2 (en) Data storage allocation utilizing virtual machine resource allocation
US10360058B2 (en) Input/output component selection for virtual machine migration
US11252232B2 (en) NVME-of queue management in host clusters
Elder et al. vSphere High Performance Cookbook
JP2022089783A (ja) セルフ・クリアリング・データ移動支援の方法、システム、およびコンピュータ・プログラム、およびコンピュータ可読な記録媒体

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20160816

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20170626

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20170704

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20170809

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20180105

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180302

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180313

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: 20180327

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20180417

R150 Certificate of patent or registration of utility model

Ref document number: 6327810

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

LAPS Cancellation because of no payment of annual fees