JP2021119502A - Rolling resource credit for scheduling virtual computer resource - Google Patents

Rolling resource credit for scheduling virtual computer resource Download PDF

Info

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
Application number
JP2021075891A
Other languages
Japanese (ja)
Other versions
JP7189997B2 (en
Inventor
フィリップス,ジョン・メリル
Merrill Phillips John
アール,ウィリアム・ジョン
John Earl William
シング,ディーパック
Singh Deepak
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Amazon Technologies Inc
Original Assignee
Amazon Technologies Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Amazon Technologies Inc filed Critical Amazon Technologies Inc
Publication of JP2021119502A publication Critical patent/JP2021119502A/en
Application granted granted Critical
Publication of JP7189997B2 publication Critical patent/JP7189997B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/4881Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation 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/505Allocation 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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/00Payment architectures, schemes or protocols
    • G06Q20/22Payment schemes or models
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5061Partitioning or combining of resources
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5061Partitioning or combining of resources
    • G06F9/5077Logical partitioning of resources; Management or configuration of virtualized resources

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

To provide a method and a system which schedule a virtual computing resource.SOLUTION: A network-based virtual computing resource provider provides a virtual computing instance that implements rolling resource credits for scheduling virtual computing resources. A virtualization manager receives a work request for the virtual computing instance. A resource credit residual is determined for the virtual computing instance. The resource credit residual is stored in a rolling system and unused credits are carried over from a previous period. Thereafter, in generating a scheduling instruction, the resource credit is applied, and a physical resource for performing the work request such as a physical CPU is provided in order to increase utilization of resources according to the number of applied credits. The applied resource credit is then subtracted from the residual credit.SELECTED DRAWING: Figure 3

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.

いくつかの実施形態に係る、仮想計算インスタンスに対するローリングリソースクレジット残量を例示するグラフである。It is a graph which illustrates the rolling resource credit remaining amount for the virtual calculation instance which concerns on some embodiments. いくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングリソースクレジットを実施する仮想計算インスタンスを提供するネットワークベースの仮想コンピューティングサービスを例示するブロック図である。FIG. 3 is a block diagram illustrating a network-based virtual computing service that provides virtual computing instances that perform rolling resource credits to schedule virtual computer resources, according to some embodiments. いくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングリソースクレジットを実施する仮想化ホストを例示するブロック図である。FIG. 5 is a block diagram illustrating a virtualization host that implements rolling resource credits to schedule virtual computer resources, according to some embodiments. いくつかの実施形態に係る、仮想計算インスタンスに対するローリングクレジット指標を提供するインターフェースの一例の説明図である。FIG. 5 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. いくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングコンピュータリソースクレジットを実施する様々な方法及び技法を例示する高レベルフロー図である。FIG. 6 is a high-level flow diagram illustrating various methods and techniques for performing rolling computer resource credits to schedule virtual computer resources, according to some embodiments. いくつかの実施形態に係る、仮想コンピュータに対する処理リソースをスケジュールするためにローリングコンピュータリソースクレジットを実施する様々な方法及び技法を例示する高レベルフロー図である。FIG. 6 is a high-level flow diagram illustrating various methods and techniques for performing rolling computer resource credits to schedule processing resources for virtual computers, according to some embodiments. いくつかの実施形態に係る、仮想計算インスタンスへの作業要求に対する利用可能なリソースクレジットに従って、物理的なコンピュータリソースの活用を低下または上昇する様々な方法及び技法を例示する高レベルフロー図である。It is a high level flow diagram illustrating various methods and techniques that reduce or increase the utilization of physical computer resources according to the available resource credits for work requests to virtual computing instances, according to some embodiments. いくつかの実施形態に係る、仮想コンピュータリソースをスケジュールするためにローリングクレジットリソースを実施する仮想計算インスタンスに対するデータ指標を記録及び活用する様々な方法及び技法を例示する高レベルフロー図である。It 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. いくつかの実施形態に係る、コンピューティングシステムの一例を例示するブロック図である。It is a block diagram which illustrates an example of the computing system which concerns on some embodiments.

本明細書では、実施形態がいくつかの実施形態及び説明図に対する例により記載されるが、実施形態は記載される実施形態または図面に限定されないことを当業者は認識するであろう。図面及びその詳細な記載は、開示される特定の形態に実施形態を限定する意図はなく、それとは逆に、添付の請求項で定義される精神及び範囲に入る全ての修正、均等物及び代替案を含める意図があることを理解されたい。本明細書で使用される見出しは、本明細書を構成する目的でのみ使用され、明細書または請求項の範囲を限定するために使用されることを意図しない。本出願を通して使用される単語「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 credit remaining limit 120 may prevent any one compute instance from accumulating sufficient resource credits to interfere with the performance of the work request for the other instance. For example, as illustrated in FIG. 1, when the rolling resource credit limit is set to 144 resource credits, the maximum that any one virtual compute instance can monopolize physical computer resources is 2 hours and 24 minutes ( Resource credit is equivalent to one minute of full utilization of resources).

前述の記載は計算インスタンスに対するローリングリソースクレジット残量及び使用量の一例を提供するにすぎず、限定する意図はないことに留意されたい。リソースクレジットが使用され得る様々な量に応じて、蓄積率、初期の残量及び残量限度は全て異なり得る。 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 client 202. The network-based virtual computing service 200 is a physical and / or virtualized computer server, which is required to implement and distribute the infrastructure and services provided by the network-based virtual computing service 200. It can contain a myriad of data centers that host various resource pools such as storage devices, a collection of networking devices, and so on. In some embodiments, the network-based virtual computing service 200 may provide computing resources. These computing resources may, in some embodiments, be supplied to the client in units called "instances" 234, such as virtual computing instances.

様々な実施形態では、ネットワークベースの仮想コンピューティングサービス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 client 202. The control plane 210 may implement a variety of different components to manage the computing resource supply. The control plane 210 may be implemented across various servers, nodes or other computing systems or devices, such as the computing system 1000 described below with respect to FIG. It is noted that if one or more instances of a given component can be present, reference to that component in the present specification can refer to either one or more. However, the use of either form is not intended to exclude the other.

少なくともいくつかの実施形態では、制御プレーン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 network 260 and direct the requests to the appropriate components for further processing. In at least some embodiments, the interface 212 may be a network-based interface, such as a graphical interface (eg, as part of a management control panel or website) and / or various application programming interface (API) commands. May be implemented as a programmatic interface. In various embodiments, interface 212 may be implemented as part of a front-end module or component that issues requests to various other components such as resource management 214, reservation management 216, resource monitoring 218 and billing 220. .. Client 202, in various embodiments, may not be able to directly arrange, launch, or configure resources, but is an exemplary component (or other component, function, or service not exemplified). The request may be sent to the control plane 210 so that may perform the requested action.

制御プレーン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 client 202 to grasp and select the capacity of computing resources from either the initial sales marketplace or the resale marketplace, and purchase and / or reserve access. It may be possible to do this via a web page or via an API. For example, the resource management component may provide a list of different available compute instance types via interface 212, each with a different credit accumulation rate. Additionally, in some embodiments, the resource management module 214 is provided (via credit accumulation rate for instance type, etc.) for a specified purchase amount or scheme (eg, lump sum payment, additional recurring payment, etc.). It may be configured to provide purchase credits (in addition to the credits made). For example, the resource management module 214 may be configured to receive a credit purchase request (eg, an API request) and populate the remaining virtual instance with purchased credits. Similarly, resource management module 214 may be configured to handle requests that increase the credit accumulation rate for a particular instance. Resource management 214 may further provide and / or implement access to the interface to the client 202 via a set of flexible resource reservations, controls and interfaces 212. For example, the resource management module 214 may provide the client 202 with authentication information or permissions so that the compute instance control operation / client can interact with the computing resource in use.

様々な実施形態では、予約管理モジュール216はインスタンス234の様々な価格スキーム(少なくとも初期の販売マーケットプレイスに対して)を処理するように様々な実施形態で構成され得る。例えば、いくつかの実施形態では、ネットワークベースの仮想コンピューティングサービス200は、例えば、期間予約(つまり、予約された計算インスタンス)、オンデマンドのリソース割り当てまたはスポット価格ベースのリソース割り当て等、いくつかの異なる購入モード(本明細書において、予約モードとしてさらに言及され得る)をサポートしても良い。長期予約モードを使用すると、クライアントは、計算インスタンスまたは他のコンピューティングリソースに対して低価格の1回限りの前払いを行ない、1年間または3年間などの指定期間にわたって計算インスタンスを予約し、そのインスタンスに対して低価格の時間当たりの料金を支払うことができ、クライアントは、予約期間にわたって利用可能な予約されたインスタンスを有することが保証されるだろう。オンデマンドモードを使用すると、クライアントは、長期間の約束または前払いをすることなく、1時間(または何らかの適切な時間単位)毎に容量に対して支払うことが可能である。スポット価格モードでは、クライアントは、計算インスタンスまたは他のコンピューティングリソースの特定の種類に対して支払うことを望んでいる、単位時間当たりの最高価格を指定することが可能であり、クライアントの最高価格が、少なくとも部分的に供給及び需要により決定された動的スポット価格を超えた場合、その種類のリソースがクライアントに提供されることになる。 In various embodiments, the booking management module 216 may be configured in various embodiments to handle different pricing schemes (at least for the initial sales marketplace) of instance 234. For example, in some embodiments, the network-based virtual computing service 200 may include, for example, period reservations (ie, reserved compute instances), on-demand resource allocation, or spot price-based resource allocation. Different purchasing modes (which may be further referred to herein as reservation modes) may be supported. With long-term reservation mode, the client makes a low-cost, one-time prepayment to a compute instance or other computing resource, reserves the compute instance for a specified period of time, such as one or three years, and that instance. You will be able to pay a low hourly rate to and your clients will be guaranteed to have reserved instances available over the booking period. On-demand mode allows clients to pay for capacity hourly (or in any suitable time unit) without long-term commitments or prepayments. In spot price mode, the client can specify the highest price per unit time that he or she wants to pay for a particular type of compute instance or other computing resource, and the client's highest price is If, at least in part, the dynamic spot price determined by supply and demand is exceeded, that type of resource will be provided to the client.

要求されたリソースの種類の供給が需要を超えた期間中、スポット価格は、オンデマンドモードの価格よりもはるかに低くなり得る。いくつかの実装において、スポット価格がクライアントにより指定された最高の指値を上回って増加した場合、リソース割り当ては中断されても良く、すなわち、以前にクライアントに割り当てられていたリソースインス
タンスは、リソース管理モジュール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 billing management module 220. The billing management module 220 sends a billing event (eg, any other factor that generates a claim for a particular date, time, usage, billing amount or a billing amount for a particular user account or a payment account linked to a user account). It can be configured to detect. In response to the detection of billing events, the billing management module may be configured to generate billing amounts for user accounts or payment accounts linked to user accounts.

仮想計算インスタンス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 instance client 202 or any other user may be configured (and / or allowed) to direct network traffic to compute instance 234.

計算インスタンス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 client 202 applications without the need for client 202 to access instance 234. It is suitable for. There can be a variety of different types of compute instances. In at least some embodiments, there may be compute instances that perform rolling resource credit balances to schedule virtual computer resource operations. This type of instance runs on the basis of resource credits, where resource credits take advantage of the amount of time an instance can spend working on physical resources (eg, physical CPU processing time, network communication channels). Time to do, etc.). The more resource credits an instance has for computer resources, the longer the physical resources can spend doing their work (increasing performance). Resource credits may be provided at instance startup and may be defined as utilization time (eg, CPU time, such as CPU-minutes), where utilization time is the physical resource on which the virtual resources of an instance are based. Can represent the time that can be spent performing a task.

様々な実施形態では、リソースクレジットはベースライン活用保証を超過した時間またはリソースの活用を表し得る。例えば、計算インスタンスはリソースに対して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 client 202 may include a suitable version of a web browser, or a plug-in module or other configured to run within or as an extension to the execution environment provided by the web browser. May include code modules of the following types. Alternatively, the client 202 can be an application such as a dashboard application (or the user interface of the dashboard application), a media application, an office application, or any other application that may utilize the compute instance 234 to perform various actions. It may be included. In some embodiments, such applications do not necessarily implement full browser support for network-based data of any kind, but have sufficient protocol support (eg, preferred) to generate and process network-based service requests. Support for different versions of the Hypertext Transfer Protocol (HTTP)) may be included. In some embodiments, the client 202 is a representational state transfer (REST) type network-based service architecture, a document or message-based network-based service architecture, or another preferred network-based service. It may be configured to generate network-based service requests according to the architecture. In some embodiments, the client 202 (eg, compute client) leverages the compute resources provided by compute instance 324 to compute instance 234 in a manner transparent to application implementation on client 202. It may be configured to provide access.

クライアント202はネットワーク260を介してネットワークベースのサービス要求をネットワークベースの仮想コンピューティングサービス200に伝送しても良い。様々な実施形態では、ネットワーク260は、クライアント202とネットワークベースの仮想コンピューティングサービス200との間のネットワークベース通信を構築するために必要なネットワーキングハードウェア及びプロトコルの任意の好適な組み合わせを包含し得る。例えば、ネットワーク260は、概して、集合的にインターネットを実装する様々な電気通信ネットワーク及びサービスプロバイダを包含し得る。ネットワーク260は、ローカルエリアネットワーク(LAN)またはワイドエリアネットワーク(WAN)などのプライベートネットワーク、ならびに公衆またはプライベート無線ネットワークをさらに含んでも良い。例えば、所与のクライアント202及びネットワークベースの仮想コンピューティングサービス200の両方が、それぞれ、独自の内部ネットワークを有する企業内で整備されても良い。係る実施形態では、ネットワーク260は、所与のクライアント202とインターネットとの間、ならびにインターネットとネットワークベースの仮想コンピューティングサービス200との間のネットワーキングリンクを構築するために必要なハードウェア(例えば、モデム、ルータ、スイッチ、ロードバランサ、プロキシサーバ等)及びソフトウェア(例えば、プロトコルスタック、会計ソフトウェア、ファイアウォール/セキュリティソフトウェア等)を含んでも良い。いくつかの実施形態では、クラ
イアント202は、公衆インターネットよりもむしろプライベートネットワークを使用して、ネットワークベースの仮想コンピューティングサービス200と通信しても良いことが留意される。
Client 202 may transmit network-based service requests over network 260 to network-based virtual computing service 200. In various embodiments, the network 260 may include any suitable combination of networking hardware and protocols required to build network-based communication between the client 202 and the network-based virtual computing service 200. .. For example, network 260 may generally include various telecommunications networks and service providers that collectively implement the Internet. The network 260 may further include a private network such as a local area network (LAN) or wide area network (WAN), as well as a public or private wireless network. For example, both a given client 202 and a network-based virtual computing service 200 may be deployed within an enterprise, each with its own internal network. In such an embodiment, the network 260 is the hardware required to build a networking link between a given client 202 and the Internet, as well as between the Internet and the network-based virtual computing service 200 (eg, a proxy). , Routers, switches, load balancers, proxy servers, etc.) and software (eg, protocol stacks, accounting software, firewall / security software, etc.). It is noted that in some embodiments, the client 202 may use a private network rather than the public internet to communicate with the network-based virtual computing service 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 amount scheduler 324. The Rolling Resource Credit Remaining Scheduler 324 may act as a meta-scheduler, managing, tracking, applying, deducting, and / or otherwise processing all resource credit remaining for each compute instance 330. In various embodiments, the rolling resource credit remaining scheduler 324 may be configured to receive a virtual compute resource work request 332 from the compute instance. Each work request 332 can be directed towards the virtual computer resource corresponding to the compute instance that sent the work. For each request 332, the rolling resource credit remaining amount scheduler now determines the current resource credit remaining amount for the requesting compute instance 330 and generates a scheduling instruction to apply the resource credits when making a work request. Can be configured. In some embodiments, the rolling resource credit residual scheduler 324 executes a scheduling instruction or orders the execution of a scheduling instruction to direct a work request to the physical computing resource 340 underlying the execution target. , Or can be sent. For example, in some embodiments, different hardware queues are implemented and the rolling resource credit remaining amount scheduler 324 follows the applied resource credits (eg, queuing tasks according to the amount of time applied resource credits). , Can be used to place tasks for making work requests in queues. However, in some embodiments, the resource scheduling instruction may be sent to the virtual computing resource scheduler 322, the virtual computing resource scheduler 322 may be implemented on the virtualization host 310, such as a physical CPU (s). It may be a scheduler for various resources 340. The rolling resource credit remaining amount scheduler 324 applies the resource credits, deducts the resource credits, and / or otherwise ensures that the work request is performed according to the applied resource credits, FIGS. May be configured to perform the various techniques described below.

いくつかの実施形態では、スケジューリング命令を受信することに応えて、仮想計算リソーススケジューラ322は、様々な実施形態では、作業要求336に対する物理的なスケジューリング命令を物理的なCPU(複数可)などの物理的なコンピューティングリソースに提供し得る。少なくともいくつかの実施形態では、仮想計算リソーススケジューラ322は、1つ以上のCPUに対するクレジットベースのスケジューラであっても良い。 In some embodiments, in response to receiving a scheduling instruction, the virtual computing resource scheduler 322, in various embodiments, issues a physical scheduling instruction for work request 336, such as a physical CPU (s). Can be provided for physical computing resources. In at least some embodiments, the virtual compute resource scheduler 322 may be a credit-based scheduler for one or more CPUs.

ローリングリソースクレジット残量スケジューラ324はクレジット残量及び使用量指標362を監視エージェント326にさらに報告しても良く、監視エージェント326は、次にこれらの指標を任意の他のホスト指標364(健全性情報等)と共にリソース監視モジュール218に報告しても良い。 The rolling resource credit remaining amount scheduler 324 may further report the credit remaining amount and usage index 362 to the monitoring agent 326, which in turn reports these indicators to any other host index 364 (health information). Etc.) and may be reported to the resource monitoring module 218.

図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 resource credit interface 400 can be implemented as a network-based site accessible to various clients. In some embodiments, the rolling resource credit interface 400 is as a downloadable application or a locally executed application that can communicate with a network-based virtual computing resource provider via a programmatic interface such as an API. Can be implemented.

エリア410は、指標データが表示され得る様々なインスタンスのリストを例示する。セレクタ412a、412b、412c、414a、414b及び414cなどの様々な異なるユーザインターフェース要素を実装して、どの物理的なリソース及び特定のインスタンスデータを読み出すべきかを示しても良い。エリア420は、表示用に選択され得る異なる種類の指標データを例示する。例えば、いくつかの実施形態では、特定のインスタンスに対するリソースクレジット残量指標422、及び選択されたインスタンスによるリソースクレジット使用量424を選択しても良い。いくつかの実施形態では、特定のインスタンスに対するクレジット更新率が例示され得る。エリア430はインスタンス指標表示エリアを表し得る。読み出されたインスタンス指標は様々な形式(例示の線グラフ、図、表または任意の他の図式またはテキストデータ表現技法など)で表示されても良い。エリア440は表示された指標データの形式を変更するための異なるユーザインターフェース要素を表し得る。例えば、表示設定444が選択されると、ポップウィンドウまたはダイアログボックスが開き、これによりデータを表示する時間範囲などの異なる表示設定を修正することが可能になり得る。表示指標要素442が選択されると、行われた変更が実行され、インスタンス指標表示430に表示されるデータを生成または再生成し得る。エクスポート指標446要素はユーザにより指定された場所にダウンロードまたは記憶される未処理の指標データを抽出するための様々な機構を提供するように構成され得る(例えば、ファイルダイアログウィンドウを開く)。ツール要素448は、指標データを基に、様々な異なるツール、分析または他の推奨エンジンを実行するように選択可能であり得る。例えば、インスタンス種類を(例えば、より大きいまたはより小さいバースト処理インスタンスに)変更するかどうかを推奨するツールが選択され得る。 Area 410 illustrates a list of various instances in which indicator data can be displayed. Various different user interface elements such as selectors 412a, 412b, 412c, 414a, 414b and 414c may be implemented to indicate which physical resources and specific instance data should be read. Area 420 illustrates different types of indicator data that may be selected for display. For example, in some embodiments, the resource credit remaining index 422 for a particular instance and the resource credit usage 424 by the selected instance may be selected. In some embodiments, the credit renewal rate for a particular instance may be exemplified. Area 430 may represent an instance index display area. The retrieved instance indicators may be displayed in various formats, such as an exemplary line graph, diagram, table or any other diagram or text data representation technique. Area 440 may represent different user interface elements for changing the format of the displayed indicator data. For example, when display setting 444 is selected, a pop window or dialog box may open, which may allow modification of different display settings, such as the time range for displaying data. When the indicator element 442 is selected, the changes made may be made to generate or regenerate the data displayed on the instance indicator display 430. The export metric 446 element may be configured to provide various mechanisms for extracting raw metric data downloaded or stored at a location specified by the user (eg, opening a file dialog window). Tool element 448 may be selectable to perform a variety of different tools, analyzes or other recommended engines based on the indicator data. For example, a tool may be selected that recommends whether to change the instance type (eg, to a larger or smaller burst processing instance).

図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 Clause 14, which causes each of the plurality of different work requests to record one or more applied resource credits as a credit usage index.

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 Clause 15, which provides notification of the alarm event to the virtual computing instance in response to detection of the alarm event.

17.前記1つ以上の計算リソースが1つ以上のネットワーキングリソースであり、前
記1つ以上の物理的なコンピュータリソースが1つ以上のネットワーク通信デバイスである、条項14に記載の非一時的コンピュータ可読記憶媒体。
17. The non-temporary computer-readable storage medium according to Clause 14, wherein the one or more computational resources are one or more networking resources and the one or more physical computer resources are one or more network communication devices. ..

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 Clause 14, which constitutes and enforces at least one of the instructions.

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 Clause 14, which enforces exclusion from the remaining resource credits of.

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 Clause 14, which is one and each of the different types of virtual computing instances corresponds to a different resource credit accumulation rate.

本明細書に記載の方法は、様々な実施形態では、ハードウェア及びソフトウェアの任意の組み合わせにより実装され得る。例えば、一実施形態では、方法はプロセッサに連結されるコンピュータ可読記憶媒体に記憶されるプログラム命令を実行する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 / O interface 1030. In various embodiments, the computer system 1000 is a uniprocessor system that includes one processor 1010, or a multiprocessor system that includes several processors 1010 (eg, 2, 4, 8, or other suitable numbers). It may be. Processor 1010 may be any suitable processor capable of executing instructions. For example, in various embodiments, the processor 1010 is a general purpose processor or embedded processor that implements any of various instruction set architectures (ISA) such as x86, PowerPC, SPARC or MIPS ISA or other suitable ISA. It's okay. In a multiprocessor system, each of the processors 1010 can usually implement the same ISA, but not necessarily so. The computer system 1000 further includes one or more network communication devices (eg, network interface 1040) and communicates with other systems and / or components via a communication network (eg, internet, LAN, etc.). For example, a client application running on system 1000 uses network interface 1040 on a single server or cluster of servers that implements one or more of the components of the data warehouse system described herein. You may communicate with the server application executed by. In another example, an instance of a server application running on computer system 1000 can be implemented on another computer system (eg, computer system 1090) using network interface 1040 (or another server application). ) May communicate with other instances.

例示した実施形態では、コンピュータシステム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 persistent storage devices 1060 and / or one or more I / O devices 1080. In various embodiments, the persistent storage device 1060 may accommodate disk drives, tape drives, solid state memory, other high capacity storage devices, or other persistent storage devices. The computer system 1000 (or a distributed application or operating system running on the system) may optionally store instructions and / or data in the persistent storage device 1060, requiring the stored instructions and / or data. You may search according to. For example, in some embodiments, the computer system 1000 may host a storage system server node, and the persistent storage 1060 may include an SSD attached to that server node.

コンピュータシステム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, DDR 10 RAM, synchronous dynamic RAM (eg, one or more caches, static random access memory (SRAM), DRAM, RDRAM, EDO RAM, DDR 10 RAM, synchronous dynamic RAM). It can be implemented using SRAM), Rambus RAM, EEPROM, non-volatile / flash memory, or any other type of memory. System memory 1020 may include program instructions 1025 that can be executed by processor 1010 (s) to implement the methods and techniques described herein. In various embodiments, the program instruction 1025 is a platform native binary, any interpreted language such as Java® bytecode, or any other language such as C / C ++, Java®, etc. Or it can be encoded in any combination of them. For example, in the illustrated embodiment, the program instruction 1025 includes, in different embodiments, an executable program instruction to implement the functionality of the virtual computing resource provider network. In some embodiments, program instruction 1025 may implement multiple individual clients, server nodes and / or other components.

いくつかの実施形態では、プログラム命令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, program instruction 1025 may include instructions that can be executed to implement an operating system (not shown), which operating system is UNIX®, LINUX, Solaris®. ), MacOS®, Windows®, and any other operating system. Any or all of the program instructions 1025 may be provided as computer program products or software. This computer program product or software may include a non-temporary computer-readable storage medium in which instructions are stored, and various embodiments may be made by programming a computer system (or other electronic device) using this medium. You may execute the process according to. The non-temporary computer-readable storage medium may include any mechanism for storing information in a form readable by a machine (eg, a computer) (eg, software, processing application). Generally speaking, non-temporary computer-accessible media may include computer-readable storage media or memory media. Such media include magnetic or optical media, such as a disc or DVD / CD-ROM connected to the computer system 1000 via the I / O interface 1030. The non-temporary computer-readable storage medium may also include any volatile or non-volatile medium such as RAM (eg, SDRAM, DDR SDRAM, RDRAM, SRAM, etc.), ROM, and the like. These media may be included as system memory 1020 or another type of memory in some embodiments of computer system 1000. In other embodiments, the program instruction is an optical, acoustic or other form of propagating signal (eg,) transmitted over a communication medium such as a network and / or wireless link such that it can be implemented via network interface 1040. It can be transmitted using carrier waves, infrared signals, digital signals, etc.).

いくつかの実施形態では、システムメモリ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), persistent storage 1060 and / or remote storage 1070 is a data block, a replica of a data block, a data block and / or a meta associated with their state. Data, configuration information, and / or any other information that can be used to implement the methods and techniques described herein may be stored.

一実施形態では、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 / O interface 1030 coordinates I / O traffic between the processor 1010, system memory 1020 and any peripheral device in the system, including through network interface 1040 or other peripheral interfaces. Can be configured as In some embodiments, the I / O interface 1030 performs any required protocol conversion, timing conversion or other data conversion and configures the data signal from one component (eg, system memory 1020) into another. It can be converted into a format suitable for use by the element (eg, processor 1010). In some embodiments, the I / O interface 1030 is mounted through various types of peripheral buses, such as variants of the Peripheral Component Interconnect (PCI) bus standard or the Universal Serial Bus (USB) standard. It can also include device support. In some embodiments, the functionality of the I / O interface 1030 can be divided into two or more separate components, such as a north bridge and a south bridge. Further, in some embodiments, some or all of the functionality of the I / O interface 1030, such as an interface with the system memory 1020, may be incorporated directly into the processor 1010.

ネットワークインターフェース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 / O devices 1050 and / or remote storage 1070. The input / output device 1050, in some embodiments, is a data from one or more display terminals, a keyboard, a keypad, a touchpad, a scanning device, a voice recognition device or an optical recognition device, or one or more computer systems 1000. Other devices suitable for input or search may be included. The plurality of input / output devices 1050 may exist in the computer system 1000, or may be distributed to various nodes of the distributed system including the computer system 1000. In some embodiments, similar input / output devices may be separated from the computer system 1000 and may be connected to one or more nodes of the distributed system, including the computer system 1000, by wire or wirelessly, such as through a network interface 1040. You may interact through. The network interface 1040 may typically support one or more wireless networking protocols (eg, Wi-Fi / IEEE 802.11, or another wireless networking standard). However, in various embodiments, the network interface 1040 may support communication over any suitable wired or wireless general data network, such as other types of Ethernet networks. In addition, the network interface 1040 is via a telecommunications network / telephone network such as an analog voice network or digital fiber communication network, a storage area network such as a fiber channel SAN, or any other suitable type of network and / or protocol. Can support communication. In various embodiments, the computer system 1000 comprises more components, fewer components, or different components (eg, displays, video cards, audio cards, peripherals) than those illustrated in FIG. Other network interfaces such as devices, ATM interfaces, Ethernet interfaces, frame relay interfaces, etc.) may be included.

本明細書に記載された分散システムの任意の実施形態、またはそれらの任意の構成要素は、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つ以上の生成されたスケジューリング命令の少なくとも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に記載の方法。 The generated scheduling instructions include the utilization of the one or more computer resources by the virtual computing instance in a time interval during which the utilization of the one or more computer resources is gradually reduced to the baseline utilization. The method of claim 1, wherein the method is gradually reduced by a plurality of increments diffused over the time increase of. 前記1つ以上のコンピュータリソースは1つ以上の中央処理装置(CPU)を備え、更に前記1つ以上のスケジューリング命令を前記1つ以上のCPUに対するスケジューラに送信することを備える、請求項1または2に記載の方法。 Claim 1 or 2, wherein the one or more computer resources include one or more central processing units (CPUs), and further comprises transmitting the one or more scheduling instructions to a scheduler for the one or more CPUs. The method described in. 前記ベースライン活用は処理容量に対する保証されたベースラインを備える、請求項3に記載の方法。 The method of claim 3, wherein the baseline utilization comprises a guaranteed baseline for processing capacity. 前記1つ以上のコンピュータリソースは1つ以上のネットワーキングチャネルを備え、更に前記1つ以上のネットワーキングチャネルに対するスケジューラに前記1つ以上のスケジューリング命令を送信することを備える、請求項1−4のいずれか一項に記載の方法。 One or more of claims 1-4, wherein the one or more computer resources include one or more networking channels and further comprises transmitting the one or more scheduling instructions to the scheduler for the one or more networking channels. The method described in paragraph 1. 前記ベースライン活用はネットワーキングチャネルに対する保証されたベースライン性能率を備える、請求項5に記載の方法。 The method of claim 5, wherein the baseline utilization comprises a guaranteed baseline performance rate for the networking channel. 前記仮想計算インスタンスは、ネットワークベースの仮想コンピューティングサービスを介して供給される複数の異なる種類の仮想計算インスタンスのうちの1つであり、前記仮想計算インスタンスのそれぞれは、個別に更新されるそれぞれのリソースクレジット残量を有する、請求項1−6のいずれか一項に記載の方法。 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 method according to any one of claims 1-6, which has a remaining amount of resource credits. 前記ネットワークベースの仮想コンピューティングサービスを介して供給される前記仮想計算インスタンスのうちの少なくともいくつかは、前記ネットワークベースの仮想コンピューティングサービスを介して供給される前記仮想計算インスタンスのうちの他のものとは異なるリソースクレジット割り当て率を有する、請求項7に記載の方法。 At least some of the virtual computing instances delivered through the network-based virtual computing service are others of the virtual computing instances served through the network-based virtual computing service. 7. The method of claim 7, which has a resource credit allocation rate different from that of. 前記ネットワークベースの仮想コンピューティングサービスを介して供給される前記仮想計算インスタンスのうちの少なくともいくつかは、前記ネットワークベースの仮想コンピューティングサービスを介して供給される前記仮想計算インスタンスのうちの他のものとは異なるベースライン活用のレベルを有する、請求項7または8に記載の方法。 At least some of the virtual computing instances delivered through the network-based virtual computing service are others of the virtual computing instances served through the network-based virtual computing service. The method of claim 7 or 8, which has a different level of baseline utilization than. 1つ以上の非一時的なコンピュータ読み取り可能な記憶媒体に連結される1つ以上のプロセッサを含むシステムであって、前記コンピュータ読み取り可能な記憶媒体は、プログラム命令を格納し、前記プログラム命令は、前記1つ以上のぷろっさにより実行されると、前記システムに、
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.
前記生成されたスケジューリング命令は、前記仮想計算インスタンスによる前記1つ以上のコンピュータリソースの活用を、前記1つ以上のコンピュータリソースの活用が前記ベースライン活用まで徐々に低下される間の時間区間における複数の時間増加分にわたり拡散される複数の増分によって徐々に低下させる、請求項10に記載のシステム。 The generated scheduling instructions include the utilization of the one or more computer resources by the virtual computing instance in a time interval during which the utilization of the one or more computer resources is gradually reduced to the baseline utilization. 10. The system of claim 10, wherein the system is gradually reduced by a plurality of increments diffused over the time increase of. 前記1つ以上のコンピュータリソースは1つ以上の中央処理装置(CPU)を備え、更に前記1つ以上のスケジューリング命令を前記1つ以上のCPUに対するスケジューラに送信することを備える、請求項10または11に記載のシステム。 10. The system described in. 前記1つ以上のコンピュータリソースは1つ以上のネットワーキングチャネルを備え、更に前記1つ以上のネットワーキングチャネルに対するスケジューラに前記1つ以上のスケジューリング命令を送信することを備える、請求項10−12のいずれか一項に記載のシステム。 One of claims 10-12, wherein the one or more computer resources comprises one or more networking channels and further comprises transmitting the one or more scheduling instructions to the scheduler for the one or more networking channels. The system described in paragraph 1. 前記ベースライン活用は処理容量に対する保証されたベースラインおよびネットワーキングチャネルに対する保証されたベースライン性能率を備える、請求項13に記載のシステム。 13. The system of claim 13, wherein the baseline utilization comprises a guaranteed baseline for processing capacity and a guaranteed baseline performance rate for networking channels. 前記仮想計算インスタンスは、ネットワークベースの仮想コンピューティングサービスを介して供給される複数の異なる種類の仮想計算インスタンスのうちの1つであり、前記仮想計算インスタンスのそれぞれは、個別に更新されるそれぞれのリソースクレジット残
量を有する、請求項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.
JP2021075891A 2014-06-27 2021-04-28 Rolling resource credits for scheduling virtual computer resources Active JP7189997B2 (en)

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)

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

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

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

Patent Citations (4)

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