JP2021119502A - Rolling resource credit for scheduling virtual computer resource - Google Patents
Rolling resource credit for scheduling virtual computer resource Download PDFInfo
- Publication number
- JP2021119502A JP2021119502A JP2021075891A JP2021075891A JP2021119502A JP 2021119502 A JP2021119502 A JP 2021119502A JP 2021075891 A JP2021075891 A JP 2021075891A JP 2021075891 A JP2021075891 A JP 2021075891A JP 2021119502 A JP2021119502 A JP 2021119502A
- Authority
- JP
- Japan
- Prior art keywords
- resource
- virtual
- credits
- instance
- network
- 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.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/4881—Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/505—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the load
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/22—Payment schemes or models
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
- G06F9/5077—Logical partitioning of resources; Management or configuration of virtualized resources
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Debugging And Monitoring (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
Description
汎用ハードウェアに対する仮想化技術の出現は、多様なニーズを有する多数の顧客のための大規模なコンピューティングリソースを管理する上で利益をもたらし、これにより、様々なコンピューティングリソースが、複数の顧客により効率的かつ安全に共有されることが可能になる。例えば、仮想化技術は、各ユーザに、単一の物理的なコンピューティングマシンによりホストされる1つ以上の仮想マシンを提供することにより、単一の物理的なコンピューティングマシンが、複数のユーザの間で共有されることを可能にすることができ、それぞれの係る仮想マシンは、ユーザが所与のハードウェアコンピューティングリソースの唯一のオペレータ及び管理者であるという錯覚をユーザに提供する別個の論理的コンピューティングシステムとして機能するソフトウェアシミュレーションであり、同時に様々な仮想マシン間のアプリケーション分離及びセキュリティも提供する。別の例として、仮想化技術は、複数のデータストレージデバイスにわたり分散され得る仮想化されたデータストアを各ユーザに提供することにより、データストレージハードウェアが複数のユーザ間で共有されることを可能にすることができ、それぞれの係る仮想化されたデータストアは、ユーザがデータストレージリソースの唯一のオペレータ及び管理者であるという錯覚をユーザに提供する別個の論理的データストアとして機能する。 The advent of virtualization technology for general purpose hardware benefits in managing large computing resources for a large number of customers with diverse needs, which allows different computing resources to be combined with multiple customers. Allows for more efficient and safe sharing. For example, virtualization technology provides each user with one or more virtual machines hosted by a single physical computing machine so that a single physical computing machine can be used by multiple users. Each such virtual machine can be allowed to be shared between, and each such virtual machine provides the user with the illusion that the user is the only operator and administrator of a given hardware computing resource. It is a software simulation that functions as a logical computing system, and at the same time provides application isolation and security between various virtual machines. As another example, virtualization technology allows data storage hardware to be shared among multiple users by providing each user with a virtualized data store that can be distributed across multiple data storage devices. Each such virtualized datastore acts as a separate logical datastore that provides the user with the illusion that the user is the only operator and administrator of the data storage resource.
仮想化技術を利用して、クライアントシステムもしくはデバイスに多くの異なる種類のサービスを作成するか、または異なる機能を実行しても良い。例えば、仮想マシンを使用して、電子商取引プラットフォームなどの外部顧客のためのネットワークベースのサービスを実装しても良い。仮想マシンをさらに使用して、企業の内部ネットワークの一部として実装される情報技術(IT)サービスなど、内部顧客のためのサービスまたはツールをさらに実装しても良い。しかしながら、これらの仮想リソースを効率的に活用するには、多くの異なる種類の仮想リソース作業量に対する柔軟な活用オプションが必要になり得る。一部の環境では、複数の仮想マシンが単一のホスト上で一緒にホストされる場合があり、これにより同じ物理的なコンピュータリソースに依存し得る異なる仮想コンピューティングリソースを活用する際に、競合及び衝突が生まれる可能性がある。 Virtualization techniques may be used to create many different types of services on client systems or devices, or to perform different functions. For example, virtual machines may be used to implement network-based services for external customers, such as e-commerce platforms. Virtual machines may also be used to further implement services or tools for internal customers, such as information technology (IT) services that are implemented as part of a company's internal network. However, efficient utilization of these virtual resources may require flexible utilization options for many different types of virtual resource workloads. In some environments, multiple virtual machines may be hosted together on a single host, which conflicts with different virtual computing resources that can depend on the same physical computer resources. And conflicts can occur.
本明細書では、実施形態がいくつかの実施形態及び説明図に対する例により記載されるが、実施形態は記載される実施形態または図面に限定されないことを当業者は認識するであろう。図面及びその詳細な記載は、開示される特定の形態に実施形態を限定する意図はなく、それとは逆に、添付の請求項で定義される精神及び範囲に入る全ての修正、均等物及び代替案を含める意図があることを理解されたい。本明細書で使用される見出しは、本明細書を構成する目的でのみ使用され、明細書または請求項の範囲を限定するために使用されることを意図しない。本出願を通して使用される単語「may」は、義務的な意味(つまり、「するべきである」という意味)ではなく、許容的な意味(つまり、「する可能性がある」という意味)で使用される。同様に、単語「include」、「including」、及び「includes」は「含む」ことを意味するが、その対象を限定しない。 Those skilled in the art will recognize that embodiments are described herein by way of example for some embodiments and illustrations, but embodiments are not limited to the embodiments or drawings described. The drawings and their detailed description are not intended to limit embodiments to the particular embodiments disclosed, and conversely, all modifications, equivalents and alternatives that fall within the spirit and scope as defined in the appended claims. Please understand that you intend to include the proposal. The headings used herein are used only for the purposes that make up the specification and are not intended to be used to limit the scope of the specification or claims. The word "may" used throughout this application is used in an acceptable sense (ie, meaning "may") rather than in an obligatory sense (ie, meaning "should"). Will be done. Similarly, the words "include", "including", and "includes" mean "include", but are not limited in scope.
本明細書に記載のシステム及び方法は、いくつかの実施形態に係る、仮想コンピューティングリソースをスケジュールするためにローリングリソースクレジットを実施し得る。仮想コンピューティングリソースを実施する異なるクライアントは異なるリソース要求を有する。例えば、あるクライアントの作業量は予測不可能であり、固定リソースを効率的に活用しない可能性がある。仮想コンピューティングリソースをスケジュールするためにローリングリソースクレジットを実施する仮想計算インスタンスは、活用されていない固定リソースを無駄にすることなく、リソースの動的な活用を提供し、柔軟性のある高性能を提供し得る。リソースクレジットは個別の仮想計算インスタンスに対して蓄積される。仮想計算インスタンスが高性能で作業を行う必要がある場合、リソースクレジットが作業に適用されも良く、これによりリソースクレジットの持続期間中に基礎を成す物理的なリソースのフル活用を効果的に提供する。仮想計算インスタンスがその共有リソースより少ないリソースを使用している場合(例えば、実行中の作業がほとんどない、または全く無い)、クレジットが取得され、後続タスクのために使用されても良い。リソースは、様々な実施形態では、管理された物理的なコンピュータリソースにより実施または実行される任意の仮想化されたコンピュータリソースであり得る。リソースは、処理リソース、通信もしくはネットワーキングリソース及びストレージリソースを含むが、これらに限定されない。 The systems and methods described herein may implement rolling resource credits for scheduling virtual computing resources, according to some embodiments. Different clients implementing virtual computing resources have different resource requirements. For example, the workload of a client is unpredictable and may not make efficient use of fixed resources. Virtual compute instances that perform rolling resource credits to schedule virtual computing resources provide dynamic resource utilization without wasting unused fixed resources, providing flexible and high performance. Can be provided. Resource credits are accumulated for individual virtual compute instances. When a virtual compute instance needs to work at high performance, resource credits may be applied to the work, effectively providing full utilization of the underlying physical resources for the duration of the resource credits. .. If a virtual compute instance uses less resources than its shared resources (eg, little or no work in progress), credits may be taken and used for subsequent tasks. The resource can, in various embodiments, be any virtualized computer resource implemented or executed by a managed physical computer resource. Resources include, but are not limited to, processing resources, communication or networking resources and storage resources.
仮想計算インスタンスは仮想コンピューティングリソースをスケジュールするためのローリングリソースクレジットを実施しても良く、限定期間に低価格で応答性及び高性能を提供する。図1はいくつかの実施形態に係る、仮想計算インスタンスに対するローリングリソースクレジット残量を例示するグラフである。グラフ100は、スケジューリングのためにローリングリソースクレジットを実施する計算インスタンスに対する、リソースクレジット使用量及びリソースクレジット残量の両方を例示する。初期のリソースクレジット残量が提供されても良く110(例えば、30クレジット)、すぐに使用されても良い。いくつかの実施形態では、経時的に、計算インスタンスはローリングリソースクレジット残量限度120に達するまで、より多くのクレジットを蓄積し得る。この限度は、一定時間(例えば、24時間)後に、特定の蓄積されたリソースクレジットを除外することにより実施され得る。いくつかの実施形態では、適用されると、リソースクレジットは特定
の時間(例えば、コンピュータリソースクレジットは中央処理装置(CPU)の1分間のフル活用、30秒間の特定のネットワーキングチャネル、または保証され得る一部の他の使用期間に等しくても良い)に対してリソースのフル活用を提供し得る。リソースクレジットは使用されるとリソースクレジット残量から差し引かれ得る。
Virtual compute instances may implement rolling resource credits for scheduling virtual computing resources, providing low cost, responsiveness and high performance for a limited period of time. FIG. 1 is a graph illustrating the remaining amount of rolling resource credits for a virtual compute instance, according to some embodiments. Graph 100 illustrates both resource credit usage and resource credit remaining for a compute instance that performs rolling resource credits for scheduling. The initial resource credit balance may be provided 110 (eg, 30 credits) and may be used immediately. In some embodiments, over time, the compute instance may accumulate more credits until it reaches the rolling resource credit limit of 120. This limit can be enforced by excluding certain accumulated resource credits after a period of time (eg, 24 hours). In some embodiments, when applied, resource credits can be guaranteed for a particular time (eg, computer resource credits can be a one minute full utilization of a central processing unit (CPU), a thirty second specific networking channel, or a guarantee. It can provide full use of resources for some other period of use). Resource credits can be deducted from the remaining resource credits when used.
リソースクレジットを消費すると、仮想計算インスタンスは必要な時に十分なリソース(例えば、CPUコア、ネットワークインターフェースカード機能等)を活用して、高性能を取得し得る。例えば、時間5でのクレジットリソース使用量は時間5でのリソースクレジット残量より少ない。したがって、現在のリソースクレジット残量のうち、タスクを行うのに必要であったリソースクレジットよりも多くのリソースクレジットが消費のために利用可能であったため、時間5で実行される作業は、タスク期間にわたりフル活用で行われた。さらに、さらなるリソースクレジット使用量が示されないため、リソースクレジットは残量限度120に達するまで引き続き繰り越され、次回の大量使用期間(または同じ仮想化ホスト上でホストされる別の計算インスタンスに対する別の作業要求)のためにさらなる物理的なリソースを節約する。タスクを行う際に利用可能なリソースクレジットが無い場合、ベースライン活用保証をさらに適用して、作業要求を行っても良い。いくつかの実施形態では、ベースライン活用保証は、仮想計算インスタンスがクレジットリソース残量のクレジットを全く費やすことなく、リソースを使用することができる時間量であり得る。 When resource credits are consumed, the virtual computing instance can utilize sufficient resources (eg, CPU core, network interface card function, etc.) when needed to obtain high performance. For example, the amount of credit resource used at time 5 is less than the remaining amount of resource credit at time 5. Therefore, of the current remaining resource credits, more resource credits were available for consumption than were required to perform the task, so the work performed at time 5 is the task period. It was done with full utilization over. In addition, since no further resource credit usage is shown, resource credits continue to be carried forward until the remaining amount limit of 120 is reached, and another work on another compute instance hosted on the next high usage period (or on the same virtualization host). Save additional physical resources due to the request). If there are no resource credits available to perform the task, the Baseline Utilization Guarantee may be further applied to make a work request. In some embodiments, the baseline utilization guarantee can be the amount of time a virtual compute instance can use a resource without spending any credit on the remaining credit resources.
少なくともいくつかの実施形態では、ベースライン活用保証はリソースクレジット蓄積率に一致し得る。例えば、リソースクレジットが1時間当たりの1分間のフル活用に等しい場合、1時間当たりの6リソースクレジット累積率は60分のうちの6分、つまり1時間に対する10%のリソース活用に等しい。この例では、ベースライン保証は1時間に対する10%のリソース活用となり得る。しかしながら、いくつかの実施形態では、リソースクレジット蓄積率はベースライン保証と無関係の場合があり(例えば、1時間当たり12リソースクレジット蓄積率及び10%のベースライン保証)、これにより、計算インスタンスが、割り当てられたベースライン活用保証を活用する作業要求を送信したとしても、リソースクレジットがリソースクレジット残量のものになることが可能である。前述の例は、リソースクレジット蓄積率及びベースライン性能が実施され得る様々な方法または組み合わせを限定する意図ではないことに留意されたい。 In at least some embodiments, the baseline utilization guarantee may match the resource credit accumulation rate. For example, if the resource credits are equal to the full utilization of 1 minute per hour, the cumulative rate of 6 resource credits per hour is equal to 6 minutes out of 60 minutes, or 10% resource utilization per hour. In this example, the baseline guarantee can be 10% resource utilization per hour. However, in some embodiments, the resource credit accumulation rate may be unrelated to the baseline guarantee (eg, 12 resource credit accumulation rate per hour and 10% baseline guarantee), which causes the compute instance to: Even if a work request is sent to take advantage of the assigned baseline utilization guarantee, the resource credits can still be the remaining resource credits. It should be noted that the above examples are not intended to limit the various methods or combinations in which resource credit accumulation rates and baseline performance can be implemented.
仮想コンピュータリソースをスケジュールするためのローリングリソースクレジットは(以下に説明する図2及び図3に例示の通り)同じ仮想化ホストにおいてホストされる複数の仮想計算インスタンスに対して実施され得る。ローリングリソースクレジット残量限度120を実施することは、任意の1つの計算インスタンスが、他のインスタンスに対する作業要求の性能を妨害するのに十分なリソースクレジットを蓄積しないようにし得る。例えば、図1に例示の通り、ローリングリソースクレジット残量限度が144リソースクレジットに設定されると、いずれか1つの仮想計算インスタンスが物理的なコンピュータリソースを独占し得る最大限度は2時間24分(リソースクレジットがリソースの1分間のフル活用に等しいと仮定する)である。
Rolling resource credits for scheduling virtual computer resources can be performed on multiple virtual computing instances hosted on the same virtualization host (as illustrated in FIGS. 2 and 3 described below). Enforcing the rolling resource
前述の記載は計算インスタンスに対するローリングリソースクレジット残量及び使用量の一例を提供するにすぎず、限定する意図はないことに留意されたい。リソースクレジットが使用され得る様々な量に応じて、蓄積率、初期の残量及び残量限度は全て異なり得る。 Note that the above description provides only an example of rolling resource credit remaining and usage for compute instances and is not intended to be limiting. The accumulation rate, initial remaining amount and remaining amount limit can all vary depending on the various amounts of resource credits that can be used.
本明細書は次に、仮想コンピューティングリソースプロバイダ概要を含み、仮想コンピューティングリソースプロバイダは、プロバイダネットワークに実施されるネットワークトラフィックポリシに含まれるネットワークエンティティハンドルに対してネットワーク
エンティティ登録を実施し得る。その後、仮想コンピューティングリソースの様々な例が説明され、これは仮想コンピューティングリソースプロバイダ実施の一部として利用され得る、異なる構成要素/モジュールまたは構成要素/モジュールの配置を含む。プロバイダネットワークに実施されるネットワークトラフィックポリシに含まれるネットワークエンティティハンドルに対する、ネットワークエンティティ登録を実施するための多数の異なる方法及び技法がその後説明され、そのいくつかは添付のフロー図で例示される。最後に、様々な構成要素、モジュール、システム、デバイス及び/またはノードが実装され得るコンピューティングシステムの一例の記載が提供される。様々な例は明細書を通じて提供される。
The present specification then includes a virtual computing resource provider overview, which may perform network entity registration for a network entity handle contained in a network traffic policy implemented on the provider network. Various examples of virtual computing resources are then described, which include different component / module or component / module placement that can be utilized as part of the virtual computing resource provider implementation. A number of different methods and techniques for performing network entity registration for network entity handles contained in the network traffic policy implemented on the provider network are subsequently described, some of which are illustrated in the attached flow diagram. Finally, an example description of a computing system in which various components, modules, systems, devices and / or nodes can be implemented is provided. Various examples are provided throughout the specification.
図2は、いくつかの実施形態に係る、仮想コンピューティングリソースをスケジュールするためのローリングリソースクレジットを実施する仮想計算インスタンスを提供するネットワークベースの仮想コンピューティングサービスを例示するブロック図である。ネットワークベースの仮想コンピューティングサービス200は企業または公的機関などのエンティティにより設定され、インターネット及び/または他のネットワークを介して、アクセス可能な1つ以上のサービス(様々な種類のクラウドベースのコンピューティングサービスまたはストレージサービスなど)をクライアント202に提供しても良い。ネットワークベースの仮想コンピューティングサービス200は、ネットワークベースの仮想コンピューティングサービス200により供給されるインフラストラクチャ及びサービスを実施及び分散するために必要とされる、物理的及び/または仮想化されたコンピュータサーバ、ストレージデバイス、ネットワーキング装置の集合などの様々なリソースプールをホストする無数のデータセンタを含み得る。いくつかの実施形態では、ネットワークベースの仮想コンピューティングサービス200はコンピューティングリソースを提供し得る。これらのコンピューティングリソースは、いくつかの実施形態では、仮想計算インスタンスなどの「インスタンス」234と呼ばれる単位でクライアントに供給され得る。
FIG. 2 is a block diagram illustrating a network-based virtual computing service that provides virtual computing instances that perform rolling resource credits for scheduling virtual computing resources, according to some embodiments. The network-based virtual computing service 200 is configured by an entity such as a company or public institution and is accessible via the Internet and / or other networks (various types of cloud-based computing). Services or storage services, etc.) may be provided to the
様々な実施形態では、ネットワークベースの仮想コンピューティングサービス200は、ネットワークベースの仮想コンピューティングサービス200によりクライアント202に提供されるコンピューティングリソース供給物を管理するために、制御プレーン210を実装し得る。制御プレーン210はコンピューティングリソース供給物を管理するために様々な異なる構成要素を実装し得る。制御プレーン210は種々のサーバ、ノードまたは他のコンピューティングシステムもしくはデバイス(図9に関して以下に記載するコンピューティングシステム1000など)にわたり実装され得る。所与の構成要素の1つ以上のインスタンスが存在し得る場合、本明細書におけるその構成要素に対する言及は、単数または複数のいずれかを指し得ることが留意される。しかしながら、いずれかの形態の使用は他方を排除することを意図しない。
In various embodiments, the network-based virtual computing service 200 may implement a control plane 210 to manage the computing resource supply provided by the network-based virtual computing service 200 to the
少なくともいくつかの実施形態では、制御プレーン210はインターフェース212を実装し得る。インターフェース212は、ネットワーク260を介して受信される着信要求を処理し、さらなる処理のために要求を適切な構成要素に導くように構成され得る。少なくともいくつかの実施形態では、インターフェース212はネットワークベースのインターフェースでも良く、(例えば、管理制御パネルもしくはウェブサイトの一部としての)グラフィカルインターフェース及び/または(例えば、様々なアプリケーションプログラミングインターフェース(API)コマンドを処理する)プログラマチックインターフェースとして実装されても良い。様々な実施形態では、インターフェース212は、リソース管理214、予約管理216、リソース監視218及び請求220などの様々な他の構成要素に要求を発信するフロントエンドモジュールまたは構成要素の一部として実装され得る。クライアント202は、様々な実施形態では、リソースを直接的に整備したり、起動したり、または構成したりし得ないが、例示された構成要素(または例示されない他の構成要素、機能もしくはサービス)が要求されたアクションを行い得るよう、要求を制
御プレーン210に送信し得る。
In at least some embodiments, the control plane 210 may implement the interface 212. Interface 212 may be configured to process incoming requests received over
制御プレーン210はリソース管理モジュール214を実装し、プロバイダネットワークにより供給されるコンピューティングリソースへのアクセス、コンピューティングリソースの容量、コンピューティングリソースへのマッピング及びコンピューティングリソースの他の制御もしくは命令を管理し得る。少なくともいくつかの実施形態では、リソース管理モジュール214は容量予約(例えば、予約された計算インスタンス)のための直接販売及び第三者再販市場の両方を提供し得る。例えば、リソース管理モジュール214は、インターフェース212を介して、クライアント202が初期の販売マーケットプレイスまたは再販マーケットプレイスのいずれかからコンピューティングリソースの容量を把握し、選択し、アクセス権を購入及び/または予約することを可能にしても良く、これはウェブページを介して、またはAPIを介して行われる。例えば、リソース管理構成要素は、インターフェース212を介して、異なる利用可能な計算インスタンスの種類のリストを提供しても良く、リストのそれぞれは異なるクレジット蓄積率を備える。追加的に、いくつかの実施形態では、リソース管理モジュール214は、指定された購入量またはスキーム(例えば、一括払い、追加定期支払等)に対して、(インスタンスの種類に対するクレジット蓄積率を介して提供されるクレジットに加えて)購入用クレジットを供給するように構成され得る。例えば、リソース管理モジュール214はクレジット購入要求(例えば、API要求)を受信し、仮想インスタンス残量に購入済みのクレジットを入れるように構成され得る。同様に、リソース管理モジュール214は、特定のインスタンスに対するクレジット蓄積率を増加する要求を処理するように構成され得る。リソース管理214は、さらに一連の柔軟なリソース予約、制御及びインターフェース212を介したクライアント202に対するインターフェースへのアクセスを供給及び/または実装し得る。例えば、リソース管理モジュール214は、計算インスタンス制御動作/クライアントと使用中のコンピューティングリソースとの相互作用が行われ得るよう、認証情報またはアクセス許可をクライアント202に提供し得る。
The control plane 210 implements the resource management module 214 to manage access to computing resources provided by the provider network, capacity of computing resources, mapping to computing resources, and other controls or instructions for computing resources. obtain. In at least some embodiments, the resource management module 214 may provide both direct sales and third party resale markets for capacity reservations (eg, reserved compute instances). For example, the resource management module 214, through interface 212, allows the
様々な実施形態では、予約管理モジュール216はインスタンス234の様々な価格スキーム(少なくとも初期の販売マーケットプレイスに対して)を処理するように様々な実施形態で構成され得る。例えば、いくつかの実施形態では、ネットワークベースの仮想コンピューティングサービス200は、例えば、期間予約(つまり、予約された計算インスタンス)、オンデマンドのリソース割り当てまたはスポット価格ベースのリソース割り当て等、いくつかの異なる購入モード(本明細書において、予約モードとしてさらに言及され得る)をサポートしても良い。長期予約モードを使用すると、クライアントは、計算インスタンスまたは他のコンピューティングリソースに対して低価格の1回限りの前払いを行ない、1年間または3年間などの指定期間にわたって計算インスタンスを予約し、そのインスタンスに対して低価格の時間当たりの料金を支払うことができ、クライアントは、予約期間にわたって利用可能な予約されたインスタンスを有することが保証されるだろう。オンデマンドモードを使用すると、クライアントは、長期間の約束または前払いをすることなく、1時間(または何らかの適切な時間単位)毎に容量に対して支払うことが可能である。スポット価格モードでは、クライアントは、計算インスタンスまたは他のコンピューティングリソースの特定の種類に対して支払うことを望んでいる、単位時間当たりの最高価格を指定することが可能であり、クライアントの最高価格が、少なくとも部分的に供給及び需要により決定された動的スポット価格を超えた場合、その種類のリソースがクライアントに提供されることになる。
In various embodiments, the
要求されたリソースの種類の供給が需要を超えた期間中、スポット価格は、オンデマンドモードの価格よりもはるかに低くなり得る。いくつかの実装において、スポット価格がクライアントにより指定された最高の指値を上回って増加した場合、リソース割り当ては中断されても良く、すなわち、以前にクライアントに割り当てられていたリソースインス
タンスは、リソース管理モジュール330により回収されても良く、より高い価格を支払うことを望んでいる誰か他のクライアントに割り当てられても良い。リソース容量予約は、さらに制御プレーンデータストア222を更新し、所有権、クライアント使用、クライアントアカウントまたは他のリソース情報の変更を反映し得る。
Spot prices can be much lower than prices in on-demand mode during periods when the supply of the requested resource type exceeds demand. In some implementations, if the spot price increases above the highest limit specified by the client, the resource allocation may be interrupted, that is, the resource instance previously assigned to the client is the resource management module. It may be recovered by 330 or assigned to someone else who wants to pay a higher price. Resource capacity reservations may further update the control plane datastore 222 to reflect changes in ownership, client usage, client accounts or other resource information.
様々な実施形態では、制御プレーン210はリソース監視モジュール218により実装され得る。リソース監視モジュール218は、異なる仮想コンピュータリソース、クライアント、ユーザアカウント及び/または特定のインスタンスのために消費される、様々なコンピューティングインスタンス(例えば、リソースクレジット残量、リソースクレジット消費)の消費を追跡し得る。少なくともいくつかの実施形態では、リソース監視モジュール218は一群の全ての仮想化ホスト230及びインスタンス234の様々な異なるシナリオを停止、解決、管理、または別の方法で応答するための様々な管理アクションを実施し得る。リソース監視モジュール218は、クライアント202(複数可)にクライアントが構成したアラームの管理ならびに様々な指標データへのアクセスをさらに提供し得る。以下に詳細に説明される図8は、リソース監視モジュールが実施し得る様々な技法のさらなる例を提供する。 In various embodiments, the control plane 210 may be implemented by the resource monitoring module 218. The resource monitoring module 218 tracks the consumption of various computing instances (eg, resource credit balance, resource credit consumption) consumed for different virtual computer resources, clients, user accounts and / or specific instances. obtain. In at least some embodiments, the resource monitoring module 218 performs various management actions to stop, resolve, manage, or otherwise respond to various different scenarios of all virtualized hosts 230 and instance 234 in a group. Can be done. The resource monitoring module 218 may further provide the client 202 (s) with management of client-configured alarms and access to various indicator data. FIG. 8, described in detail below, provides further examples of various techniques that the resource monitoring module can perform.
様々な実施形態では、制御プレーン210は請求管理モジュール220を実装し得る。請求管理モジュール220は請求イベント(例えば、特定の日付、時間、使用量、請求額に対する要求または特定のユーザアカウントもしくはユーザアカウントにリンクされた支払アカウントに対する請求額を生成する任意の他の要因)を検出するように構成され得る。請求イベントの検出に応えて、請求管理モジュールはユーザアカウントまたはユーザアカウントにリンクされた支払アカウントに対する請求額を生成するように構成され得る。
In various embodiments, the control plane 210 may implement the
仮想計算インスタンス234は、例えば、指定された計算能力(CPUの種類及び数、メインメモリサイズ等を示すことにより指定されても良い)、及び指定されたソフトウェアスタック(例えば、これによりハイパーバイザの上位で稼動することができる、オペレーティングシステムの特定のバージョン)を備える1つ以上のサーバを含み得る。異なる実施形態において、ネットワークベースの仮想コンピューティングサービス200の計算インスタンス234を実装するために、汎用または専用コンピュータサーバ、ストレージデバイス、ネットワークデバイスなどを含む、多数の異なる種類のコンピューティングデバイスが単独または組み合わされて使用されても良い。いくつかの実施形態では、インスタンスクライアント202または他の任意の他のユーザはネットワークトラフィックを計算インスタンス234に導くように構成(及び/または許可)され得る。
The virtual compute instance 234 is, for example, a specified computing power (which may be specified by indicating the type and number of CPUs, main memory size, etc.) and a specified software stack (eg, thereby higher than the hypervisor). It may include one or more servers with a specific version of the operating system that can run on. In different embodiments, a number of different types of computing devices, including general purpose or dedicated computer servers, storage devices, network devices, etc., are used alone or in combination to implement compute instances 234 of the network-based virtual computing service 200. May be used. In some embodiments, the
計算インスタンス234は種々の異なるプラットフォームを動作または実装しても良く、このようなプラットフォームとしては、アプリケーションサーバインスタンス、Java(登録商標)仮想マシン(JVM)、汎用もしくは専用オペレーティングシステム、Ruby、Perl、Python、C、C++などの様々なインタープリタ方式もしくはコンパイラ方式のプログラミング言語をサポートするプラットフォームなど、または高性能コンピューティングプラットフォームなどがあり、例えば、クライアント202がインスタンス234にアクセスする必要なく、クライアント202アプリケーションを行うのに好適である。様々な異なる種類の計算インスタンスがあり得る。少なくともいくつかの実施形態では、仮想コンピュータリソース動作をスケジュールするためのローリングリソースクレジット残量を実施する計算インスタンスがあり得る。この種類のインスタンスはリソースクレジットに基づき実行し、ここでリソースクレジットはインスタンスが物理的なリソースの作業を行うのに費やすことができる時間(例えば、物理的なCPUの処理時間、ネットワーク通信チャネルを活用する時間等)を表す。インスタンスがコンピュータリソースに対して有するリソースクレジットが多いほど、物理的なリソースが作業を実行するのに費やし得る時間が長くなる(性能が増加する)。リソースクレジットはインスタ
ンスの起動時に提供されても良く、活用時間(例えば、CPU―分などのCPU時間)として定義されても良く、活用時間は、あるインスタンスの仮想リソースが基礎を成す物理的なリソースのタスク実行に費やすことができる時間を表し得る。
Computation Instance 234 may operate or implement a variety of different platforms, such as Application Server Instances, Java® Virtual Machines (JVM), General Purpose or Dedicated Operating Systems, Rubi, Perl, Python. , C, C ++ and other platforms that support various interpreter or compiler programming languages, or high performance computing platforms, for example, to perform
様々な実施形態では、リソースクレジットはベースライン活用保証を超過した時間またはリソースの活用を表し得る。例えば、計算インスタンスはリソースに対して10%のベースライン活用保証を有しても良く、したがって、リソースクレジットはリソースの活用が10%を超えるよう増加しても良い。残りのリソースクレジットが無い場合でも、やはり10%のベースラインで計算インスタンスに活用が保証され得る。クレジット消費は、インスタンスがベースライン性能を超える作業を行うために物理的なリソースを必要とする際にのみ発生し得る。いくつかの実施形態では、計算インスタンスがリソースのベースライン活用保証を消費する作業要求を送信するかどうかに関わらず、クレジットは更新されるか、またはリソースクレジット残量に蓄積され得る。 In various embodiments, resource credits may represent time or resource utilization that exceeds the baseline utilization guarantee. For example, a compute instance may have a 10% baseline utilization guarantee for resources, and therefore resource credits may be increased to exceed 10% resource utilization. Even if there are no remaining resource credits, utilization can still be guaranteed for compute instances at a 10% baseline. Credit consumption can only occur when an instance requires physical resources to do work that exceeds baseline performance. In some embodiments, credits can be renewed or accumulated in the resource credit balance, regardless of whether the compute instance sends a work request that consumes the resource's baseline utilization guarantee.
コンピュータリソースをスケジュールするためのローリングリソースクレジットを実施する異なる種類の計算インスタンスが供給され得る。異なる計算インスタンスは、特定の数の仮想CPUコア、メモリ、キャッシュ、ストレージ、ネットワーキングならびに任意の他の性能特性を有し得る。計算インスタンスの構成は、その位置、特定のデータセンタにおいては、利用可能ゾーン、地理、位置等及び(予約計算インスタンスの場合は)予約期間の長さをさらに含み得る。異なる計算インスタンスは異なる仮想リソースに対して異なるリソースクレジット蓄積率を有しても良く、計算インスタンスのために維持されるリソースクレジットの現在の残量に蓄積する多数のリソースクレジットであっても良い。例えば、いくつかの実施形態では、計算インスタンスのある種類は1つの仮想コンピュータリソースに対して1時間当たり6クレジットを蓄積しても良く、一方で別の種類の計算インスタンスは同じ種類の仮想コンピュータリソースに対して1時間当たり24クレジットを蓄積しても良い。別の例では、同じ仮想計算インスタンスの1つのリソース(例えば、vCPU)に対するリソースクレジット蓄積率は、別の仮想コンピュータリソース(例えば、ネットワーキングチャネル)に対するリソースクレジット蓄積率とは異なり得る。いくつかの実施形態では、ある仮想計算インスタンスにより使用される複数の異なる仮想コンピュータリソースに対して、その仮想計算インスタンスのために複数の異なるリソースクレジット残量が維持され得る。ベースライン性能保証は、仮想コンピュータリソースのそれぞれに対してさらに実施されても良く、ベースライン性能保証は、異なるインスタンス種類に対して、ならびに各それぞれの仮想コンピュータリソースに対して異なり得る。 Different types of compute instances may be provided that perform rolling resource credits for scheduling computer resources. Different compute instances can have a certain number of virtual CPU cores, memory, cache, storage, networking and any other performance characteristics. The configuration of a compute instance may further include its location, in a particular data center, available zones, geography, location, etc. and (in the case of reserved compute instances) the length of the reservation period. Different compute instances may have different resource credit accumulation rates for different virtual resources, or may be a large number of resource credits accumulating in the current remaining amount of resource credits maintained for the compute instance. For example, in some embodiments, one type of compute instance may accumulate 6 credits per hour for one virtual computer resource, while another type of compute instance may accumulate the same type of virtual computer resource. You may accumulate 24 credits per hour. In another example, the resource credit accumulation rate for one resource (eg, vCPU) of the same virtual computing instance can be different from the resource credit accumulation rate for another virtual computer resource (eg, networking channel). In some embodiments, for a plurality of different virtual computer resources used by a virtual compute instance, a plurality of different resource credit balances may be maintained for that virtual compute instance. Baseline performance guarantees may be further implemented for each of the virtual computer resources, and baseline performance guarantees may be different for different instance types, as well as for each individual virtual computer resource.
ベースライン性能保証は、いくつかの実施形態では、リソースクレジット蓄積率と共に含まれ得る。したがって、一例では、インスタンス種類は、処理のための特定のリソースクレジット蓄積率及び保証されたベースライン性能、ならびにネットワーキングチャネルのための別の特定のリソースクレジット蓄積率及び保証されたベースライン性能率を含み得る。このように、ネットワークベースの仮想コンピューティングサービス200は、異なる仮想コンピュータリソースに対する異なる組み合わせのリソースクレジット蓄積率及びベースライン保証を備える、多くの異なる種類のインスタンスを供給し得る。これらの異なる構成は、リソースクレジット蓄積率及びベースライン性能率ならびに様々な物理的及び/または仮想容量に従って、別々に価格設定され得る。いくつかの実施形態では、仮想計算インスタンスは1時間毎の価格で予約及び/または活用され得る。一方、長期予約インスタンス構成は異なる価格スキームを活用しても良いが、やはりクレジット蓄積率及びベースライン性能保証を含む。 Baseline performance guarantees may be included with resource credit accumulation rates in some embodiments. Thus, in one example, the instance type has a specific resource credit accumulation rate and guaranteed baseline performance for processing, as well as another specific resource credit accumulation rate and guaranteed baseline performance rate for networking channels. Can include. As such, the network-based virtual computing service 200 may provide many different types of instances with different combinations of resource credit accumulation rates and baseline guarantees for different virtual computer resources. These different configurations can be priced separately according to resource credit accumulation rates and baseline performance rates as well as various physical and / or virtual capacities. In some embodiments, the virtual compute instance may be booked and / or utilized at an hourly price. On the other hand, long-term booking instance configurations may utilize different pricing schemes, but also include credit accumulation rates and baseline performance guarantees.
図2に例示する通り、いくつかの実施形態では、仮想化ホスト230a、230b〜230nなどの仮想化ホスト230は複数の計算インスタンス234を実装及び/または管理しても良く、図9に関して以下に記載されるコンピューティングシステム1000など
の1つ以上のコンピューティングデバイスであっても良い。仮想化ホスト230は仮想化管理モジュール232a、232b〜232nなどの仮想化管理モジュール232を含んでも良く、多数の異なるクライアントがアクセス可能な仮想マシンまたは計算インスタンス234をインスタンス化及び管理することができる。仮想化管理モジュール232は、例えば、オペレーティングシステムのハイパーバイザ及び管理インスタンスを含んでも良く、いくつかの実装では、「ドメインゼロ」または「dom0」と呼ばれ得る。dom0オペレーティングシステムは、クライアントによりアクセスすることができず、その代りに計算インスタンス234が動作するが、計算インスタンス234に導かれる、または計算インスタンス234から導かれるネットワークトラフィックの処理を含め、ネットワークプロバイダの様々な管理または制御プレーン動作を代わりに担う。
As illustrated in FIG. 2, in some embodiments, the virtualization hosts 230, such as the virtualization hosts 230a, 230b-230n, may implement and / or manage a plurality of compute instances 234, with reference to FIG. 9 below. It may be one or more computing devices such as the described computing system 1000. The virtualization host 230 may include virtualization management modules 232 such as virtualization management modules 232a, 232b to 232n, and can instantiate and manage virtual machines or compute instances 234 accessible to many different clients. The virtualization management module 232 may include, for example, an operating system hypervisor and management instance, and in some implementations it may be referred to as "domain zero" or "dom0". The dom0 operating system is inaccessible to clients and instead operates compute instance 234, but with a variety of network providers, including handling network traffic directed to or from compute instance 234. Takes on the management or control plane operation instead.
クライアント202(複数可)は要求をネットワークベースの仮想コンピューティングサービス200に送信するように構成可能な、任意の種類のクライアントを包含し得る。例えば、所与のクライアント202は好適なバージョンのウェブブラウザを含み得るか、あるいはウェブブラウザにより提供される実行環境への拡張として、または実行環境内で実行するように構成されるプラグインモジュールもしくは他の種類のコードモジュールを含んでも良い。代替的には、クライアント202はダッシュボードアプリケーション(またはダッシュボードアプリケーションのユーザインターフェース)、メディアアプリケーション、オフィスアプリケーションまたは様々な動作を行うために計算インスタンス234を利用し得る任意の他のアプリケーションなどのアプリケーションを包含しても良い。いくつかの実施形態では、係るアプリケーションは、あらゆる種類のネットワークベースのデータの完全なブラウザサポートを必ずしも実装することなく、ネットワークベースのサービス要求を生成及び処理するのに十分なプロトコルサポート(例えば、好適なバージョンのハイパーテキスト転送プロトコル(HTTP)に対してのサポート)を含んでも良い。いくつかの実施形態では、クライアント202は、リプリゼンテーショナル・ステート・トランスファ(REST)型のネットワークベースのサービスアーキテクチャ、ドキュメントまたはメッセージベースのネットワークベースのサービスアーキテクチャ、または別の好適なネットワークベースのサービスアーキテクチャに従って、ネットワークベースのサービス要求を生成するように構成されても良い。いくつかの実施形態では、クライアント202(例えば、計算クライアント)は、計算インスタンス324により提供される計算リソースを活用して、クライアント202上でのアプリケーション実装に透過的な方式で、計算インスタンス234へのアクセスを提供するように構成されても良い。
Client 202 (s) may include any type of client that can be configured to send a request to the network-based virtual computing service 200. For example, a given
クライアント202はネットワーク260を介してネットワークベースのサービス要求をネットワークベースの仮想コンピューティングサービス200に伝送しても良い。様々な実施形態では、ネットワーク260は、クライアント202とネットワークベースの仮想コンピューティングサービス200との間のネットワークベース通信を構築するために必要なネットワーキングハードウェア及びプロトコルの任意の好適な組み合わせを包含し得る。例えば、ネットワーク260は、概して、集合的にインターネットを実装する様々な電気通信ネットワーク及びサービスプロバイダを包含し得る。ネットワーク260は、ローカルエリアネットワーク(LAN)またはワイドエリアネットワーク(WAN)などのプライベートネットワーク、ならびに公衆またはプライベート無線ネットワークをさらに含んでも良い。例えば、所与のクライアント202及びネットワークベースの仮想コンピューティングサービス200の両方が、それぞれ、独自の内部ネットワークを有する企業内で整備されても良い。係る実施形態では、ネットワーク260は、所与のクライアント202とインターネットとの間、ならびにインターネットとネットワークベースの仮想コンピューティングサービス200との間のネットワーキングリンクを構築するために必要なハードウェア(例えば、モデム、ルータ、スイッチ、ロードバランサ、プロキシサーバ等)及びソフトウェア(例えば、プロトコルスタック、会計ソフトウェア、ファイアウォール/セキュリティソフトウェア等)を含んでも良い。いくつかの実施形態では、クラ
イアント202は、公衆インターネットよりもむしろプライベートネットワークを使用して、ネットワークベースの仮想コンピューティングサービス200と通信しても良いことが留意される。
図3はいくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングリソースクレジットを実施する仮想化ホストを例示するブロック図である。上記の図2で述べる通り、仮想化ホストは1つ以上の仮想計算インスタンスのためのホストプラットフォームとして機能し得る。これらの仮想計算インスタンスは仮想化されたハードウェアインターフェースを活用し、様々なタスク、機能、サービス及び/またはアプリケーションを行い得る。これらのタスクの実行の一部として、仮想計算インスタンスは、それぞれの計算インスタンスに対するそれぞれの物理的なコンピュータリソース上で作業を行うために、仮想化ホストで実装される仮想化されたコンピュータリソース(例えば、物理的なCPU(複数可)に対する仮想プロキシとして機能し得る仮想中央処理装置(複数可)(vCPU))を活用し得る。 FIG. 3 is a block diagram illustrating a virtualized host that implements rolling resource credits to schedule virtual computer resources, according to some embodiments. As described in FIG. 2 above, a virtualized host can act as a host platform for one or more virtual computing instances. These virtual computing instances can take advantage of virtualized hardware interfaces to perform a variety of tasks, functions, services and / or applications. As part of performing these tasks, virtualized computer resources are implemented on virtualized hosts to work on their respective physical computer resources for each compute instance (eg, virtualized computer resources). , A virtual central processing unit (s) (vCPU) that can function as a virtual proxy for a physical CPU (s).
図3は仮想化ホスト310を例示する。仮想化ホスト310は、計算インスタンス330a、330b、330c〜330nをホストし得る。少なくともいくつかの実施形態では、計算インスタンス330は同じ種類の計算インスタンスであっても良い。図3では、計算インスタンス330は仮想コンピュータリソースをスケジュールするためのローリングリソースクレジットを実施する計算インスタンスである。仮想化ホスト310は、仮想計算インスタンス330と物理的なコンピューティングリソース(複数可)340との間の様々なインターフェース(例えば、様々なハードウェア構成要素、プロセッサ、入出力デバイス、ネットワーキングデバイス等)を処理し得る仮想化管理モジュール320をさらに実装し得る。 FIG. 3 illustrates the virtualization host 310. The virtualization host 310 may host compute instances 330a, 330b, 330c-330n. In at least some embodiments, the compute instance 330 may be the same type of compute instance. In FIG. 3, compute instance 330 is a compute instance that performs rolling resource credits for scheduling virtual computer resources. The virtualization host 310 provides various interfaces (eg, various hardware components, processors, I / O devices, networking devices, etc.) between the virtual computing instance 330 and the physical computing resource (s) 340. A virtualization management module 320 that can be processed may be further implemented.
図3では、仮想化管理モジュール320はローリングリソースクレジット残量スケジューラ324を実装し得る。ローリングリソースクレジット残量スケジューラ324はメタスケジューラとして機能しても良く、それぞれの計算インスタンス330に対して全てのリソースクレジット残量を管理、追跡、適用、差し引き、及び/または別の方法で処理する。様々な実施形態では、ローリングリソースクレジット残量スケジューラ324は計算インスタンスから仮想計算リソース作業要求332を受信するように構成され得る。各作業要求332は作業を送信した計算インスタンスに対応する仮想コンピュータリソースに向けて導き得る。各要求332に対し、ローリングリソースクレジット残量スケジューラは、要求している計算インスタンス330に対する現在のリソースクレジット残量を判定し、作業要求を行う際にリソースクレジットを適用するスケジューリング命令を生成するように構成され得る。いくつかの実施形態では、ローリングリソースクレジット残量スケジューラ324はスケジューリング命令の実行を行うか、スケジューリング命令の実行を命令し、実行対象の基礎を成す物理的なコンピューティングリソース340に作業要求を導くか、または送信し得る。例えば、いくつかの実施形態では、異なるハードウェアキューが実施され、ローリングリソースクレジット残量スケジューラ324は適用されたリソースクレジット(例えば、適用されたリソースクレジットの時間量に従ったタスクのキューイング)に従って、キューの作業要求を行うためのタスクを配置するために使用され得る。しかしながら、いくつかの実施形態では、リソーススケジューリング命令は仮想計算リソーススケジューラ322に送信されても良く334、仮想計算リソーススケジューラ322は仮想化ホスト310で実装され得る、CPU(複数可)などの物理的なリソース340に対するスケジューラであっても良い。ローリングリソースクレジット残量スケジューラ324は、リソースクレジットを適用し、リソースクレジットを差し引き、及び/または別の方法で作業要求が適用されたリソースクレジットに従って行われることを保証するために、図5〜図7に関して以下に記載される様々な技法を行うように構成されても良い。
In FIG. 3, the virtualization management module 320 may implement the rolling resource credit remaining
いくつかの実施形態では、スケジューリング命令を受信することに応えて、仮想計算リソーススケジューラ322は、様々な実施形態では、作業要求336に対する物理的なスケジューリング命令を物理的なCPU(複数可)などの物理的なコンピューティングリソースに提供し得る。少なくともいくつかの実施形態では、仮想計算リソーススケジューラ322は、1つ以上のCPUに対するクレジットベースのスケジューラであっても良い。
In some embodiments, in response to receiving a scheduling instruction, the virtual
ローリングリソースクレジット残量スケジューラ324はクレジット残量及び使用量指標362を監視エージェント326にさらに報告しても良く、監視エージェント326は、次にこれらの指標を任意の他のホスト指標364(健全性情報等)と共にリソース監視モジュール218に報告しても良い。
The rolling resource credit remaining
図2に関して上記の通り、仮想コンピューティングリソースプロバイダに対するネットワークベースのインターフェースが図式化して実装され得る。図4はいくつかの実施形態に係る、仮想計算インスタンスに対するローリングクレジット指標を提供するインターフェースの一例の説明図である。ローリングリソースクレジットインターフェース400は様々なクライアントにアクセス可能なネットワークベースのサイトとして実装され得る。いくつかの実施形態では、ローリングリソースクレジットインターフェース400は、APIなどのプログラマチックインターフェースを介して、ネットワークベースの仮想コンピューティングリソースプロバイダと通信し得る、ダウンロード可能なアプリケーション、またはローカルに実行されるアプリケーションとして実装され得る。
As mentioned above with respect to FIG. 2, a network-based interface to a virtual computing resource provider can be graphically implemented. FIG. 4 is an explanatory diagram of an example of an interface that provides a rolling credit index for a virtual compute instance, according to some embodiments. The rolling
エリア410は、指標データが表示され得る様々なインスタンスのリストを例示する。セレクタ412a、412b、412c、414a、414b及び414cなどの様々な異なるユーザインターフェース要素を実装して、どの物理的なリソース及び特定のインスタンスデータを読み出すべきかを示しても良い。エリア420は、表示用に選択され得る異なる種類の指標データを例示する。例えば、いくつかの実施形態では、特定のインスタンスに対するリソースクレジット残量指標422、及び選択されたインスタンスによるリソースクレジット使用量424を選択しても良い。いくつかの実施形態では、特定のインスタンスに対するクレジット更新率が例示され得る。エリア430はインスタンス指標表示エリアを表し得る。読み出されたインスタンス指標は様々な形式(例示の線グラフ、図、表または任意の他の図式またはテキストデータ表現技法など)で表示されても良い。エリア440は表示された指標データの形式を変更するための異なるユーザインターフェース要素を表し得る。例えば、表示設定444が選択されると、ポップウィンドウまたはダイアログボックスが開き、これによりデータを表示する時間範囲などの異なる表示設定を修正することが可能になり得る。表示指標要素442が選択されると、行われた変更が実行され、インスタンス指標表示430に表示されるデータを生成または再生成し得る。エクスポート指標446要素はユーザにより指定された場所にダウンロードまたは記憶される未処理の指標データを抽出するための様々な機構を提供するように構成され得る(例えば、ファイルダイアログウィンドウを開く)。ツール要素448は、指標データを基に、様々な異なるツール、分析または他の推奨エンジンを実行するように選択可能であり得る。例えば、インスタンス種類を(例えば、より大きいまたはより小さいバースト処理インスタンスに)変更するかどうかを推奨するツールが選択され得る。
図4の例示及び添付の記載はグラフィカルユーザインターフェースの一例を提供することを意図するにすぎないことに留意されたい。グラフィカルインターフェースを含まない、様々な他の構成及びインターフェースが実装されても良く、したがって、前述の例は限定を意図するものではない。例えば、上記に説明したデータ、指標または他の情報に対する様々な要求がプログラマティックインターフェース(API)を介して仮想コンピューティングリソースプロバイダから要求されても良く、未処理のデータが要求中のクライア
ントに戻されても良い。例えば、クライアントが仮想コンピューティングリソースプロバイダのAPIを介して、特定の計算インスタンスに対するクレジット使用量及び更新率を要求した場合、そのクライアントのための指標または追跡情報がクライアントに提供されても良い。
It should be noted that the illustrations and accompanying descriptions in FIG. 4 are intended only to provide an example of a graphical user interface. Various other configurations and interfaces may be implemented that do not include a graphical interface, and therefore the above examples are not intended to be limiting. For example, various requests for the data, metrics or other information described above may be requested by the virtual computing resource provider via a programmatic interface (API) and the raw data is returned to the requesting client. May be done. For example, if a client requests credit usage and renewal rate for a particular compute instance through the API of a virtual computing resource provider, metrics or tracking information for that client may be provided to the client.
図2〜図4に関して上記に説明した仮想コンピューティングリソースをスケジュールするためにローリングリソースクレジットを実施する例は、ネットワークベースのコンピューティングリソースサービスにより供給される仮想コンピューティングリソースに関して与えられた。仮想コンピューティングリソースの様々な他の種類または構成はこれらの技法を実施しても良く、これらの技法はネットワークベースのサービスの一部として供給されても良く、または供給されなくても良い。例えば、他の仮想コンピューティングリソースは、より短い期間でバースト処理または他のバースト活用に高性能レベルで利用可能であることを望み、例えば、仮想コンピューティングリソースをスケジュールするためのローリングリソースクレジットを実施し得る。図5はいくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングリソースクレジットを実施する様々な方法及び技法を例示する高レベルフロー図である。これらの技法は、図2〜図4に関して上記に記載したネットワークベースの仮想コンピューティングサービスの様々な構成要素または他の仮想コンピューティングリソースホストを使用して実施され得る。 An example of performing rolling resource credits to schedule the virtual computing resources described above with respect to FIGS. 2-4 was given for virtual computing resources provided by a network-based computing resource service. Various other types or configurations of virtual computing resources may implement these techniques, which may or may not be supplied as part of a network-based service. For example, other virtual computing resources may want to be available at a high performance level for burst processing or other burst utilization in a shorter period of time, eg, implementing rolling resource credits to schedule virtual computing resources. Can be done. FIG. 5 is a high level flow diagram illustrating various methods and techniques for performing rolling resource credits to schedule virtual computer resources, according to some embodiments. These techniques can be performed using various components of the network-based virtual computing services described above with respect to FIGS. 2-4 or other virtual computing resource hosts.
510に示す通り、1つ以上の仮想コンピュータリソースに対する作業要求が仮想計算インスタンスに対する仮想化ホストで受信され得る。要求は仮想コンピュータリソース(例えば、処理、ネットワーキング、ストレージ等)を識別し得る。作業要求は作業要求を完了するために行われる作業量またはタスク量を識別し得る。 As shown in 510, work requests for one or more virtual computer resources can be received by the virtualization host for virtual computing instances. The request can identify virtual computer resources (eg, processing, networking, storage, etc.). The work request can identify the amount of work or task performed to complete the work request.
520に示す通り、仮想コンピュータリソースそれぞれ計算インスタンスに対する現在のリソースクレジット残量が判定され得る。リソースクレジット蓄積率は、様々な実施形態では、期間中に未使用である現在のリソースクレジット残量に追加されるいくつかのリソースクレジットであり得る。例えば、リソースクレジット蓄積率が1時間当たり12リソースクレジットに設定されると、その後、その時間中に消費されない全てのリソースクレジットが現在のリソースクレジット残量の合計に追加され得る(例えば、12のうち9が使用されていないと、9が追加され得る)。いくつかの実施形態では、リソースクレジット蓄積率は仮想計算インスタンスに対するベースライン活用または性能保証に一致し得る。現在のリソースクレジット残量が高いほど、仮想計算インスタンスが仮想コンピュータリソースを使用してより高いレベルの性能を持続することができる時間がより長くなり得る。複数の異なるリソースクレジット残量が異なる仮想コンピュータリソースに対して実施されても良いため、判定されたクレジットリソース残量は作業要求を行う仮想コンピュータリソースに固有であり得る。 As shown in 520, the current remaining resource credits for each compute instance of the virtual computer resource can be determined. The resource credit accumulation rate can be, in various embodiments, some resource credits that are added to the current remaining amount of resource credits that are unused during the period. For example, if the resource credit accumulation rate is set to 12 resource credits per hour, then all resource credits not consumed during that time may be added to the total remaining resource credits (eg, out of 12). If 9 is not used, 9 can be added). In some embodiments, the resource credit accumulation rate may match the baseline utilization or performance guarantee for the virtual compute instance. The higher the current resource credit balance, the longer the virtual compute instance can use virtual computer resources to sustain a higher level of performance. Since a plurality of different remaining credit resources may be applied to different virtual computer resources, the determined remaining credit resources may be unique to the virtual computer resource making the work request.
少なくともいくつかの実施形態では、リソースクレジット蓄積は特定の期間に限定され得る。したがって、リソースクレジット蓄積期間より前に蓄積された未使用のリソースクレジットは、現在のリソースクレジット残量に含むことはできない。例えば、いくつかの実施形態では、リソースクレジット蓄積時間は24時間であっても良く、所与の時点の前の24時間より以前に蓄積された任意の未使用のリソースクレジットを除外する。様々な実施形態では、現在のリソースクレジット残量に利用可能な少なくとも1つのリソースクレジットは、現在の期間の前の期間から繰り越される。 In at least some embodiments, resource credit accumulation may be limited to a particular time period. Therefore, unused resource credits accumulated before the resource credit accumulation period cannot be included in the current remaining resource credits. For example, in some embodiments, the resource credit accumulation time may be 24 hours, excluding any unused resource credits accumulated prior to the 24 hours prior to a given time point. In various embodiments, at least one resource credit available for the current resource credit balance is carried forward from the period preceding the current period.
530に示す通り、スケジューリング命令を生成して、1つ以上のリソースクレジットを適用することに少なくとも部分的に基づき、作業要求を行っても良い。したがって、スケジューリング命令は、いくつかの実施形態では、仮想コンピュータリソース(複数可)に対して、または仮想コンピュータリソース(複数可)としての作業要求を行う基礎を成
す物理的なコンピュータリソース(複数可)が活用される継続期間を指定しても良い。いくつかの実施形態では、生成されたスケジューリング命令は、物理的なコンピュータリソース(複数可)に対するタスクまたはハードウェアキューとして実施されても良い。いくつかの実施形態では、別のスケジューラまたは仮想コンピュータリソースドライバもしくはマネジャが命令を、入力、パラメータ及び/または他の情報として受信しても良く、同時に物理的なリソース(複数可)での作業要求の実行を命令する。以下に説明する図7は、リソースクレジットが作業要求を行うのに利用不可能な際に利用可能なリソースクレジットを適用するため、ならびにシナリオを処理するための様々な技法を記載する。540に示す通り、適用されたリソースクレジット(複数可)を差し引くために、現在のリソースクレジット残量が更新され得る。
As shown in 530, the work request may be made based at least in part on generating a scheduling instruction and applying one or more resource credits. Therefore, in some embodiments, a scheduling instruction is a physical computer resource (s) that underlies a work request to or as a virtual computer resource (s). You may specify the duration in which is used. In some embodiments, the generated scheduling instructions may be implemented as tasks or hardware queues for physical computer resources (s). In some embodiments, another scheduler or virtual computer resource driver or manager may receive instructions as inputs, parameters and / or other information, as well as work requests on physical resources (s). Command the execution of. FIG. 7, described below, describes various techniques for applying resource credits available when resource credits are not available to make work requests, as well as for handling scenarios. As shown in 540, the current remaining resource credits may be updated in order to deduct the applied resource credits (s).
図5に記載の様々な要素は、いくつかの実施形態では、異なる物理的なリソースに依存する異なる仮想コンピュータリソースに対して作業要求を行うために、複数回繰り返されても良いことに留意されたい。追加的に、要素の異なる並び替えが行われても良い。したがって、例示及び上記の説明は限定を意図するものではない。 It should be noted that the various elements described in FIG. 5 may be repeated multiple times in some embodiments to make work requests for different virtual computer resources that depend on different physical resources. sea bream. In addition, different sorts of elements may be performed. Therefore, the examples and the above description are not intended to be limiting.
図6はリソースを処理するために、図5に関して上記に記載した様々な技法を行うための一例を例示する。610に示す通り、仮想計算インスタンスの1つ以上の仮想中央処理装置(vCPU)に対する作業要求は、仮想計算インスタンスをホストする仮想化ホストのための仮想化マネジャで受信され得る。作業要求は仮想計算インスタンスの1つ以上のvCPUにより行われる特定のプロセス、タスクまたは他のアクションを対象としても良い。例えば、特定のプロセスは、仮想計算インスタンスにより行われるか、実行される特定のプログラムまたはアプリケーションを実施する、1つ以上の命令を実行することであっても良い。作業要求は、いくつかの実施形態では、使用される処理の負荷または処理量を示し得る。 FIG. 6 illustrates an example for performing the various techniques described above with respect to FIG. 5 to process a resource. As shown in 610, work requests to one or more virtual central processing units (vCPUs) of a virtual compute instance can be received by the virtualization manager for the virtualization host that hosts the virtual compute instance. The work request may target a particular process, task or other action performed by one or more vCPUs of the virtual compute instance. For example, a particular process may be to execute one or more instructions that implement a particular program or application performed or executed by a virtual compute instance. The work request may, in some embodiments, indicate the processing load or processing amount used.
620に示す通り、リソースクレジット蓄積率に従ってアイドル状態のvCPU期間に対してリソースクレジットを蓄積する計算インスタンスに対する現在のリソースクレジット残量が判定されても良い。上記の通り、リソースクレジット蓄積率は、様々な実施形態では、期間中にアイドル状態である仮想インスタンスに対して現在のリソースクレジット残量に追加されるいくつかのリソースクレジットであり得る。例えば、リソースクレジット蓄積率が1時間当たり12リソースクレジットに設定されると、その後、その時間中に消費されない全てのリソースクレジットが現在のリソースクレジット残量の合計に追加され得る(例えば、12のうち9が使用されていないと、9が追加され得る)。いくつかの実施形態では、リソースクレジット蓄積率は仮想計算インスタンスに対するベースライン活用または性能保証に一致し得る。例えば、仮想計算インスタンスに対するベースライン活用または性能保証が1時間の期間で10%の場合、仮想計算インスタンスは物理的なCPU(複数可)上で6分間の独占的な処理時間を有すると言えるだろう。これらの6分が全く使用されないか、またはこれらの6分の一部分のみが使用される場合、残りの分数が次の期間(例えば、次の1時間)に効果的に繰り越され得る。物理的なCPUが要求された作業を行う際にリソースクレジットを消費し得るため、現在のリソースクレジット残量が高いほど、仮想計算インスタンスがより高いレベルの性能を持続することができる時間がより長くなり得る。 As shown in 620, the current remaining amount of resource credits for the calculation instance that accumulates resource credits for the idle vCPU period may be determined according to the resource credit accumulation rate. As mentioned above, the resource credit accumulation rate can be, in various embodiments, some resource credits that are added to the current remaining resource credits for the virtual instance that is idle during the period. For example, if the resource credit accumulation rate is set to 12 resource credits per hour, then all resource credits not consumed during that time may be added to the total remaining resource credits (eg, out of 12). If 9 is not used, 9 can be added). In some embodiments, the resource credit accumulation rate may match the baseline utilization or performance guarantee for the virtual compute instance. For example, if the baseline utilization or performance guarantee for a virtual compute instance is 10% over an hour period, then the virtual compute instance can be said to have an exclusive processing time of 6 minutes on the physical CPU (s). Let's go. If these 6 minutes are not used at all, or only a portion of these 6 minutes are used, the remaining fractions can be effectively carried over to the next period (eg, the next hour). The higher the current resource credit balance, the longer the virtual compute instance can sustain a higher level of performance, as the physical CPU can consume resource credits when performing the required work. Can be.
630に示す通り、いくつかの実施形態では、スケジューリング命令を生成して、判定された現在のリソースクレジット残量に少なくとも部分的に基づき、作業要求を行っても良い。スケジューリング命令は、1つ以上の物理的な中央処理装置(CPU)に対するタスクまたは作業をスケジュールするスケジューラに送信される形式で生成され得る。これらのCPU(複数可)は、上記に説明の通り、仮想化ホストがそれ自体のvCPU(複数可)に命令する作業要求の実際の処理を行い得る。命令自体は現在の期間に対して物理的
なCPU(複数可)の活用を増加するために、リソースクレジット(利用可能な場合)を適用するように構成され得る。リソースクレジットは物理的なCPUが仮想計算ホストにより独占的に活用され得る作業量または時間を表し得る。したがって、命令は、スケジューラが適用されたリソースクレジットに等しいフル活用の時間を確実にスケジュールするように構成され得る。例えば、物理的なCPU(複数可)に対するスケジューラは、特定の仮想計算インスタンスに対する作業要求をどのように処理すべきかを命令する、異なるパラメータを受信するように構成され得る。これらのパラメータは、タイムスライス、優先度、比例分配、会計期間及び/または容量のサイジングを含み得るが、これに限定されない。少なくともいくつかの実施形態では、スケジューラは比例的で公平な分配スケジューラを提供するクレジットベースのスケジューラであっても良い。図7に関して以下に説明する通り、現在のリソースクレジット残量のリソースクレジットが作業要求の完了の前に使い果たされると(または作業要求の実行の開始時に無い場合)、生成された命令は、ベースライン性能要件(例えば、10%、20%または40%のCPU活用)に従って作業要求を実行するか、または作業要求の性能を徐々に低下させ、特定の期間の経過後にベースライン性能要件に等しくするように構成され得る。
As shown in 630, in some embodiments, scheduling instructions may be generated to make work requests, at least in part, based on the current remaining resource credits determined. Scheduling instructions can be generated in a format that is sent to a scheduler that schedules tasks or work for one or more physical central processing units (CPUs). These CPUs (s) can actually process the work request that the virtualization host commands its own vCPUs (s), as described above. The instructions themselves may be configured to apply resource credits (if available) to increase the utilization of the physical CPU (s) for the current period. Resource credits can represent the amount of work or time that a physical CPU can be exclusively utilized by a virtual computing host. Therefore, the instruction may be configured to ensure that the scheduler schedules full utilization time equal to the applied resource credits. For example, a scheduler for a physical CPU (s) may be configured to receive different parameters that dictate how work requests for a particular virtual computing instance should be processed. These parameters may include, but are not limited to, time slices, priorities, proportional distributions, accounting periods and / or volume sizing. In at least some embodiments, the scheduler may be a credit-based scheduler that provides a proportional and equitable distribution scheduler. As described below with respect to FIG. 7, if the current resource credit remaining amount of resource credits is exhausted before the work request is completed (or not at the beginning of the work request execution), the generated instruction is based. Perform work requirements according to line performance requirements (eg, 10%, 20% or 40% CPU utilization) or gradually reduce the performance of the work requirements to equalize the baseline performance requirements after a certain period of time. Can be configured as
640に示す通り、様々な実施形態では、スケジューリング命令は、その後、物理的なCPU(複数可)のためのスケジューラに送信され得る。スケジューリング命令の送信は、生成されたスケジューリング命令に従って作業要求の性能をスケジュールするために、様々なパラメータ及び/または他の情報を伝達しながら、スケジューラをプログラムでコール、呼び出し、または起動して、作業要求を行わせることを含み得る。550に示す通り、作業要求を行う際に適用されるリソースクレジットを差し引くために、現在のリソースクレジット残量が更新され得る。 As shown in 640, in various embodiments, scheduling instructions may then be sent to the scheduler for the physical CPU (s). The transmission of scheduling instructions works by programmatically calling, calling, or invoking the scheduler, transmitting various parameters and / or other information in order to schedule the performance of the work request according to the generated scheduling instructions. It may include making a request. As shown in 550, the current remaining resource credits may be updated to deduct the resource credits applied when making the work request.
図6に記載する様々な要素は、いくつかの実施形態では、作業要求の様々なサブ部分を行うために、複数回繰り返され得ることに留意されたい。追加的に、スケジューリング命令をスケジューラに送信する前にリソースクレジット残量を更新するなど、要素の異なる並び替えが行われても良い。したがって、例示及び上記の説明は限定を意図するものではない。 It should be noted that the various elements described in FIG. 6 may be repeated multiple times in some embodiments to perform different subparts of the work requirement. In addition, different sorting may be performed, such as updating the remaining resource credits before sending the scheduling instruction to the scheduler. Therefore, the examples and the above description are not intended to be limiting.
上記の通り、リソースクレジットは、特定の仮想計算インスタンスが1つ以上のCPUなどの物理的なリソースを活用し得る時間量を上昇し得る。反対に、リソースクレジットの不足は物理的なリソースの活用を低下させ得る。図6はいくつかの実施形態に係る、仮想計算インスタンスに対する作業要求に利用可能なリソースクレジットに従って、物理的なコンピュータリソースの活用を低下または上昇する様々な方法及び技法を例示する高レベルフロー図である。 As mentioned above, resource credits can increase the amount of time a particular virtual computing instance can utilize physical resources such as one or more CPUs. Conversely, lack of resource credits can reduce the use of physical resources. FIG. 6 is a high-level flow diagram illustrating various methods and techniques for reducing or increasing the utilization of physical computer resources according to the resource credits available for work requests for virtual computing instances, according to some embodiments. be.
610に示す通り、様々な実施形態では、作業要求を行うためのリソースクレジットを適用するために、仮想計算インスタンスに対する現在のリソースクレジット残量が確認され得る。620からの肯定的な出口により示される通り、適用するリソースクレジットがある場合、リソースクレジットが適用され、640に示す通り、仮想計算インスタンスに対する作業要求を行うための物理的なリソース(複数可)の活用が増加されても良い。リソースクレジットは、以前に述べた通り、作業要求を行うための物理的なリソースを活用する追加時間を提供し得る。例えば、仮想計算インスタンスに対するベースライン処理率が毎時6分(例えば、10%の活用)の場合、追加の1分と同等である追加のコンピューティングリソースクレジットを追加することは、vCPU(複数可)に向かって導かれる作業要求に対してプロセス活用率を毎時7分(例えば、11.667%の活用)に上昇させ得る。 As shown in 610, in various embodiments, the current remaining resource credits for the virtual compute instance may be checked in order to apply the resource credits for making the work request. If there are resource credits to apply, as indicated by the positive exit from 620, the resource credits are applied, and as shown in 640, of the physical resources (s) for making work requests to the virtual compute instance. Utilization may be increased. Resource credits can provide additional time to utilize physical resources to make work requests, as previously mentioned. For example, if the baseline processing rate for a virtual compute instance is 6 minutes per hour (eg, 10% utilization), adding additional compute resource credits equivalent to an additional 1 minute can be vCPUs (s). The process utilization rate can be increased to 7 minutes per hour (eg, 11.667% utilization) for the work demands guided towards.
しかしながら、620からの否定的な出口により示される通り、適用するリソースクレ
ジットが残っていない場合、作業要求を行うための物理的なリソースの活用は仮想計算インスタンスにおいて仮想リソースに対するベースライン活用率まで徐々に低下され得る。例えば、仮想計算インスタンスに対するvCPUの現在の活用(例えば、25%)が特定の期間(例えば、15分)にわたり拡散して徐々に低下し、次第に活用率を低下し得る。したがって、仮想計算インスタンスにおいてvCPUに対するベースライン活用率が10%の場合、15%の活用は15分の期間にわたる均一な(またはほぼ均一な)拡散率への個別変化に分かれ得る。活用を徐々に低下させることにより、リソースクレジットが不足している仮想計算インスタンス(及び仮想計算インスタンスとの任意のクライアントまたはシステム相互作用)が急激な性能低下に直面することを防ぎ得る。
However, as indicated by the negative exit from 620, if there are no resource credits left to apply, the utilization of physical resources to make work requests gradually reaches the baseline utilization rate for virtual resources in the virtual compute instance. Can be reduced to. For example, the current utilization of vCPUs for virtual compute instances (eg, 25%) may spread over a specific period of time (eg, 15 minutes) and gradually decline, with a gradual decline in utilization. Thus, if the baseline utilization rate for vCPUs is 10% in a virtual compute instance, the 15% utilization can be divided into individual changes to a uniform (or nearly uniform) diffusion rate over a 15 minute period. Gradually reducing utilization can prevent virtual compute instances (and any client or system interactions with virtual compute instances) that are deficient in resource credits from facing a sharp performance degradation.
特定のクライアントに対して独占的なリソースを提供する仮想計算インスタンスとは異なり、仮想コンピュータリソースをスケジュールするためのローリングリソースクレジットを実施する仮想インスタンスの動作または使用は、割り当てられたリソースの活用が、仮想計算インスタンスを購入または予約した特定のクライアントのニーズを十分に満たしているかどうかを判定するために分析する必要があり得る。クライアントまたは顧客は、クライアントまたは顧客がローリングリソースクレジットを提供する特定の種類の計算インスタンスを適切に選択したかどうかを判断することを望み得る。例えば、中位のリソースクレジット蓄積率を提供する仮想計算リソースを予約した顧客は、使用されたクレジット及び/またはクレジット残量の履歴を基に、より小さいまたはより大きい仮想計算インスタンスが適切であり得るかどうかを判断することができ得る。図8はいくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングクレジットリソースを実施する仮想計算インスタンスに対するデータ指標を記録及び活用する様々な方法及び技法を例示する高レベルフロー図である。 Unlike virtual compute instances, which provide exclusive resources to specific clients, the behavior or use of virtual instances that perform rolling resource credits for scheduling virtual computer resources is the utilization of allocated resources. It may need to be analyzed to determine if it fully meets the needs of a particular client who has purchased or reserved a virtual compute instance. The client or customer may wish to determine whether the client or customer has properly selected a particular type of compute instance that provides rolling resource credits. For example, a customer who has booked a virtual compute resource that provides a medium resource credit accumulation rate may find a smaller or larger virtual compute instance appropriate based on the history of credits used and / or credit balance. It can be determined whether or not. FIG. 8 is a high-level flow diagram illustrating various methods and techniques for recording and utilizing data indicators for virtual compute instances that implement rolling credit resources to schedule virtual computer resources, according to some embodiments. ..
810に示す通り、クレジット残量指標は仮想計算インスタンスに対して経時的な現在のリソースクレジット残量に対して記録され得る。現在のリソースクレジット残量は種々の精度レベルで記録され得る。例えば、いくつかの実施形態では、現在のリソースクレジット残量は変化が発生した際(例えば、残量の増加または減少)にのみ記録され得る。別の例では、変化が全く発生しなかったとしても、現在のリソースクレジット残量を記録する間の非常に短い経過期間である。いくつかの実施形態では、クライアント、管理者または他のユーザは、データが記録される時間間隔の精度を調整することができ得る。クレジット残量指標は、データベースなどの永続データストレージシステムに記憶され得る。データ指標は選択的に読出し可能となるよう、データベースに記憶され得る。例えば、データベースに指標を記憶することにより、特定のクエリは、データセット全体の指標を返すことなく、特定の範囲の情報、最小値、最大値または他のより専門的もしくは選択データセットを取得することが可能になり得る。 As shown in 810, the credit balance indicator can be recorded for the current resource credit balance over time for the virtual compute instance. The current resource credit balance can be recorded at various accuracy levels. For example, in some embodiments, the current resource credit remaining amount can only be recorded when a change occurs (eg, increasing or decreasing the remaining amount). In another example, there is a very short elapsed period between recording the current resource credit balance, even if no changes occur. In some embodiments, the client, administrator or other user may be able to adjust the accuracy of the time interval in which the data is recorded. The credit balance indicator can be stored in a persistent data storage system such as a database. The data index can be stored in the database so that it can be selectively read. For example, by storing metrics in a database, a particular query retrieves a particular range of information, minimums, maximums or other more specialized or selected datasets without returning metrics for the entire dataset. Can be possible.
820に示す通り、仮想計算インスタンスに対して経時的に作業要求を行うために、適用されたリソースクレジットに対するクレジット使用量指標が記録され得る。クレジット残量指標と同様に、クレジット使用量指標は異なる時間に記憶もしくは記録されるか、または異なるイベントに応えて記憶もしくは記録され得る。例えば、いくつかの実施形態では、使用値は作業要求を行うための特定のクレジットが適用される度に記録され得る。代替的には、全体の作業要求に適用されるクレジットの量(例えば、30)などの、総計使用量は単一のデータポイントとして表され得る。当然ながら、これらの2つの例の間にある様々な他の組み合わせまたは精度が実装されても良い(例えば、作業要求に対する合計費用である9クレジットのうちの4適用クレジットなど、特定の作業要求の一部を行うために使用される適用されたクレジットを記録する)。上記に説明したクレジット残量指標と同様に、クレジット使用量指標は、選択的に維持されるように記憶され得る。例えば、データベースに指標を記憶することにより、特定のクエリは、データセット全体の指標を返すことなく、特定の範囲の情報、最小値、最大値または他のより専門的もしくは選択デ
ータセットを取得することが可能になり得る。
As shown in 820, a credit usage index for the applied resource credits may be recorded in order to make work requests to the virtual compute instance over time. Like the credit balance metric, the credit usage metric can be stored or recorded at different times, or stored or recorded in response to different events. For example, in some embodiments, usage values may be recorded each time a particular credit is applied to make a work request. Alternatively, the total usage, such as the amount of credit applied to the entire work request (eg, 30), can be expressed as a single data point. Of course, various other combinations or precisions between these two examples may be implemented (eg, 4 applicable credits out of 9 credits, which is the total cost for the work request, for a particular work request. Record the applied credits used to do some). Similar to the credit balance metric described above, the credit usage metric can be stored to be selectively maintained. For example, by storing metrics in a database, a particular query retrieves a particular range of information, minimums, maximums or other more specialized or selected datasets without returning metrics for the entire dataset. Can be possible.
仮想計算インスタンスに対して記録された指標は様々な方法で使用され得る。指標のライブ報告またはストリーミングは、例えば、現在の仮想リソース情報を一瞥で提供するダッシュボードまたは他のユーザインターフェースに新規指標を記録する際に行われ得る。特に、いくつかの実施形態では、クレジット残量及びクレジット使用量に対する指標は、要求に応えてクライアントに提供され得る。例えば、830に示す通り、インターフェースを介して、仮想計算インスタンスのクレジット残量指標及び/またはクレジット使用量指標に対する要求が受信され得る。インターフェース212と同様に、インターフェースはネットワークベースのインターフェース(例えば、インターネットなどのネットワークを介してアクセス可能)であっても良く、様々なグラフィカルまたはプログラム式の通信方法を提供し得る。例えば、いくつかの実施形態では、ネットワークベースのインターフェースはアプリケーションプログラミングインターフェース(API)であっても良い。データに対する特定の要求は、返される特定のデータセットに対する様々な異なるパラメータまたは制約を含むAPIに従って形式化されても良い。同様に、ウェブサイトまたは他の表示可能なアプリケーションのためにホストまたは実装され得るようなグラフィカルインターフェースは、提供される特定の情報(図4に関して上記に説明したものなど)をユーザが選択することを可能にし得る。要求の受信に応えて、840に示す通り、要求された指標(使用量指標の一部か、使用量指標を全く含まないか、使用量指標の全ては、ネットワークベースのインターフェースを介して(例えば、APIまたは要求者の閲覧用に表示される図式もしくはテキストデータに従って形式化された応答を介して)は戻され得る。 The metrics recorded for the virtual compute instance can be used in a variety of ways. Live reporting or streaming of metrics can occur, for example, when recording new metrics on dashboards or other user interfaces that provide a glance of current virtual resource information. In particular, in some embodiments, indicators for credit balance and credit usage may be provided to the client on demand. For example, as shown in 830, a request for a credit balance indicator and / or a credit usage indicator for a virtual compute instance may be received via an interface. Similar to interface 212, the interface may be a network-based interface (eg, accessible via a network such as the Internet) and may provide a variety of graphical or programmatic communication methods. For example, in some embodiments, the network-based interface may be an application programming interface (API). A particular request for data may be formalized according to an API that contains various different parameters or constraints for the particular dataset returned. Similarly, a graphical interface that can be hosted or implemented for a website or other viewable application allows the user to select the particular information provided (such as that described above with respect to FIG. 4). It can be possible. In response to the request, as shown in 840, the requested metric (part of the usage metric, no usage metric at all, or all of the usage metric is via a network-based interface (eg,). , API or via a response formalized according to the diagram or textual data displayed for the requester's viewing) can be returned.
いくつかの実施形態では、様々な異なる動的ツール、モニタ、構成要素または他のデバイスを使用して指標データを分析しても良い。いくつかの実施形態では、仮想コンピューティングリソースプロバイダネットワークのクライアントは、トリガされ得るアラーム及び通知を定義し、修正し、または設定しても良い。850に示す通り、様々な実施形態では、仮想計算インスタンスに対するクレジット残量指標及びユーザ値指標が監視されても良い。例えば、特定の変化または急激な変化に対して現在の値(例えば、現在のリソースクレジット残量またはクレジット使用値)が評価されても良い。860に示す通り、例えば、リソースクレジット使用量が急増するか、または何らかの閾値を超える際、アラームがトリガされても良い。長期的な傾向及び他の種類の情報は、仮想計算インスタンスに対するクレジット残量及び/またはクレジット使用量指標を監視することから収集されても良い。860に示す通り、例えば、長期的な傾向が低いクレジット使用(または98%などの特定の時間パーセンテージに対して高い現在のリソースクレジット残量を有する)を示す場合、アラームがトリガされても良い。より一般的には、アラームは、様々な方法でクレジット残量指標及び/またはクレジット使用量指標を評価するように構成され得る。860からの否定的な出口に示す通り、アラームがトリガされない場合、クレジット残量指標及び/または使用量指標の監視が継続され得る。 In some embodiments, metric data may be analyzed using a variety of different dynamic tools, monitors, components or other devices. In some embodiments, clients in the virtual computing resource provider network may define, modify, or configure alarms and notifications that can be triggered. As shown in 850, in various embodiments, the credit remaining amount index and the user value index for the virtual calculation instance may be monitored. For example, the current value (eg, the current resource credit balance or credit usage value) may be evaluated for a particular change or abrupt change. As shown in 860, the alarm may be triggered, for example, when resource credit usage spikes or exceeds some threshold. Long-term trends and other types of information may be collected from monitoring credit balance and / or credit usage indicators for virtual compute instances. As shown in 860, an alarm may be triggered, for example, to indicate low credit usage (or have a high current resource credit balance for a particular time percentage, such as 98%), which tends to be long-term. More generally, alarms can be configured to evaluate credit balance indicators and / or credit usage indicators in a variety of ways. As shown in the negative exit from 860, monitoring of credit balance indicators and / or usage indicators may continue if the alarm is not triggered.
860からの肯定的な出口に示す通り、様々な実施形態では、アラームがトリガされると、870に示す通り、トリガされるアラームの通知が提供され得る。例えば、メッセージングシステム(例えば、音声、テキストまたは電子メール)を使用してアラームの所有者/作成者または責任者(仮想コンピューティングリソースプロバイダネットワークのクライアント/顧客であっても良い)にアラームをトリガしたインスタンスに対して通知しても良い。アラームの通知を提供することに加え、いくつかの実施形態では、自動またはプログラム式のアクションを行い、アラームを解消するか、アラームに反応しても良い。例えば、特定の仮想インスタンスに高いリソースクレジット活用が見られる場合、仮想インスタンスにより行われる作業の一部を別の仮想化ホスト上の別の仮想インスタンスにシフトして、特定の処理を行う仮想計算インスタンスの数を拡大しても良い。 As shown in the positive exit from 860, in various embodiments, when an alarm is triggered, notification of the triggered alarm may be provided, as shown in 870. For example, a messaging system (eg, voice, text, or email) was used to trigger an alarm to the owner / creator or responsible person (which may be a client / customer of a virtual computing resource provider network). You may notify the instance. In addition to providing alarm notifications, in some embodiments, automatic or programmed actions may be taken to clear or respond to the alarm. For example, if a particular virtual instance sees high resource credit utilization, a virtual compute instance that does some of the work done by the virtual instance by shifting it to another virtual instance on another virtualization host. You may increase the number of.
記録されたリソースクレジット残量指標及び/またはリソースクレジット使用量指標を個別の仮想コンピュータインスタンスベースでクライアントまたはその他に提供することに加え、ネットワークベースの仮想コンピューティングサービスプロバイダあるいは他の実装者、オペレータ、管理者または他の制御システムもしくはエージェントは、ネットワークベースの仮想コンピューティングリソースプロバイダの動作及び性能への全体的な洞察力を有するクレジット残量指標及び/またはリソースクレジット使用量指標の総括的な考察を見出し得る。 In addition to providing recorded resource credit remaining and / or resource credit usage metrics to clients or others on a separate virtual computer instance basis, network-based virtual computing service providers or other implementers, operators, The administrator or other control system or agent provides a comprehensive review of credit balance indicators and / or resource credit usage indicators that provide overall insight into the behavior and performance of network-based virtual computing resource providers. You can find out.
例えば、いくつかの実施形態では、システム管理者、制御システムまたは他の構成要素は、特定の仮想計算インスタンスを検出するために熱または競合管理を実施しても良く、特定の仮想計算インスタンスとは、過剰なトラフィックを受信しているため、クライアントに対するサービス保証を満たすことができていないか、特定のホスト(例えば、競合)上の仮想計算インスタンス間に過剰な対立アクティビティがあり得るかのいずれかである。図2のリソース監視モジュール218に関して上記に説明した通り、仮想化ホスト上の各仮想計算インスタンスに対する記録データは共に集計され得る。その後、集計された指標を基に、仮想化ホストに関する管理決定が行われ得る。例えば、仮想化ホスト上の異なる仮想計算インスタンスに対する使用量指標が類似する時間に出現してvCPU上の作業を要求する際、使用量指標はその仮想化ホスト上の仮想インスタンス間の何らかの競合レベルを示しても良い。競合レベルが何らかの最大競合閾値を超過する場合、1つ以上の仮想計算インスタンスが異なる仮想化ホスト上で移動または再開しても良く、コンピューティングリソースを開放し、残りの仮想計算インスタンスの作業要求をより優れた柔軟性で行い得る。 For example, in some embodiments, a system administrator, control system, or other component may perform thermal or conflict management to detect a particular virtual compute instance, which is a particular virtual compute instance. Either the service guarantee for the client cannot be met due to receiving excessive traffic, or there may be excessive conflict activity between virtual compute instances on a particular host (eg, conflict). Is. As described above for the resource monitoring module 218 of FIG. 2, the recorded data for each virtual computing instance on the virtualized host can be aggregated together. Then, management decisions regarding virtualized hosts can be made based on the aggregated indicators. For example, when usage indicators for different virtual computing instances on a virtualized host appear at similar times to request work on the vCPU, the usage indicators indicate some level of contention between the virtual instances on that virtualized host. May be shown. If the contention level exceeds some maximum contention threshold, one or more virtualized compute instances may move or resume on different virtualization hosts, freeing up computing resources and requesting the remaining virtual compute instances. It can be done with greater flexibility.
仮想計算インスタンス動作の報告に依存する(または単独で依存する)代わりに、いくつかの実施形態では、制御プレーン、システム管理者、健全性構成要素または他のシステムもしくはデバイスは、ベンチマークインスタンスを起動して、仮想化ホスト上の他の仮想計算インスタンスと一緒に実行され得る。これらのベンチマークインスタンスは、vCPUに対して作業量の特定のサイズまたは種類を要求するなど、係る要求が他の仮想計算インスタンスに対する作業要求の性能に及ぼし得る影響をテストするために、特定の種類のアクションを行うように構成され得る。ベンチマークインスタンスは、ベンチマークインスタンスのテスト結果を回収し、かつリソース監視モジュール218などの報告モジュールまたはサービスに直接報告するようにさらに構成され得る。前述の例は限定ではなく、ローリングクレジットリソースに対する回収された指標が使用され得る多くの異なる方法の一部を意図することに留意されたい。 Instead of relying on reporting virtual computing instance behavior (or on its own), in some embodiments, the control plane, system administrator, health component or other system or device launches a benchmark instance. Can be run with other virtual compute instances on the virtualization host. These benchmark instances are of a particular type to test the potential impact of such a request on the performance of the work request for other virtual compute instances, such as requiring a particular size or type of workload from the vCPU. It can be configured to take action. The benchmark instance may be further configured to retrieve the test results of the benchmark instance and report directly to a reporting module or service such as the resource monitoring module 218. It should be noted that the above example is not limited and is intended to be part of many different ways in which the recovered indicators for rolling credit resources can be used.
本開示の実施形態は、以下の条項を考慮して説明することができる。
1.少なくとも1つのそれぞれのプロセッサ及びメモリを備え、仮想化ホストを実装する計算ノードと、
1つ以上の中央処理装置(vCPU)に対する作業要求を仮想計算インスタンスから受信することと、
それぞれの期間に対する固定率に少なくとも部分的に基づき、リソースクレジット蓄積率が現在のリソースクレジット残量に適用され、前記現在のリソースクレジット残量の少なくとも1つのリソースクレジットが現在の期間の前の期間に対する前記現在のリソースクレジット残量に蓄積される、前記vCPUそれぞれの前記仮想計算インスタンスに対する前記現在のリソースクレジット残量を計算することと、
1つ以上のスケジューリング命令は前記仮想計算インスタンスに対する前記現在のリソースクレジット残量の1つ以上のリソースクレジットの適用に少なくとも部分的に基づき生成され、前記作業要求に適用された前記1つ以上のリソースクレジットのそれぞれを、前記現在の期間に対して前記それぞれの少なくとも1つのプロセッサの活用を相応して増
加させる、前記計算ノードの前記それぞれの少なくとも1つのプロセッサを活用して性能に対する前記作業要求をスケジュールするために、前記1つ以上のスケジューリング命令を生成することと、
前記作業要求を行うために適用された前記1つ以上のリソースクレジットを差し引くために、前記現在のリソースクレジット残量を更新することと
を行うように構成される実行可能命令を備える前記仮想化ホストと
を備えるシステム。
The embodiments of the present disclosure can be described with the following provisions in mind.
1. 1. A compute node that has at least one processor and memory and implements a virtualized host.
Receiving work requests for one or more central processing units (vCPUs) from a virtual compute instance
The resource credit accumulation rate is applied to the current remaining resource credits, at least in part based on the fixed rate for each period, and at least one of the current remaining resource credits is relative to the period prior to the current period. To calculate the current remaining amount of resource credits for the virtual calculation instance of each of the vCPUs accumulated in the current remaining amount of resource credits.
The one or more scheduling instructions are generated at least in part based on the application of one or more resource credits of the current resource credit remaining amount to the virtual compute instance, and the one or more resources applied to the work request. Each of the credits schedules the work request for performance by leveraging each of the at least one processor of the compute node, correspondingly increasing the utilization of each of the at least one processor for the current period. To generate one or more of the scheduling instructions,
The virtualization host with an executable instruction configured to update the current remaining resource credits to deduct the one or more resource credits applied to make the work request. A system with and.
2.前記1つ以上のスケジューリング命令の生成において、前記仮想化ホストはさらに、
前記1つ以上のリソースクレジットを前記作業要求に適用した後で、
前記現在のリソースクレジット残量に前記作業要求に適用するための残りのリソースクレジットが無いという判定に応えて、前記それぞれの少なくとも1つのプロセッサが前記仮想計算インスタンスに対するベースライン活用まで徐々に低下されるよう、前記1つ以上のスケジューリング命令の少なくとも一部を構成する
ように構成される、条項1に記載のシステム。
2. In generating the one or more scheduling instructions, the virtualization host further
After applying the one or more resource credits to the work request,
In response to the determination that the current remaining resource credits do not have any remaining resource credits to apply to the work request, at least one of the respective processors is gradually reduced to baseline utilization for the virtual compute instance. The system according to Clause 1, which is configured to constitute at least a portion of the one or more scheduling instructions.
3.前記仮想化ホストは、経時的な前記仮想計算インスタンスに対する前記現在のリソースクレジット残量及び経時的な前記仮想計算インスタンスに対する作業要求のために適用されたリソースクレジットを追跡するように構成される監視エージェントを備え、
前記計算ノードが共にネットワークベースの仮想コンピューティングサービスを実施する複数の計算ノードの一部として実装され、前記ネットワークベースの仮想コンピューティングサービスは前記ネットワークベースの仮想コンピューティングサービスのクライアントに経時的な前記仮想計算インスタンスに対する前記現在のリソースクレジット残量及び経時的な前記仮想計算インスタンスに対する作業要求のために適用されたリソースクレジットを提供するように構成されるネットワークベースのインターフェースを備える、
条項1に記載のシステム。
3. 3. The virtualization host is a monitoring agent configured to track the current resource credit balance for the virtual compute instance over time and the resource credits applied for work requests for the virtual compute instance over time. With
The compute nodes are implemented as part of a plurality of compute nodes that together implement a network-based virtual computing service, and the network-based virtual computing service is a client of the network-based virtual computing service over time. It comprises a network-based interface configured to provide the current resource credit balance for the virtual compute instance and the resource credits applied for the work request for the virtual compute instance over time.
The system described in Clause 1.
4.前記仮想計算インスタンスは、前記ネットワークベースの仮想コンピューティングサービスを介して供給される複数の異なる種類の仮想計算インスタンスのうちの1つであり、前記異なる種類の仮想計算インスタンスのそれぞれが異なるそれぞれのリソースクレジット蓄積率に対応する、条項3に記載のシステム。 4. The virtual computing instance is one of a plurality of different types of virtual computing instances supplied through the network-based virtual computing service, and each of the different types of virtual computing instances has a different resource. The system described in Clause 3 that corresponds to the credit accumulation rate.
5.1つ以上のコンピューティングデバイスにより、
仮想化ホストに対する仮想化マネジャで、前記仮想化ホスト上でホストされる仮想計算インスタンスの1つ以上のコンピュータリソースに対する作業要求を受信することと、
それぞれの期間に対する固定率に少なくとも部分的に基づき、リソースクレジット蓄積率が現在のリソースクレジット残量に適用され、前記現在のリソースクレジット残量の少なくとも1つのリソースクレジットが現在の期間の前の期間に対する前記現在のリソースクレジット残量に蓄積される、前記1つ以上のコンピュータリソースそれぞれの前記仮想計算インスタンスに対する前記現在のリソースクレジット残量を判定することと、
1つ以上のスケジューリング命令は前記仮想計算インスタンスに対する前記現在のリソースクレジット残量の1つ以上のリソースクレジットの適用に少なくとも部分的に基づき生成され、前記作業要求に適用された前記1つ以上のリソースクレジットのそれぞれは、前記現在の期間に対して前記少なくとも1つの物理的なコンピュータリソースの活用を相応して増加させる、前記仮想化ホストの一部として実装される1つ以上の物理的なコンピュータリソースにおける性能に対する前記作業要求をスケジュールするために、前記1つ以上のスケジューリング命令を生成することと、
前記作業要求を行うために適用された前記1つ以上のリソースクレジットを差し引くために、前記仮想計算インスタンスに対する前記現在のリソースクレジット残量を更新する
ことと
を行う方法。
5. With one or more computing devices
Receiving work requests for one or more computer resources of virtualized compute instances hosted on the virtualized host in the virtualization manager for the virtualized host.
The resource credit accumulation rate is applied to the current remaining resource credits, at least in part based on the fixed rate for each period, and at least one of the current remaining resource credits is relative to the period prior to the current period. Determining the current remaining resource credits for the virtual compute instance of each of the one or more computer resources accumulated in the current remaining resource credits.
The one or more scheduling instructions are generated at least partially based on the application of one or more resource credits of the current resource credit remaining amount to the virtualized computing instance, and the one or more resources applied to the work request. Each of the credits is one or more physical computer resources implemented as part of the virtualization host that correspondingly increases the utilization of the at least one physical computer resource for the current period. To generate the one or more scheduling instructions to schedule the work request for performance in
A method of updating the current remaining resource credits for the virtual compute instance in order to deduct the one or more resource credits applied to make the work request.
6.前記受信、前記判定、前記生成及び前記更新は複数の異なる作業要求に対して行われ、
前記複数の異なる作業要求のそれぞれに対して前記判定された現在のリソースクレジット残量をクレジット残量指標として記録することと、
前記複数の異なる作業要求のそれぞれに対して前記適用された1つ以上のリソースクレジットをクレジット使用量指標として記録することと
をさらに備える、条項5に記載の方法。
6. The reception, the determination, the generation and the update are made for a plurality of different work requests.
Recording the current resource credit remaining amount determined for each of the plurality of different work requests as a credit remaining amount index, and
The method of Clause 5, further comprising recording one or more of the applied resource credits as a credit usage index for each of the plurality of different work requests.
7.ネットワークベースのインターフェースを介して、前記仮想計算インスタンスに対する前記クレジット残量指標の少なくとも一部に対する要求を受信することと、
前記要求の受信に応えて、前記ネットワークベースのインターフェースを介して、前記仮想計算インスタンスに対する前記クレジット残量指標の少なくとも一部を提供することと
をさらに備える、条項6に記載の方法。
7. Receiving a request for at least a portion of the credit balance metric for the virtual compute instance through a network-based interface.
The method of Clause 6, further comprising providing at least a portion of the credit balance index for the virtual compute instance via the network-based interface in response to receiving the request.
8.ネットワークベースのインターフェースを介して、前記仮想計算インスタンスに対する前記クレジット使用量指標の少なくとも一部に対する要求を受信することと、
前記要求の受信に応えて、前記ネットワークベースのインターフェースを介して、前記仮想計算インスタンスに対する前記クレジット使用量指標の少なくとも一部を提供することと
をさらに備える、条項6に記載の方法。
8. Receiving a request for at least a portion of the credit usage metric for the virtual compute instance through a network-based interface.
The method of Clause 6, further comprising providing at least a portion of the credit usage metric for the virtual compute instance via the network-based interface in response to receiving the request.
9.前記仮想計算インスタンスに対する前記クレジット残量指標または前記クレジット使用量指標を監視することと、
前記監視に少なくとも部分的に基づき、前記仮想計算インスタンスに対するアラームイベントを検出することと、
前記アラームイベントの検出に応えて、前記仮想計算インスタンスに対する前記アラームイベントの通知を提供することと
をさらに備える、条項6に記載の方法。
9. To monitor the credit remaining amount index or the credit usage index for the virtual calculation instance.
Detecting alarm events for the virtual compute instance, at least in part, based on the monitoring.
The method of Clause 6, further comprising providing notification of the alarm event to the virtual compute instance in response to detection of the alarm event.
10.前記スケジューラに送信するための前記1つ以上のスケジューリング命令の前記生成は、
前記1つ以上のリソースクレジットを前記作業要求に適用した後で、
前記現在のリソースクレジット残量に前記作業要求に適用するための残りのリソースクレジットが無いことを判定することと、
残りのリソースクレジットが無いという判定に応えて、前記1つ以上の物理的なコンピューティングリソースの活用が前記仮想計算インスタンスに対するベースライン活用まで徐々に低下されるよう、前記1つ以上の生成されたスケジューリング命令の少なくとも1つを構成することと
を備える、条項5に記載の方法。
10. The generation of the one or more scheduling instructions for transmission to the scheduler
After applying the one or more resource credits to the work request,
Determining that the current remaining resource credits do not have any remaining resource credits to apply to the work request.
The one or more generated so that the utilization of the one or more physical computing resources is gradually reduced to the baseline utilization for the virtual compute instance in response to the determination that there are no remaining resource credits. The method of clause 5, comprising configuring at least one of the scheduling instructions.
11.前記1つ以上のコンピュータリソースが1つ以上の仮想中央処理装置(vCPU)であり、前記1つ以上の物理的なコンピュータリソースが1つ以上の中央処理装置(CPU)であり、前記方法が前記1つ以上のスケジューリング命令を前記1つ以上の物理的なCPUに対するスケジューラに送信することをさらに備える、条項5に記載の方法。 11. The one or more computer resources are one or more virtual central processing units (vCPUs), and the one or more physical computer resources are one or more central processing units (CPUs). The method of clause 5, further comprising transmitting one or more scheduling instructions to the scheduler for the one or more physical CPUs.
12.前記1つの仮想計算インスタンスに対する前記現在のリソースクレジット残量の
前記判定は、リソースクレジット蓄積期間の前に蓄積された未使用のリソースクレジットを前記現在のリソースクレジット残量から除外することを備える、条項5に記載の方法。
12. The determination of the current resource credit remaining amount for the one virtual compute instance comprises excluding unused resource credits accumulated before the resource credit accumulation period from the current resource credit remaining amount. The method according to 5.
13.前記1つ以上のコンピュータリソースは複数の異なるコンピュータリソースの一部であり、異なるそれぞれの現在のリソースクレジット残量は前記複数の異なるコンピュータリソースのうちの異なるコンピュータリソースに対して維持され、別の作業要求は前記複数の異なるコンピュータリソースのうちの別のコンピュータリソースに対して受信され、前記判定、前記生成及び前記更新は前記他の作業要求に対して行われる、条項5に記載の方法。 13. The one or more computer resources are part of a plurality of different computer resources, and each different current resource credit balance is maintained for a different computer resource of the different computer resources and another task. 5. The method of clause 5, wherein the request is received for another computer resource among the plurality of different computer resources, and the determination, generation, and update are made for the other work request.
14.1つ以上のコンピューティングデバイスにより実行されると、前記1つ以上のコンピューティングデバイスに、
仮想化ホストに対する仮想化マネジャで、前記仮想化ホスト上でホストされる仮想計算インスタンスの1つ以上のコンピュータリソースに対する作業要求を受信することと、
それぞれの期間に対する固定率に少なくとも部分的に基づき、リソースクレジット蓄積率が現在のリソースクレジット残量に適用され、前記現在のリソースクレジット残量の少なくとも1つのリソースクレジットが現在の期間の前の期間に対する前記現在のリソースクレジット残量に蓄積される、前記1つ以上の仮想コンピュータリソースそれぞれの前記仮想計算インスタンスに対する前記現在のリソースクレジット残量を判定することと、
1つ以上のスケジューリング命令は前記仮想計算インスタンスに対する前記現在のリソースクレジット残量の1つ以上のリソースクレジットの適用に少なくとも部分的に基づき生成され、前記作業要求に適用された前記1つ以上のリソースクレジットのそれぞれは、前記現在の期間に対して前記1つ以上の物理的なコンピュータリソースの活用を相応して増加させる、前記仮想化ホストの一部として実装される1つ以上の物理的なコンピュータリソースにおける性能に対する前記作業要求をスケジュールするために、前記1つ以上のスケジューリング命令を生成することと、
前記作業要求を行うために適用された前記1つ以上のリソースクレジットを差し引くために、前記1つの仮想計算インスタンスに対する前記現在のリソースクレジット残量を更新することと
を実施させるプログラム命令を記憶する、非一時的コンピュータ可読記憶媒体。
14. When executed by one or more computing devices, the one or more computing devices
Receiving work requests for one or more computer resources of virtualized compute instances hosted on the virtualized host in the virtualization manager for the virtualized host.
The resource credit accumulation rate is applied to the current remaining resource credits, at least in part based on the fixed rate for each period, and at least one of the current remaining resource credits is relative to the period prior to the current period. Determining the current remaining resource credits for the virtual compute instance of each of the one or more virtual computer resources accumulated in the current remaining resource credits.
The one or more scheduling instructions are generated at least partially based on the application of one or more resource credits of the current resource credit remaining amount to the virtualized computing instance, and the one or more resources applied to the work request. Each of the credits is one or more physical computers implemented as part of the virtualization host that correspondingly increases the utilization of the one or more physical computer resources for the current period. To generate the one or more scheduling instructions to schedule the work request for performance in the resource.
Stores a program instruction to update the current remaining resource credits for the one virtual compute instance in order to deduct the one or more resource credits applied to make the work request. Non-temporary computer-readable storage medium.
15.前記プログラム命令が、前記1つ以上のコンピューティングデバイスにさらに、
前記受信、前記判定、前記生成、前記送信及び前記更新は複数の異なる作業要求に対して行われ、
前記複数の異なる作業要求のそれぞれに対して前記判定された現在のリソースクレジット残量をクレジット残量指標として記録することと、
前記複数の異なる作業要求のそれぞれに対して前記適用された1つ以上のリソースクレジットをクレジット使用量指標として記録することと
を実施させる、条項14に記載の非一時的コンピュータ可読記憶媒体。
15. The program instructions further extend to the one or more computing devices.
The reception, the determination, the generation, the transmission and the update are performed for a plurality of different work requests.
Recording the current resource credit remaining amount determined for each of the plurality of different work requests as a credit remaining amount index, and
The non-temporary computer-readable storage medium according to
16.前記プログラム命令が、前記1つ以上のコンピューティングデバイスにさらに、前記仮想計算インスタンスに対する前記クレジット残量指標または前記クレジット使用量指標を監視することと、
前記監視に少なくとも部分的に基づき、前記仮想計算インスタンスに対するアラームイベントを検出することと、
前記アラームイベントの検出に応えて、前記仮想計算インスタンスに対する前記アラームイベントの通知を提供することと
を実施させる、条項15に記載の非一時的コンピュータ可読記憶媒体。
16. The program instruction further monitors the one or more computing devices for the credit remaining amount index or the credit usage index for the virtual computing instance.
Detecting alarm events for the virtual compute instance, at least in part, based on the monitoring.
The non-temporary computer-readable storage medium according to
17.前記1つ以上の計算リソースが1つ以上のネットワーキングリソースであり、前
記1つ以上の物理的なコンピュータリソースが1つ以上のネットワーク通信デバイスである、条項14に記載の非一時的コンピュータ可読記憶媒体。
17. The non-temporary computer-readable storage medium according to
18.前記スケジューラに送信するための前記1つ以上のスケジューリング命令の前記生成において、前記プログラム命令は前記1つ以上のコンピューティングデバイスに、
前記1つ以上のリソースクレジットを前記作業要求に適用した後で、
前記現在のリソースクレジット残量に前記作業要求に適用するための残りのリソースクレジットが無いことを判定することと、
残りのリソースクレジットが無いという判定に応えて、前記1つ以上の物理的なコンピュータリソースの活用が前記仮想計算インスタンスに対するベースライン活用まで徐々に低下されるよう、前記1つ以上の生成されたスケジューリング命令の少なくとも1つを構成することと
を実施させる、条項14に記載の非一時的コンピュータ可読記憶媒体。
18. In the generation of the one or more scheduling instructions to be transmitted to the scheduler, the program instructions are sent to the one or more computing devices.
After applying the one or more resource credits to the work request,
Determining that the current remaining resource credits do not have any remaining resource credits to apply to the work request.
The one or more generated schedulings so that the utilization of the one or more physical computer resources is gradually reduced to the baseline utilization for the virtual compute instance in response to the determination that there are no remaining resource credits. The non-temporary computer-readable storage medium according to
19.前記仮想計算インスタンスに対する前記現在のリソースクレジット残量の前記判定において、前記プログラム命令が、前記1つ以上のコンピューティングデバイスに、リソースクレジット蓄積期間の前に蓄積された未使用のリソースクレジットを前記現在のリソースクレジット残量から除外することを実施させる、条項14に記載の非一時的コンピュータ可読記憶媒体。
19. In the determination of the current resource credit remaining amount for the virtual computing instance, the program instruction causes the unused resource credits accumulated before the resource credit accumulation period in the one or more computing devices to the present. A non-temporary computer-readable storage medium as described in
20.前記仮想化ホストはネットワークベースの仮想コンピューティングサービスの一部として実装され、前記仮想計算インスタンスは、前記ネットワークベースの仮想コンピューティングサービスを介して供給される複数の異なる種類の仮想計算インスタンスのうちの1つであり、前記異なる種類の仮想計算インスタンスのそれぞれが異なるそれぞれのリソースクレジット蓄積率に対応する、条項14に記載の非一時的コンピュータ可読記憶媒体。
20. The virtualization host is implemented as part of a network-based virtual computing service, and the virtual computing instance is of a number of different types of virtual computing instances served through the network-based virtual computing service. The non-temporary computer-readable storage medium according to
本明細書に記載の方法は、様々な実施形態では、ハードウェア及びソフトウェアの任意の組み合わせにより実装され得る。例えば、一実施形態では、方法はプロセッサに連結されるコンピュータ可読記憶媒体に記憶されるプログラム命令を実行する1つ以上のプロセッサを含むコンピュータシステム(例えば、図9のコンピュータシステム)により実施され得る。プログラム命令は本明細書に記載する機能性(例えば、本明細書に記載のネットワークベースの仮想コンピューティングリソースプロバイダを実装する様々なサーバ及び他の構成要素の機能性)を実施するように構成され得る。図面に例示し本明細書に記載した様々な方法は、方法の実施形態例を表す。任意の方法の順序は変更されて良く、様々な要素が追加、再順序付け、結合、省略、修正等、されて良い。 The methods described herein can be implemented in various embodiments by any combination of hardware and software. For example, in one embodiment, the method may be implemented by a computer system (eg, the computer system of FIG. 9) that includes one or more processors that execute program instructions stored in a computer-readable storage medium coupled to the processor. Program instructions are configured to perform the functionality described herein (eg, the functionality of various servers and other components that implement the network-based virtual computing resource providers described herein). obtain. The various methods illustrated in the drawings and described herein represent examples of embodiments of the method. The order of any method may be changed and various elements may be added, reordered, combined, omitted, modified, etc.
本明細書に記載の仮想コンピュータリソースをスケジュールするためのローリングクレジットリソースの実施形態は1つ以上のコンピュータシステム上で実行されても良く、コンピュータシステムは様々な他のデバイスと相互作用しても良い。図9は、様々な実施形態に係る、コンピュータシステムの一例を例示するブロック図である。例えば、コンピュータシステム1000は、異なる実施形態では、計算クラスタ、分散キーバリューデータストア、及び/またはクライアントのノードを実装するように構成され得る。コンピュータシステム1000は、パーソナルコンピュータシステム、デスクトップコンピュータ、ラップトップコンピュータもしくはノートブックコンピュータ、メインフレームコンピュータシステム、ハンドヘルドコンピュータ、ワークステーション、ネットワークコンピュータ、コンシューマデバイス、アプリケーションサーバ、ストレージデバイス、電話、携帯電話、または一般的な任意の種類のコンピューティングデバイスを含む様々な種類のデバイスのいずれでもあって良いが、これらに限定されない。 The rolling credit resource embodiment for scheduling virtual computer resources described herein may be performed on one or more computer systems, which may interact with various other devices. .. FIG. 9 is a block diagram illustrating an example of a computer system according to various embodiments. For example, computer system 1000 may be configured to implement compute clusters, distributed key-value data stores, and / or client nodes in different embodiments. The computer system 1000 includes personal computer systems, desktop computers, laptop or notebook computers, mainframe computer systems, handheld computers, workstations, network computers, consumer devices, application servers, storage devices, telephones, mobile phones, or the general public. It can be, but is not limited to, any type of device, including any type of computer device.
コンピュータシステム1000は、入出力(I/O)インターフェース1030を介してシステムメモリ1020に連結された1つ以上のプロセッサ1010を含む(これらのプロセッサはいずれも複数のコアを含んで良く、それらのコアはシングルスレッド方式でもマルチスレッド方式でも良い)。コンピュータシステム1000は、I/Oインターフェース1030に連結されたネットワークインターフェース1040をさらに含む。様々な実施形態では、コンピュータシステム1000は、1つのプロセッサ1010を含むユニプロセッサシステム、またはいくつかのプロセッサ1010(例えば、2個、4個、8個もしくは他の好適な数)を含むマルチプロセッサシステムであって良い。プロセッサ1010は、命令を実行可能な任意の好適なプロセッサであって良い。例えば、様々な実施形態では、プロセッサ1010は、x86、PowerPC、SPARCもしくはMIPSのISAまたはその他の好適なISAなどの種々の命令セットアーキテクチャ(ISA)のいずれかを実装する汎用プロセッサまたは組み込みプロセッサであって良い。マルチプロセッサシステムでは、プロセッサ1010のそれぞれは、通常は同じISAを実装し得るが、必ずしもそのように実装されるとは限らない。コンピュータシステム1000は、1つ以上のネットワーク通信デバイス(例えば、ネットワークインターフェース1040)をさらに含み、通信ネットワーク(例えば、インターネット、LAN等)を介して他のシステム及び/または構成要素と通信する。例えば、システム1000上で実行されるクライアントアプリケーションは、ネットワークインターフェース1040を使用して、本明細書に記載したデータウェアハウスシステムの構成要素の1つ以上を実装する単一のサーバまたはサーバのクラスタ上で実行するサーバアプリケーションと通信しても良い。別の例では、コンピュータシステム1000上で実行するサーバアプリケーションのインスタンスは、ネットワークインターフェース1040を使用して、他のコンピュータシステム(例えば、コンピュータシステム1090)上に実装され得るサーバアプリケーション(または別のサーバアプリケーション)の他のインスタンスと通信しても良い。
The computer system 1000 includes one or more processors 1010 connected to the system memory 1020 via an input / output (I / O) interface 1030 (all of these processors may include a plurality of cores, and the cores thereof). Can be single-threaded or multi-threaded). The computer system 1000 further includes a network interface 1040 coupled to an I /
例示した実施形態では、コンピュータシステム1000は、1つ以上の永続ストレージデバイス1060及び/または1つ以上のI/Oデバイス1080をさらに含む。様々な実施形態では、永続ストレージデバイス1060は、ディスクドライブ、テープドライブ、ソリッドステートメモリ、他の大容量ストレージデバイス、またはその他の永続ストレージデバイスに対応し得る。コンピュータシステム1000(または分散アプリケーションもしくはそのシステム上で動作するオペレーティングシステム)は、所望により、命令及び/またはデータを永続ストレージデバイス1060に記憶しても良く、記憶された命令及び/またはデータを必要に応じて検索しても良い。例えば、いくつかの実施形態では、コンピュータシステム1000は、ストレージシステムサーバノードをホストしても良く、永続ストレージ1060は、そのサーバノードに取り付けられたSSDを含んでも良い。
In the illustrated embodiment, the computer system 1000 further comprises one or more
コンピュータシステム1000は、1つ以上のシステムメモリ1020を含み、これらのメモリは、プロセッサ1010(複数可)によりアクセス可能な命令及びデータを記憶するように構成される。様々な実施形態では、システムメモリ1020は、任意の好適なメモリ技術(例えば、1つ以上のキャッシュ、スタティックランダムアクセスメモリ(SRAM)、DRAM、RDRAM、EDO RAM、DDR 10 RAM、同期式ダイナミックRAM(SDRAM)、Rambus RAM、EEPROM、不揮発性/フラッシュ型メモリ、またはその他任意の種類のメモリ)を使用して実装され得る。システムメモリ1020は、本明細書に記載された方法及び技法を実装するために、プロセッサ1010(複数可)により実行可能なプログラム命令1025を含み得る。様々な実施形態では、プログラム命令1025は、プラットフォームのネイティブバイナリ、Java(登録商標)バイトコードなどの任意のインタープリタ型言語、もしくはC/C++、Java(登録商標)等などの任意の他の言語、またはそれらの任意の組み合わせにコード化され得る。例えば、例示した実施形態では、プログラム命令1025は、異なる実施形態
では、仮想コンピューティングリソースプロバイダネットワークの機能性を実装するために実行可能なプログラム命令を含む。いくつかの実施形態では、プログラム命令1025は、複数の個別のクライアント、サーバノード及び/または他の構成要素を実装しても良い。
The computer system 1000 includes one or more system memories 1020, which are configured to store instructions and data accessible by the processor 1010 (s). In various embodiments, the system memory 1020 comprises any suitable memory technology (eg, one or more caches, static random access memory (SRAM), DRAM, RDRAM, EDO RAM,
いくつかの実施形態では、プログラム命令1025は、オペレーティングシステム(図示せず)を実装するために実行可能な命令を含んでも良く、このオペレーティングシステムは、UNIX(登録商標)、LINUX、Solaris(登録商標)、MacOS(登録商標)、Windows(登録商標)等などの様々なオペレーティングシステムのいずれでも良い。プログラム命令1025のいずれかまたは全ては、コンピュータプログラム製品またはソフトウェアとして提供され得る。このコンピュータプログラム製品またはソフトウェアは、命令が記憶された非一時的コンピュータ可読記憶媒体を含んでも良く、この媒体を使用してコンピュータシステム(または他の電子装置)をプログラムすることにより、様々な実施形態に応じたプロセスを実行しても良い。非一時的コンピュータ可読記憶媒体は、マシン(例えば、コンピュータ)により読み取り可能な形態(例えば、ソフトウェア、処理アプリケーション)で情報を記憶するための任意の機構を含んでも良い。一般的に言えば、非一時的コンピュータアクセス可能媒体は、コンピュータ可読記憶媒体またはメモリ媒体を含み得る。このような媒体としては、磁気媒体または光学媒体、例えば、I/Oインターフェース1030を介してコンピュータシステム1000に連結されたディスクまたはDVD/CD−ROMなどがある。非一時的コンピュータ可読記憶媒体は、RAM(例えば、SDRAM、DDR SDRAM、RDRAM、SRAM等)、ROM等などの任意の揮発性または不揮発性媒体も含み得る。これらの媒体は、コンピュータシステム1000のいくつかの実施形態では、システムメモリ1020または別の種類のメモリとして含まれ得る。他の実施形態では、プログラム命令は、ネットワークインターフェース1040を介して実装され得るようなネットワーク及び/または無線リンクなどの通信媒体を介して伝わる光学的、音響的または他の形態の伝搬信号(例えば、搬送波、赤外線信号、デジタル信号等)を使用して伝送され得る。
In some embodiments,
いくつかの実施形態では、システムメモリ1020は、データストア1045を含んでも良く、このデータストアは、本明細書に記載されたように構成され得る。概して、システムメモリ1020(例えば、システムメモリ1020内のデータストア1045)、永続ストレージ1060及び/またはリモートストレージ1070は、データブロック、データブロックのレプリカ、データブロック及び/もしくはそれらの状態に関連付けられたメタデータ、構成情報、ならびに/または本明細書に記載された方法及び技法を実装するのに使用可能な他の任意の情報を記憶し得る。
In some embodiments, the system memory 1020 may include a data store 1045, which data store may be configured as described herein. In general, system memory 1020 (eg, data store 1045 in system memory 1020),
一実施形態では、I/Oインターフェース1030は、ネットワークインターフェース1040または他の周辺インターフェースを通るものを含む、プロセッサ1010、システムメモリ1020及びシステム内の任意の周辺デバイスの間のI/Oトラフィックを調整するように構成され得る。いくつかの実施形態では、I/Oインターフェース1030は、任意の必要なプロトコル変換、タイミング変換または他のデータ変換を実行し、ある構成要素(例えば、システムメモリ1020)からのデータ信号を別の構成要素(例えば、プロセッサ1010)による使用に好適な形式に変換し得る。いくつかの実施形態では、I/Oインターフェース1030は、例えば、ペリフェラル・コンポーネント・インターコネクト(PCI)バス規格またはユニバーサル・シリアル・バス(USB)規格の変型などの様々な種類の周辺バスを通じて取り付けられたデバイスのサポートも含み得る。いくつかの実施形態では、I/Oインターフェース1030の機能は、例えば、ノースブリッジ及びサウスブリッジなどの、2つ以上の別々の構成要素に分割され得る。さらに、いくつかの実施形態では、システムメモリ1020とのインターフェースなどの、I/Oインターフェース1030の機能性の一部または全てをプロセッサ1010に直接組み込
んでも良い。
In one embodiment, the I /
ネットワークインターフェース1040は、例えば、コンピュータシステム1000と、他のコンピュータシステム1090(このシステムは、本明細書に記載されたデータベースシステムの1つ以上のストレージシステムサーバノード、データベースエンジン・ヘッドノード及び/またはクライアントを実装し得る)などの、ネットワークに取り付けられた他のデバイスとの間でデータを交換できるように構成され得る。加えて、ネットワークインターフェース1040は、コンピュータシステム1000と、様々なI/Oデバイス1050及び/またはリモートストレージ1070との間の通信を行うことができるように構成され得る。入出力デバイス1050は、いくつかの実施形態では、1つ以上の表示端末、キーボード、キーパッド、タッチパッド、スキャニングデバイス、音声認識デバイスもしくは光学認識デバイス、または1つ以上のコンピュータシステム1000によるデータの入力もしくは検索に好適なその他のデバイスを含んでも良い。複数の入出力デバイス1050は、コンピュータシステム1000内に存在しても良く、またはコンピュータシステム1000を含む分散システムの様々なノードに分散されても良い。いくつかの実施形態では、同様の入出力デバイスは、コンピュータシステム1000から分離されても良く、コンピュータシステム1000を含む分散システムの1つ以上のノードと、ネットワークインターフェース1040を介するような有線または無線接続を通じて相互作用しても良い。ネットワークインターフェース1040は、通常1つ以上の無線ネットワーキングプロトコル(例えば、Wi−Fi/IEEE802.11、または別の無線ネットワーキング規格)をサポートし得る。しかしながら、様々な実施形態では、ネットワークインターフェース1040は、例えば、他の種類のイーサネットネットワークなどの、任意の好適な有線または無線の一般的なデータネットワークを介した通信をサポートし得る。加えて、ネットワークインターフェース1040は、アナログ音声ネットワークもしくはデジタルファイバ通信ネットワークなどの電気通信ネットワーク/電話網、ファイバチャネルSANなどのストレージエリアネットワーク、またはその他任意の好適な種類のネットワーク及び/またはプロトコルを介した通信をサポートし得る。様々な実施形態では、コンピュータシステム1000は、図9に例示した構成要素よりも多い構成要素、これよりも少ない構成要素、またはこれとは異なる構成要素(例えば、ディスプレイ、ビデオカード、オーディオカード、周辺デバイス、ATMインターフェース、イーサネットインターフェース、フレームリレーインターフェースなどの他のネットワークインターフェース等)を含んでも良い。
The network interface 1040 may be, for example, a computer system 1000 and another computer system 1090, which is one or more storage system server nodes, database engine head nodes and / or clients of the database systems described herein. Can be configured to exchange data with other devices attached to the network, such as. In addition, network interface 1040 may be configured to allow communication between the computer system 1000 and various I /
本明細書に記載された分散システムの任意の実施形態、またはそれらの任意の構成要素は、1つ以上のネットワークベースのサービスとして実装され得ることが留意される。例えば、コンピューティングサービス内の計算クラスタは、コンピューティングサービス及び/または本明細書に記載した分散コンピューティングシステムを利用する他の種類のサービスを、ネットワークベースのサービスとしてクライアントに与え得る。いくつかの実施形態では、ネットワークベースのサービスは、ネットワークを介して相互運用可能なマシン対マシン相互作用をサポートするように設計されたソフトウェア及び/またはハードウェアシステムにより実装され得る。ネットワークベースのサービスは、Webサービス記述言語(WSDL)などの、マシンが処理可能な形式で記述されたインターフェースを有しても良い。他のシステムは、ネットワークベースのサービスのインターフェースを記述することにより定められる方法でネットワークベースのサービスと相互作用しても良い。やはり、例えば、ネットワークベースのサービスは、他のシステムが呼び出すことができる様々な動作を定義しても良く、様々な動作を要求する際に他のシステムが適合していると見込むことができる特定のアプリケーションプログラミングインターフェース(API)を定義しても良い。 It is noted that any embodiment of the distributed system described herein, or any component thereof, may be implemented as one or more network-based services. For example, a computing cluster within a computing service may provide a client with a computing service and / or other type of service utilizing the distributed computing system described herein as a network-based service. In some embodiments, network-based services may be implemented by software and / or hardware systems designed to support machine-to-machine interactions that are interoperable over the network. The network-based service may have an interface described in a machine-processable format, such as a Web Services Description Language (WSDL). Other systems may interact with the network-based service in a manner defined by describing the interface of the network-based service. Again, for example, a network-based service may define different behaviors that other systems can call, and specifics that can be expected to fit when requesting different behaviors. You may define the application programming interface (API) of.
様々な実施形態において、ネットワークベースのサービスは、ネットワークベースのサ
ービス要求に関連するパラメータ及び/またはデータを含むメッセージの使用を通して、要求、または呼び出され得る。係るメッセージは、拡張マークアップ言語(XML)等の特定のマークアップ言語に従って形式化され、及び/または簡易オブジェクトアクセスプロトコル(SOAP)などのプロトコルを使用してカプセル化され得る。ネットワークベースのサービス要求を行うために、ネットワークベースのサービスのクライアントは、要求を含むメッセージをアセンブルし、メッセージをネットワークベースのサービスに対応するアドレス指定可能なエンドポイント(例えば、ユニフォームリソースロケータ(URL))へ、ハイパーテキスト転送プロトコル(HTTP)等のインターネットベースのアプリケーション層転送プロトコルを使用して伝送し得る。
In various embodiments, network-based services may be requested or invoked through the use of messages containing parameters and / or data associated with network-based service requests. Such messages may be formalized according to a particular markup language such as XML (XML) and / or encapsulated using a protocol such as the Simple Object Access Protocol (SOAP). To make a network-based service request, the client of the network-based service assembles the message containing the request and sends the message to the addressable endpoint corresponding to the network-based service (eg, Uniform Resource Locator (URL)). ) Can be transmitted using an internet-based application layer transfer protocol such as the Hypertext Transfer Protocol (HTTP).
いくつかの実施形態において、ネットワークベースのサービスは、メッセージベースの技法ではなく、リプリゼンテーショナル・ステート・トランスファ(「RESTful」)技法を使用して実施され得る。例えば、RESTful技法に従って実施されるネットワークベースのサービスは、SOAPメッセージ内にカプセル化されたパラメータではなく、PUT、GET、またはDELETEなどのHTTPメソッド内に含まれるパラメータを通して呼び出され得る。 In some embodiments, network-based services may be performed using representational state transfer (“RESTful”) techniques rather than message-based techniques. For example, network-based services performed according to the RESTful technique can be called through parameters contained within HTTP methods such as PUT, GET, or DELETE, rather than parameters encapsulated in SOAP messages.
上記の実施形態はかなり詳細に説明されているが、いったん上記開示が完全に理解されると当業者に明らかになるように、多数の変形形態及び修正形態が行われて良い。以下の請求項は全ての係る修正形態及び変更を包含し、したがって、上記の記載は制限的な意味ではなく例示的な意味としてみなされることを意図する。 Although the above embodiments have been described in considerable detail, a number of modifications and modifications may be made so that once the disclosure is fully understood, those skilled in the art will appreciate it. The following claims include all such amendments and modifications, and are therefore intended to be taken as exemplary rather than restrictive.
Claims (15)
1つ以上のクレジットを仮想計算インスタンスに対するリソースクレジット残量に割り当てることであって、前記仮想計算インスタンスに対する前記リソースクレジット残量のクレジットは、前記仮想計算インスタンスが、前記仮想計算インスタンスを実装する1つ以上のコンピュータリソースをベースライン活用のレベルを超えて活用するために、前記クレジットを適用することを可能にする、前記割り当てることと、
前記仮想計算インスタンスを実装する1つ以上のコンピュータリソースにおける性能に対する作業要求をスケジュールするために、1つ以上のスケジューリング命令を前記仮想計算インスタンスに対し生成することであって、前記1つ以上のスケジューリング命令は、前記仮想計算インスタンスに対する前記リソースクレジット残量の1つ以上のリソースクレジットの適用に少なくとも部分的に基づき生成される、前記生成することと、
前記1つ以上のリソースクレジットを適用した後で、前記仮想計算インスタンスに対する前記リソースクレジット残量の残りのリソースクレジットが閾値よりも少ないことを判定することと、
前記判定に応答して、前記仮想計算インスタンスによる前記1つ以上のコンピュータリソースの活用が前記ベースライン活用まで低下するよう、前記1つ以上の生成されたスケジューリング命令の少なくとも1つを構成することと、
を行う方法。 With one or more computing devices
One or more credits are allocated to the remaining resource credits for the virtual compute instance, and the credits for the remaining resource credits for the virtual compute instance are one in which the virtual compute instance implements the virtual compute instance. The allocation and the allocation that make it possible to apply the credits in order to utilize the above computer resources beyond the level of baseline utilization.
Generating one or more scheduling instructions for the virtual computing instance to schedule work requests for performance on one or more computer resources that implement the virtual computing instance, the one or more scheduling The instructions are generated, at least in part, on the application of one or more of the resource credits remaining to the virtual compute instance.
After applying the one or more resource credits, determining that the remaining resource credits of the remaining resource credits for the virtual compute instance are less than the threshold value.
In response to the determination, at least one of the one or more generated scheduling instructions is configured so that the utilization of the one or more computer resources by the virtual computing instance is reduced to the baseline utilization. ,
How to do.
1つ以上のクレジットを仮想計算インスタンスに対するリソースクレジット残量に割り当てることであって、前記仮想計算インスタンスに対する前記リソースクレジット残量のクレジットは、、前記仮想計算インスタンスを実装する1つ以上のコンピュータリソースをベースライン活用のレベルを超えて活用するために、前記クレジットを適用することを可能にする、前記割り当てることと、
前記仮想計算インスタンスを実装する1つ以上のコンピュータリソースにおける性能に対する作業要求をスケジュールするために、1つ以上のスケジューリング命令を前記仮想計算インスタンスに対し生成することであって、前記1つ以上のスケジューリング命令は、前記仮想計算インスタンスに対する前記リソースクレジット残量の1つ以上のリソースクレジットの適用に少なくとも部分的に基づき生成される、前記生成することと、
前記1つ以上のリソースクレジットを適用した後で、前記仮想計算インスタンスに対する前記リソースクレジット残量の残りのリソースクレジットが閾値よりも少ないことを判定することと、
前記判定に応答して、前記仮想計算インスタンスによる前記1つ以上のコンピュータリソースの活用が前記ベースライン活用まで低下するよう、前記1つ以上の生成されたスケジューリング命令の少なくとも1つを構成することと、
を行わせる、
システム。 A system comprising one or more processors coupled to one or more non-transitory computer-readable storage media, wherein the computer-readable storage medium stores program instructions. When executed by the one or more processors, the system
Allocating one or more credits to the remaining resource credits for a virtual compute instance, where the remaining resource credits for the virtual compute instance are one or more computer resources that implement the virtual compute instance. The allocation and the allocation, which allows the credit to be applied in order to utilize beyond the level of baseline utilization.
Generating one or more scheduling instructions for the virtual computing instance to schedule work requests for performance on one or more computer resources that implement the virtual computing instance, the one or more scheduling The instructions are generated, at least in part, on the application of one or more of the resource credits remaining to the virtual compute instance.
After applying the one or more resource credits, determining that the remaining resource credits of the remaining resource credits for the virtual compute instance are less than the threshold value.
In response to the determination, at least one of the one or more generated scheduling instructions is configured so that the utilization of the one or more computer resources by the virtual computing instance is reduced to the baseline utilization. ,
To do,
system.
量を有する、請求項10−14のいずれか一項に記載のシステム。 The virtual compute instance is one of a plurality of different types of virtual compute instances supplied through a network-based virtual computing service, and each of the virtual compute instances is individually updated. The system according to any one of claims 10-14, which has a remaining amount of resource credits.
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201462018466P | 2014-06-27 | 2014-06-27 | |
US62/018,466 | 2014-06-27 | ||
US14/331,745 US10649796B2 (en) | 2014-06-27 | 2014-07-15 | Rolling resource credits for scheduling of virtual computer resources |
US14/331,745 | 2014-07-15 | ||
JP2019132615A JP6878512B2 (en) | 2014-06-27 | 2019-07-18 | Rolling resource credits for scheduling virtual computer resources |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019132615A Division JP6878512B2 (en) | 2014-06-27 | 2019-07-18 | Rolling resource credits for scheduling virtual computer resources |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2021119502A true JP2021119502A (en) | 2021-08-12 |
JP7189997B2 JP7189997B2 (en) | 2022-12-14 |
Family
ID=54930573
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2016573062A Active JP6560263B2 (en) | 2014-06-27 | 2015-06-24 | Rolling resource credits for scheduling virtual computer resources |
JP2019132615A Active JP6878512B2 (en) | 2014-06-27 | 2019-07-18 | Rolling resource credits for scheduling virtual computer resources |
JP2021075891A Active JP7189997B2 (en) | 2014-06-27 | 2021-04-28 | Rolling resource credits for scheduling virtual computer resources |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2016573062A Active JP6560263B2 (en) | 2014-06-27 | 2015-06-24 | Rolling resource credits for scheduling virtual computer resources |
JP2019132615A Active JP6878512B2 (en) | 2014-06-27 | 2019-07-18 | Rolling resource credits for scheduling virtual computer resources |
Country Status (7)
Country | Link |
---|---|
US (2) | US10649796B2 (en) |
EP (1) | EP3161637A1 (en) |
JP (3) | JP6560263B2 (en) |
CN (2) | CN106415500B (en) |
AU (3) | AU2015279996A1 (en) |
CA (1) | CA2951401C (en) |
WO (1) | WO2015200493A1 (en) |
Families Citing this family (29)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10649796B2 (en) | 2014-06-27 | 2020-05-12 | Amazon Technologies, Inc. | Rolling resource credits for scheduling of virtual computer resources |
US10853077B2 (en) | 2015-08-26 | 2020-12-01 | Huawei Technologies Co., Ltd. | Handling Instruction Data and Shared resources in a Processor Having an Architecture Including a Pre-Execution Pipeline and a Resource and a Resource Tracker Circuit Based on Credit Availability |
US11221853B2 (en) * | 2015-08-26 | 2022-01-11 | Huawei Technologies Co., Ltd. | Method of dispatching instruction data when a number of available resource credits meets a resource requirement |
CN107133087A (en) | 2016-02-29 | 2017-09-05 | 阿里巴巴集团控股有限公司 | A kind of resource regulating method and equipment |
US10149193B2 (en) | 2016-06-15 | 2018-12-04 | At&T Intellectual Property I, L.P. | Method and apparatus for dynamically managing network resources |
US10454836B2 (en) | 2016-11-01 | 2019-10-22 | At&T Intellectual Property I, L.P. | Method and apparatus for dynamically adapting a software defined network |
US10284730B2 (en) | 2016-11-01 | 2019-05-07 | At&T Intellectual Property I, L.P. | Method and apparatus for adaptive charging and performance in a software defined network |
US10505870B2 (en) | 2016-11-07 | 2019-12-10 | At&T Intellectual Property I, L.P. | Method and apparatus for a responsive software defined network |
US10469376B2 (en) | 2016-11-15 | 2019-11-05 | At&T Intellectual Property I, L.P. | Method and apparatus for dynamic network routing in a software defined network |
US10039006B2 (en) | 2016-12-05 | 2018-07-31 | At&T Intellectual Property I, L.P. | Method and system providing local data breakout within mobility networks |
US10373284B2 (en) * | 2016-12-12 | 2019-08-06 | Amazon Technologies, Inc. | Capacity reservation for virtualized graphics processing |
US10264075B2 (en) * | 2017-02-27 | 2019-04-16 | At&T Intellectual Property I, L.P. | Methods, systems, and devices for multiplexing service information from sensor data |
US10469286B2 (en) | 2017-03-06 | 2019-11-05 | At&T Intellectual Property I, L.P. | Methods, systems, and devices for managing client devices using a virtual anchor manager |
US10212289B2 (en) | 2017-04-27 | 2019-02-19 | At&T Intellectual Property I, L.P. | Method and apparatus for managing resources in a software defined network |
US10819606B2 (en) | 2017-04-27 | 2020-10-27 | At&T Intellectual Property I, L.P. | Method and apparatus for selecting processing paths in a converged network |
US10749796B2 (en) | 2017-04-27 | 2020-08-18 | At&T Intellectual Property I, L.P. | Method and apparatus for selecting processing paths in a software defined network |
US10673751B2 (en) | 2017-04-27 | 2020-06-02 | At&T Intellectual Property I, L.P. | Method and apparatus for enhancing services in a software defined network |
US10382903B2 (en) | 2017-05-09 | 2019-08-13 | At&T Intellectual Property I, L.P. | Multi-slicing orchestration system and method for service and/or content delivery |
US10257668B2 (en) | 2017-05-09 | 2019-04-09 | At&T Intellectual Property I, L.P. | Dynamic network slice-switching and handover system and method |
CN108984264B (en) * | 2017-06-02 | 2022-11-15 | 阿里巴巴集团控股有限公司 | Virtual GPU (graphics processing Unit) implementation method, device and system |
US10070344B1 (en) | 2017-07-25 | 2018-09-04 | At&T Intellectual Property I, L.P. | Method and system for managing utilization of slices in a virtual network function environment |
US10104548B1 (en) | 2017-12-18 | 2018-10-16 | At&T Intellectual Property I, L.P. | Method and apparatus for dynamic instantiation of virtual service slices for autonomous machines |
KR102507249B1 (en) * | 2018-03-08 | 2023-03-07 | 삼성전자주식회사 | Method for controlling performance mode and electronic device supporting the same |
US10963296B1 (en) * | 2018-06-22 | 2021-03-30 | Amazon Technologies, Inc. | Load balancing of compute resources based on resource credits |
CN109033468B (en) * | 2018-08-31 | 2022-09-16 | 创新先进技术有限公司 | Resource change processing method and device |
US11550634B2 (en) | 2019-03-08 | 2023-01-10 | Microsoft Technology Licensing, Llc | Capacity management in a cloud computing system using virtual machine series modeling |
CN110648232A (en) * | 2019-08-20 | 2020-01-03 | 上海数据交易中心有限公司 | Method and device for controlling limit of processing node, storage medium and terminal |
KR102496115B1 (en) * | 2019-11-28 | 2023-02-06 | 한국전자통신연구원 | Apparatus and Method of Altruistic Scheduling based on Reinforcement Learning |
US20220327003A1 (en) * | 2021-04-09 | 2022-10-13 | Oracle International Corporation | Cloud edge device virtualization |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2010113677A (en) * | 2008-11-10 | 2010-05-20 | Hitachi Ltd | Service management device, service management method, and service management system |
JP2010539570A (en) * | 2007-09-14 | 2010-12-16 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Method, system, and computer program for balancing access to shared resources using credit-based tokens |
JP2011198027A (en) * | 2010-03-19 | 2011-10-06 | Fujitsu Ltd | Virtual machine system and virtual machine management method |
WO2014073024A1 (en) * | 2012-11-09 | 2014-05-15 | Hitachi, Ltd. | Management computer, computer system, and instance management method |
Family Cites Families (76)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6714960B1 (en) * | 1996-11-20 | 2004-03-30 | Silicon Graphics, Inc. | Earnings-based time-share scheduling |
US7065762B1 (en) * | 1999-03-22 | 2006-06-20 | Cisco Technology, Inc. | Method, apparatus and computer program product for borrowed-virtual-time scheduling |
US7065764B1 (en) | 2001-07-20 | 2006-06-20 | Netrendered, Inc. | Dynamically allocated cluster system |
US7093250B1 (en) * | 2001-10-11 | 2006-08-15 | Ncr Corporation | Priority scheduler for database access |
US7194616B2 (en) * | 2001-10-27 | 2007-03-20 | International Business Machines Corporation | Flexible temporary capacity upgrade/downgrade in a computer system without involvement of the operating system |
US7330430B2 (en) * | 2002-06-04 | 2008-02-12 | Lucent Technologies Inc. | Packet-based traffic shaping |
US7698115B2 (en) * | 2003-06-30 | 2010-04-13 | Microsoft Corporation | System and method for dynamically allocating resources in a client/server environment |
EP2341432A1 (en) * | 2004-03-13 | 2011-07-06 | Adaptive Computing Enterprises, Inc. | System and method of co-allocating a reservation spanning different compute resources types |
US20050273511A1 (en) * | 2004-06-08 | 2005-12-08 | Hewlett-Packard Development Company, L.P. | Equitable resource sharing in grid-based computing environments |
US7797699B2 (en) | 2004-09-23 | 2010-09-14 | Intel Corporation | Method and apparatus for scheduling virtual machine access to shared resources |
US20060130062A1 (en) * | 2004-12-14 | 2006-06-15 | International Business Machines Corporation | Scheduling threads in a multi-threaded computer |
US7770173B2 (en) * | 2005-02-03 | 2010-08-03 | International Business Machines Corporation | System for dynamic processor enablement |
US8091088B2 (en) * | 2005-02-22 | 2012-01-03 | Microsoft Corporation | Method and system for hierarchical resource management involving hard and soft resource limits |
US7613897B2 (en) * | 2005-03-30 | 2009-11-03 | International Business Machines Corporation | Allocating entitled processor cycles for preempted virtual processors |
EP2036267B1 (en) * | 2006-06-22 | 2009-10-07 | Xelerated AB | A processor and a method for a processor |
US8255910B2 (en) * | 2006-07-18 | 2012-08-28 | Hewlett-Packard Development Company, L.P. | Fair weighted proportional-share virtual time scheduler |
CN100517237C (en) * | 2006-09-28 | 2009-07-22 | 联想(北京)有限公司 | Virtual machine system and its CPU scheduling method |
US9354960B2 (en) * | 2010-12-27 | 2016-05-31 | Red Hat, Inc. | Assigning virtual machines to business application service groups based on ranking of the virtual machines |
US7707248B2 (en) * | 2007-06-25 | 2010-04-27 | Microsoft Corporation | Credit-based peer-to-peer storage |
WO2009029549A2 (en) * | 2007-08-24 | 2009-03-05 | Virtualmetrix, Inc. | Method and apparatus for fine grain performance management of computer systems |
US8045563B2 (en) | 2007-12-27 | 2011-10-25 | Cellco Partnership | Dynamically adjusted credit based round robin scheduler |
EP2141643A1 (en) * | 2008-07-04 | 2010-01-06 | Koninklijke KPN N.V. | Software usage controlled by CPU utilization |
JP5157717B2 (en) * | 2008-07-28 | 2013-03-06 | 富士通株式会社 | Virtual machine system with virtual battery and program for virtual machine system with virtual battery |
TWI397010B (en) * | 2008-12-10 | 2013-05-21 | Inst Information Industry | Virtual machine module scheduling, scheduling methods and computer program products |
US9086913B2 (en) * | 2008-12-31 | 2015-07-21 | Intel Corporation | Processor extensions for execution of secure embedded containers |
US8019861B2 (en) | 2009-01-29 | 2011-09-13 | Vmware, Inc. | Speculative virtual machine resource scheduling |
CN101488098B (en) * | 2009-02-13 | 2011-11-30 | 华中科技大学 | Multi-core computing resource management system based on virtual computing technology |
US8914511B1 (en) * | 2009-06-26 | 2014-12-16 | VMTurbo, Inc. | Managing resources in virtualization systems |
US8910153B2 (en) * | 2009-07-13 | 2014-12-09 | Hewlett-Packard Development Company, L. P. | Managing virtualized accelerators using admission control, load balancing and scheduling |
US8245234B2 (en) * | 2009-08-10 | 2012-08-14 | Avaya Inc. | Credit scheduler for ordering the execution of tasks |
EP2323035B1 (en) * | 2009-11-16 | 2019-04-17 | Red Bend Software | Scheduling system |
US8037187B2 (en) * | 2009-12-11 | 2011-10-11 | International Business Machines Corporation | Resource exchange management within a cloud computing environment |
US8984521B2 (en) * | 2010-02-18 | 2015-03-17 | International Business Machines Corporation | Computer system performance by applying rate limits to control block tenancy |
JP2011182115A (en) * | 2010-02-26 | 2011-09-15 | Hitachi Ltd | Communication method, communication system and server |
JP5388909B2 (en) * | 2010-03-09 | 2014-01-15 | 株式会社日立製作所 | Hypervisor, computer system, and virtual processor scheduling method |
KR101690652B1 (en) * | 2010-08-25 | 2016-12-28 | 삼성전자주식회사 | Scheduling apparatus and method for a multicore system |
CN103154926B (en) * | 2010-09-30 | 2016-06-01 | 亚马逊技术股份有限公司 | Virtual resource cost tracking is carried out by special implementing resource |
US8429276B1 (en) * | 2010-10-25 | 2013-04-23 | Juniper Networks, Inc. | Dynamic resource allocation in virtual environments |
US8918784B1 (en) | 2010-12-21 | 2014-12-23 | Amazon Technologies, Inc. | Providing service quality levels through CPU scheduling |
US8615579B1 (en) * | 2010-12-28 | 2013-12-24 | Amazon Technologies, Inc. | Managing virtual machine migration |
US9454406B2 (en) * | 2011-02-28 | 2016-09-27 | Novell, Inc. | Techniques for cloud bursting |
US20120221454A1 (en) * | 2011-02-28 | 2012-08-30 | Morgan Christopher Edwin | Systems and methods for generating marketplace brokerage exchange of excess subscribed resources using dynamic subscription periods |
CN102681899B (en) * | 2011-03-14 | 2015-06-10 | 金剑 | Virtual computing resource dynamic management system of cloud computing service platform |
US8990149B2 (en) * | 2011-03-15 | 2015-03-24 | International Business Machines Corporation | Generating a predictive model from multiple data sources |
CN102117226A (en) * | 2011-03-18 | 2011-07-06 | 浪潮(北京)电子信息产业有限公司 | Resource dispatching system and resource dispatching method |
US8676981B2 (en) * | 2011-05-12 | 2014-03-18 | International Business Machines Corporation | Routing service requests based on lowest actual cost within a federated virtual service cloud |
US8863140B2 (en) * | 2011-08-29 | 2014-10-14 | Oracle International Corporation | Method for resource management allocating and freeing credits from and to a resource credit tree |
US8959114B2 (en) * | 2011-10-21 | 2015-02-17 | Salesforce.Com, Inc. | Entitlement management in an on-demand system |
CN102413186B (en) * | 2011-12-02 | 2014-07-30 | 北京星网锐捷网络技术有限公司 | Resource scheduling method and device based on private cloud computing, and cloud management server |
CN104011680B (en) | 2011-12-26 | 2017-03-01 | 英特尔公司 | The virtual center processing unit of scheduling virtual machine in physical processing unit |
CN103744714A (en) * | 2011-12-31 | 2014-04-23 | 华茂云天科技(北京)有限公司 | Virtual machine management platform based on cloud computing |
CN103248659B (en) * | 2012-02-13 | 2016-04-20 | 北京华胜天成科技股份有限公司 | A kind of cloud computing resource scheduling method and system |
US20170278087A1 (en) * | 2012-03-28 | 2017-09-28 | Google Inc. | Virtual machine pricing model |
US9027024B2 (en) * | 2012-05-09 | 2015-05-05 | Rackspace Us, Inc. | Market-based virtual machine allocation |
US9218196B2 (en) * | 2012-05-17 | 2015-12-22 | International Business Machines Corporation | Performing pre-stage replication of data associated with virtual machines prior to migration of virtual machines based on resource usage |
US8930948B2 (en) * | 2012-06-21 | 2015-01-06 | Vmware, Inc. | Opportunistically proactive resource management using spare capacity |
US20140013321A1 (en) | 2012-07-05 | 2014-01-09 | Telefonica, S.A. | Method for providing cloud computing resources |
US8949848B2 (en) * | 2012-08-20 | 2015-02-03 | International Business Machines Corporation | Reducing usage of resource utilized by a virtual machine whose resource utilization is adversely affecting neighboring virtual machines |
US9130969B2 (en) * | 2012-08-23 | 2015-09-08 | Seagate Technology Llc | Data storage I/O communication method and apparatus |
US9379995B2 (en) * | 2012-09-11 | 2016-06-28 | Vmware, Inc. | Resource allocation diagnosis on distributed computer systems based on resource hierarchy |
US9189260B2 (en) * | 2012-09-27 | 2015-11-17 | International Business Machines Corporation | Resource allocation for virtual machines and logical partitions |
US9304803B2 (en) * | 2012-11-12 | 2016-04-05 | Vmware, Inc. | Cooperative application workload scheduling for a consolidated virtual environment |
CN103036800B (en) * | 2012-12-14 | 2015-09-09 | 北京高森明晨信息科技有限公司 | Virtual machine SiteServer LBS, node and method |
CN103095599A (en) * | 2013-01-18 | 2013-05-08 | 浪潮电子信息产业股份有限公司 | Dynamic feedback weighted integration load scheduling method of cloud computing operating system |
CN103064746B (en) * | 2013-01-23 | 2015-08-12 | 上海交通大学 | The accurate distribution method of processor resource of forecast dispatching is carried out based on current credit |
US20140280964A1 (en) * | 2013-03-15 | 2014-09-18 | Gravitant, Inc. | Systems, methods and computer readable mediums for implementing cloud service brokerage platform functionalities |
US9634958B2 (en) * | 2013-04-02 | 2017-04-25 | Amazon Technologies, Inc. | Burst capacity for user-defined pools |
US10063712B2 (en) * | 2013-06-21 | 2018-08-28 | Openet Telecom Ltd. | System and method for dynamically allocating quota for shared balances in distributed telecommunications networks |
US9602426B2 (en) * | 2013-06-21 | 2017-03-21 | Microsoft Technology Licensing, Llc | Dynamic allocation of resources while considering resource reservations |
US9218221B2 (en) * | 2013-06-25 | 2015-12-22 | Amazon Technologies, Inc. | Token sharing mechanisms for burst-mode operations |
KR20160004365A (en) * | 2013-06-29 | 2016-01-12 | 인텔 코포레이션 | Service rate redistribution for credit-based arbitration |
US9880883B2 (en) * | 2013-08-05 | 2018-01-30 | Nec Corporation | Virtual resource control system determining new allocation of resources at a hub |
US10554579B2 (en) * | 2014-01-02 | 2020-02-04 | Sky Atlas Iletisim Sanayi Ve Ticaret Anonim Sirketi | Method and system for allocating resources to resource consumers in a cloud computing environment |
US9396009B2 (en) * | 2014-01-30 | 2016-07-19 | International Business Machines Corporation | Optimized global capacity management in a virtualized computing environment |
US10721173B2 (en) * | 2014-03-31 | 2020-07-21 | Hewlett Packard Enterprise Development Lp | Credit distribution to clients |
US10649796B2 (en) | 2014-06-27 | 2020-05-12 | Amazon Technologies, Inc. | Rolling resource credits for scheduling of virtual computer resources |
-
2014
- 2014-07-15 US US14/331,745 patent/US10649796B2/en active Active
-
2015
- 2015-06-24 CN CN201580034494.8A patent/CN106415500B/en active Active
- 2015-06-24 AU AU2015279996A patent/AU2015279996A1/en not_active Abandoned
- 2015-06-24 CN CN202010073301.2A patent/CN111176796B/en active Active
- 2015-06-24 WO PCT/US2015/037443 patent/WO2015200493A1/en active Application Filing
- 2015-06-24 EP EP15741401.2A patent/EP3161637A1/en not_active Withdrawn
- 2015-06-24 CA CA2951401A patent/CA2951401C/en active Active
- 2015-06-24 JP JP2016573062A patent/JP6560263B2/en active Active
-
2018
- 2018-06-26 AU AU2018204629A patent/AU2018204629A1/en not_active Ceased
-
2019
- 2019-07-18 JP JP2019132615A patent/JP6878512B2/en active Active
-
2020
- 2020-05-08 US US16/870,764 patent/US11487562B2/en active Active
- 2020-10-09 AU AU2020250308A patent/AU2020250308A1/en not_active Abandoned
-
2021
- 2021-04-28 JP JP2021075891A patent/JP7189997B2/en active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2010539570A (en) * | 2007-09-14 | 2010-12-16 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Method, system, and computer program for balancing access to shared resources using credit-based tokens |
JP2010113677A (en) * | 2008-11-10 | 2010-05-20 | Hitachi Ltd | Service management device, service management method, and service management system |
JP2011198027A (en) * | 2010-03-19 | 2011-10-06 | Fujitsu Ltd | Virtual machine system and virtual machine management method |
WO2014073024A1 (en) * | 2012-11-09 | 2014-05-15 | Hitachi, Ltd. | Management computer, computer system, and instance management method |
Also Published As
Publication number | Publication date |
---|---|
EP3161637A1 (en) | 2017-05-03 |
AU2015279996A1 (en) | 2017-01-05 |
AU2020250308A1 (en) | 2020-11-05 |
WO2015200493A1 (en) | 2015-12-30 |
JP6878512B2 (en) | 2021-05-26 |
US20150378753A1 (en) | 2015-12-31 |
JP7189997B2 (en) | 2022-12-14 |
US20200272486A1 (en) | 2020-08-27 |
US11487562B2 (en) | 2022-11-01 |
CN106415500A (en) | 2017-02-15 |
US10649796B2 (en) | 2020-05-12 |
CN106415500B (en) | 2020-02-21 |
CN111176796B (en) | 2023-12-05 |
AU2018204629A1 (en) | 2018-07-12 |
JP2017526999A (en) | 2017-09-14 |
JP2019194914A (en) | 2019-11-07 |
CN111176796A (en) | 2020-05-19 |
CA2951401C (en) | 2020-02-25 |
CA2951401A1 (en) | 2015-12-30 |
JP6560263B2 (en) | 2019-08-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6878512B2 (en) | Rolling resource credits for scheduling virtual computer resources | |
US9626210B2 (en) | Resource credit pools for replenishing instance resource credit balances of virtual compute instances | |
US10452438B2 (en) | Parameter selection for optimization of task execution based on execution history for prior tasks | |
US9635103B2 (en) | Dynamic virtual resource request rate control for utilizing physical resources | |
US10552774B2 (en) | Cost-minimizing task scheduler | |
US9529633B2 (en) | Variable timeslices for processing latency-dependent workloads | |
US8156226B2 (en) | Ordering provisioning request execution based on service level agreement and customer entitlement | |
US9430280B1 (en) | Task timeouts based on input data characteristics | |
JP2021519478A (en) | How to quantify heterogeneous computing resource usage as a single unit of measurement | |
US20150212857A1 (en) | Dynamic allocation of physical computing resources amongst virtual machines | |
US20180270296A1 (en) | Preemptive extraction of data from long latency storage in a cloud computing environment | |
Mosleh et al. | Adaptive cost-based task scheduling in cloud environment | |
US10915250B2 (en) | Addressing usage of shared SSD resources in volatile and unpredictable operating environments | |
WO2016040743A1 (en) | Dynamic virtual resource request rate control for utilizing physical resources |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20210428 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20210428 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20220309 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20220329 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220628 |
|
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: 20221115 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20221202 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 7189997 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |