WO2022026426A1 - Scheduling workloads on a common set of resources by multiple schedulers operating independently - Google Patents
Scheduling workloads on a common set of resources by multiple schedulers operating independently Download PDFInfo
- Publication number
- WO2022026426A1 WO2022026426A1 PCT/US2021/043248 US2021043248W WO2022026426A1 WO 2022026426 A1 WO2022026426 A1 WO 2022026426A1 US 2021043248 W US2021043248 W US 2021043248W WO 2022026426 A1 WO2022026426 A1 WO 2022026426A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- workloads
- scheduler
- scheduling
- cluster
- resources
- Prior art date
Links
- 230000005012 migration Effects 0.000 claims abstract description 10
- 238000013508 migration Methods 0.000 claims abstract description 10
- 238000012423 maintenance Methods 0.000 claims abstract description 5
- 238000000034 method Methods 0.000 claims description 46
- 238000007726 management method Methods 0.000 description 18
- 230000008569 process Effects 0.000 description 12
- 238000010586 diagram Methods 0.000 description 10
- 230000006870 function Effects 0.000 description 9
- 230000006855 networking Effects 0.000 description 7
- 239000003795 chemical substances by application Substances 0.000 description 5
- 238000004590 computer program Methods 0.000 description 5
- 238000007792 addition Methods 0.000 description 2
- 238000013500 data storage Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 238000013467 fragmentation Methods 0.000 description 1
- 238000006062 fragmentation reaction Methods 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000002955 isolation Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 238000013468 resource allocation Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/4881—Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5011—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/505—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the load
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
- G06F9/5077—Logical partitioning of resources; Management or configuration of virtualized resources
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/4557—Distribution of virtual machine instances; Migration and load balancing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/48—Indexing scheme relating to G06F9/48
- G06F2209/485—Resource constraint
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/505—Clust
Definitions
- VMs virtual machines
- application services application services
- Kubernetes® a container orchestration platform known as Kubernetes® has gained in popularity among application developers.
- Kubernetes provides a platform for automating deployment, scaling, and operations of application containers across clusters of hosts. It offers flexibility in application development and offers several useful tools for scaling.
- a node includes an operating system (OS), such as Linux®, and a container engine executing on top of the OS that supports the containers of the pod.
- OS operating system
- Kubernetes control plane components e.g., a kubelet
- a node includes multiple containers and control plane components executing on a shared OS.
- Kubernetes nodes can be implemented in a virtualized computing system including a cluster of hosts having a virtualization layer executing on host hardware platforms to support execution of virtual machines (VMs).
- VMs virtual machines
- each host in the cluster operates as a Kubernetes node and Kubernetes pods are implemented as VMs (hereinafter referred to as “pod VMs”), each of which includes an OS and a container engine that supports execution of containers therein.
- pod VMs each of which includes an OS and a container engine that supports execution of containers therein.
- Such a Kubernetes system further includes other VMs that implement the Kubernetes control plane components and support applications implemented using the pod VMs.
- the integration of the Kubemetes control plane into the virtualization computing system results in scheduling complexities because the Kubemetes control plane employs a scheduler for placing pods on nodes (which, in the integrated system, means pod VMs being scheduled on hosts of the cluster), and the virtualization computing system employs a scheduler for placing VMs, including pod VMs, on the same hosts of the cluster. These schedulers, each running its own scheduling algorithm, may decide on different hosts to place a pod VM.
- U.S. Patent Application No. 16/681,990 discloses a technique in which the VM scheduler cooperates with a Kubemetes scheduler when placing pod VMs on a cluster of hosts, in this technique, the Kubemetes scheduler includes an extension which communicates with the VM scheduler to request and acquire a host recommendation when placing a pod VM on the cluster of hosts.
- One or more embodiments provide a method for scheduling workloads using at least two schedulers that operate independently.
- the workloads may be virtual objects, including VMs, and also operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode.
- these workloads are scheduled on a common set of resources that are distributed across a cluster of hosts. These resources include CPU, memory, network, and storage.
- the at least two independent schedulers are assigned priorities such that the higher priority scheduler is executed to schedule workloads in its inventory on the common set of resources before the lower priority scheduler is executed to schedule workloads in its inventory on the common set of resources.
- FIG. 6 Further embodiments include, without limitation, a non-transiiory computer- readable storage medium that includes instructions for a processor to carry out the above method, and a computer system that includes a processor programmed to carry out the above method.
- Figure 1 is a block diagram of a virtualized computing system in which embodiments may be implemented.
- Figure 2 is a flow' diagram depicting steps of a method carried out by a scheduler arbiter according to embodiments.
- Figure 3 is a flow diagram depicting steps of a method carried out by a resource budget allocator according to embodiments.
- Figure 4 is a flow diagram depicting steps of a method carried out by each scheduler according to embodiments.
- FIG. 5 is a block diagram of another virtualized computing system in which embodiments may be implemented.
- Figure 6 is a conceptual diagram illustrating an implementation of a distributed scheduler in the virtualized computing system of Figure 5.
- Figures 7-8 are conceptual diagrams illustrating other implementations of the distributed scheduler.
- FIG. 1 is a block diagram of a virtualized computing system 100 in which embodiments may be implemented.
- Virtualized computing system 100 includes a cluster 118 of hosts 120 that may be constructed on server- grade hardware platforms such as an x86 architecture platforms (also referred to as “host cluster 118”).
- a hardware platform 122 of each host 120 includes conventional components of a computing device, such as one or more central processing units (CPUs) 160, system memory (e.g., random access memory (RAM) 162), one or more network interface controllers (NICs) 164, and optionally local storage 163.
- CPUs 160 are configured to execute instructions, for example, executable instructions that perform one or more operations described herein, which may be stored in RAM 162.
- NICs 164 enable host 120 to communicate with other devices through a network 180.
- Network 180 is a physical network that enables communication between hosts 120 and between other components and hosts 120 (other components discussed further herein).
- hosts 120 access shared storage 170 by using NICs 164 to connect to network 180.
- each host 120 contains a host bus adapter (FIBA) through which input/output operations (IDs) are sent to shared storage 170 over a separate network (e.g., a fibre channel (FC) network).
- FIBA host bus adapter
- shared storage 170 includes one or more storage arrays, such as a storage area network (SAN), network attached storage (NAS), or the like.
- SAN storage area network
- NAS network attached storage
- shared storage 170 may comprise magnetic disks, solid-state disks, flash memory, and the like as well as combinations thereof.
- hosts 120 include local storage 163 (e.g., hard disk drives, solid-state drives, etc.).
- Hypervisor 150 abstracts processor, memory, storage, and network resources of hardware platform 122 to provide a virtual machine execution space within which multiple virtual machines (VM) may be concurrently instantiated and executed.
- hypervisor 150 is a VMware ESXiTM hypervisor provided as part of the VMware vSphere® solution made commercially available by VMware, Inc. of Palo Alto, CA.
- VMs executing on each host 120 include pod VMs 130 and native VMs 140.
- a pod VM 130 is a virtual machine that includes an OS and container engine dial supports execution of containers, as well as an agent (referred to as a pod VM agent) that cooperates with a controller of orchestration control plane 115 executing in hypervisor 150 (referred to as a pod VM controller).
- Some native VMs 140 have specific functions within host cluster 118, such as control VMs 143 and support, VMs 145.
- Control VMs 143 are VMs that implement control planes as described further herein.
- Support VMs 145 are VMs that are created by a control plane to support applications implemented using pod VMs 130 and/or native VMs 140.
- Software platform 124 is configured with software-defined (SD) networking
- SD networking 175 includes a data plane having various logical components, such as routers, switches, gateways, firewalls, load balancers, and the like, coupled to form logical networks that overlay network 180.
- the terms “logical” and “virtual” are used interchangeably herein with respect, to SD networking 175.
- SD networking 175 includes a control plane configured to manage the data plane. Some components of the control and data planes are implemented as support VMs 145 (e.g., logical router control VMs, load balancers, edge gateways, etc.). Other components are implemented as part of hypervisor 150 (e.g., logical switches, logical routers, distributed firewalls, etc.).
- VM management server 116 is a physical or virtual server that provisions VMs from the hardware resources of hosts 120.
- VM management server 116 installs a control plane agent 152 in hypervisor 150 to add a host 120 to as a managed entity.
- VM management server 116 logically groups hosts 120 into cluster 1.18 to provide cluster-level functions to hosts 120, such as VM migration between hosts 120 (e.g., for load balancing), distributed power management, dynamic VM placement according to affinity and anti-affinity rules, and high- availability.
- the number of hosts 120 in the duster may be one or many.
- Each host 120 in cluster 118 has access to shared storage 170 via network 180.
- VM management server 116 can also communicate with shared storage 170 via network 180 to perform control operations thereon.
- VM management server 116 further includes a supervisor cluster service 109.
- Supervisor cluster service 109 configures host cluster 118 to be part of a supervisor cluster 119.
- Supervisor duster service 109 installs a control plane agent 152 in hypervisor 150 to add a host 120 to supervisor cluster 119.
- Supervisor duster 119 integrates an orchestration control plane, such as Kuhernetes, into host cluster 118. in supervisor duster 119, hosts 120 become nodes for use by the orchestration control plane.
- Supervisor cluster service 109 provisions one or more virtual servers as “master servers” to manage the orchestration control plane.
- supervisor cluster 119 includes a supervisor Kubemetes master 104 that functions as a master server for an orchestration control plane 115 of supervisor cluster 119.
- supervisor Kuhernetes master 104 is shown as a separate logical entity. In practice, supervisor Kuhernetes master 104 may be implemented as control VMs 143 in host, duster 118. Further, although only one supervisor Kubemetes master 104 is shown, supervisor cluster 119 can include more than one supervisor Kuhernetes master 104.
- workloads that are scheduled on resources include pod VMs 130, native VMs 140, control VMs 143, and support VMs 145. These workloads are scheduled on a common set of resources, e.g,, resources of a set of hosts 120 that belong to both host duster 118 and supervisor cluster 119, by two independent schedulers — resource scheduler 96 and Kuhernetes scheduler 105.
- a workload inventory 97 contains workloads to be scheduled by resource scheduler 96 and a workload inventory 106 contains workloads to be scheduled by Kubemetes scheduler 105.
- Resource scheduler 96 runs as a process in VM management server 116 to schedule the workloads in its workload inventory 97 on a set of hosts 120 of host cluster 118 and Kubemetes scheduler 105 runs as a process in supervisor Kuhernetes master 104 to schedule the workloads in its workload inventory 106 on the same set of hosts 120 of supervisor cluster 119.
- Workloads are added to workload inventories 97, 106 under various circumstances.
- control VMs 143 and support VMs 145 that were executing on the failed host are added to workload inventory 97 and all pod VMs 130 that were executing on that same failed host (of supervisor cluster 119) are added to workload inventor )' ⁇ 106.
- Native VMs 140 executing on the failed host which are components of the application deployed using orchestration control plane 115 are added to workload inventory ' 106.
- Other native VMs 140 are added to workload inventory 97.
- VM management server 116 further includes a scheduler arbiter 90 that enforces the order of scheduling priority given to independent schedulers.
- scheduler arbiter 90 allows resource scheduler 96 to execute (to schedule the workloads that are in its workload inventor ⁇ ' 97) prior to allowing Kubernetes scheduler 105 to execute (to schedule the workloads in its workload inventory 106).
- scheduler arbiter 90 executes a process, shown in Figure 1 as resource budget allocator 91, to set resource budgets for each of the independent schedulers.
- the resource budgets may be set at the cluster level or at the individual host level, in addition, the resource budget may be set for all or a subset of workloads managed by resource scheduler 96 or Kubernetes scheduler 105.
- the resource budget is set for a scheduler, that scheduler is prevented from scheduling any workload in its workload inventory that will cause the scheduled resource usage to be in excess of the scheduler’s resource budget.
- the resource budget is set for a subset of workloads managed by a scheduler, that scheduler is prevented from scheduling any workload in the subset and in its workload inventory that will cause the scheduled resource usage to be in excess of the scheduler’s resource budget for the subset.
- a granularity for the resource may be additionally set.
- the granularity defines the minimum size of a particular resource that can be set at the individual host level. Therefore, if the granularity for memory is 1 GB and the total memory budget across a cluster of 10 hosts is 5 GB, it will prevent the budget to he set at 0.5 GB per host across 10 hosts. Instead, the budget will be set at 1 GB (or more) across 5 hosts (or less) and 5 hosts will get a memory budget of 0 GB.
- Virtualized computing system 100 further includes storage manager 110.
- Storage manager 110 is a physical or virtual server that provisions virtual disks in shared storage 170 (or a vSAN formed from local storage 163) as independent objects. That is, virtual disks that persist apart from the lifecycle of any VM or container.
- Various components can interact with storage manager 110 to provision persistent storage, such as VM management server 116 and supervisor Kubernetes master 104.
- Storage manager 110 can operate independently from VM management server 116 (e.g., as an independent physical or virtual server).
- storage manager 110 can be a service in VM management server 116 (e.g., alongside components such as resource scheduler 108 and supervisor cluster service 109).
- Virtualized computing system 100 further includes a network manager 112.
- Network manager 112 is a physical or virtual server that manages SD networking 175 for hosts 120.
- Network manager 112 can install a control plane agent 152 in hypervisor 150 to add a host 120 as a managed entity.
- Network manager 112 configures host cluster 118 to be part of a transport zone. In such a transport zone, hosts 120 become transport nodes having shared logical networking resources.
- Network manager 112 can operate independently from VM management server 116 (e.g., as an independent physical or virtual server).
- network manager 112 can be a sendee of VM management server 116 (e.g., alongside components such as resource scheduler 108 and supervisor cluster service 109).
- a VI administrator can interact with VM management server 116 through a VM management client 101.
- a VI admin commands VM management server 116 to form host cluster 118, configure resource pools, resource allocation policies, and other cluster-level functions, configure storage and networking, and create supervisor cluster 119.
- Kubernetes client 102 represents an input interface to supervisor Kubernetes master 104.
- Kubernetes client 102 is commonly referred to as kubectl.
- a user submits desired states of the Kubernetes system, e.g., as YAML documents, to supervisor Kubernetes master 104.
- supervisor Kubernetes master 104 configures supervisor cluster 119 to match the desired state by creating pod VMs 130 and native VMs 140, connecting the VMs to storage and logical networks, destroying pod VMs 130 and native VMs 140, and the like. In this manner, the user interacts with supervisor Kubernetes master 104 to deploy applications in supervisor cluster 119.
- FIG. 2 is a flow diagram depicting steps of a method carried out by a scheduler arbiter 90 according to embodiments.
- Scheduler arbiter 90 enforces the scheduling priority of independent, schedulers by executing a high priority scheduler [process 220) prior to a low priority scheduler (process 230).
- the high priority scheduler is resource scheduler 96 and the low priority scheduler is Kubernetes scheduler 105.
- the highest priority scheduler is executed first, the second highest, priority scheduler is executed second, and so forth until all schedulers are. executed.
- Scheduler arbiter 90 also executes a process 210 (e.g., resource budget allocator
- resource budget allocator 91 to set resource budgets to each of the independent schedulers.
- the steps executed by resource budget allocator 91 are illustrated in Figure 3.
- the method of Figure 3 begins at step 310, at which resource budget allocator 91 determines if resource budgets are allocated. If no resource budget is allocated to a scheduler, no resource limit is imposed on the scheduler and the scheduler will atempt to schedule all workloads in its inventory until resources are no longer available. If resources are still available after all workloads in the scheduler’s inventory have been scheduled, the scheduler having the next highest priority will execute,
- Steps 320 and 330 are executed if resource budgets are allocated.
- resource budget allocator 91 sets the resource budget for the high priority scheduler
- resource budget allocator 91 sets the resource budget for the low priority scheduler.
- additional steps are executed to set the resource budgets for all schedulers.
- Figure 4 is a flow diagram depicting steps of a method carried out by each scheduler according to embodiments.
- the method of Figure 4 is applicable to any of the independent schedulers including the high priority scheduler and the low priority scheduler, and begins at step 410, where the scheduler selects the next workload in its inventory to schedule. Then, at step 412, the scheduler determines if there are sufficient resources for scheduling the selected workload and if the scheduling of the selected workload wdll cause it to exceed its resource budget. If there are sufficient resources for scheduling the selected workload and the scheduling of the selected workload will not cause it to exceed its resource budget (step 412, Yes), the scheduler schedules the selected workload on the resources at step 414.
- the scheduler examines the resource usage by workloads that it previously scheduled, to see if there is an opportunity to defragment (step 418). For example, if the memory requirement of a VM that needs to be scheduled is greater than what a single host in host cluster 118 can provide, a defragmentation process can be executed to live migrate one or more VMs from one host, in host cluster 118 to one or more other hosts in host cluster 118 to free up enough memory in the one host for the VM that needs to be scheduled.
- step 422 migrates to free up resources on one of the hosts in host cluster 118.
- step 414 is executed to schedule the selected wmrkload on the resources of the freed-up host, if the selected w'orkload is not a VM, which is stateful, but a different virtual object, which is stateless, migration is carried out by terminating the running instance of the virtual object in one host and instantiating the virtual object in another host.
- the opportunity to defragment to free up space for scheduling a workload by the high priority scheduler may be achieved by defragmenting workloads previously scheduled by the low priority scheduler.
- the high priority scheduler makes such a defragmentation request to the lower priority scheduler (e.g., by calling an API exposed by the low priority scheduler).
- a high priority scheduler may request a larger budget allocation from resource budget allocator 91.
- Resource budget allocator 91 fulfills this request by reducing the resource budget allocated to a low priority scheduler or by setting up a buffer of resources and allocating resources from this buffer.
- the pool of resources available in this buffer is decreased as resources are allocated from this buffer to the schedulers, and increased as resources are freed up by the schedulers and returned to this buffer.
- step 414 the scheduler determines if there are any more workloads in its inventory to schedule. If there are, the process returns to step 410, where the scheduler selects the next workload in its inventory to schedule. If there are no more, the process ends.
- Virtualized computing system 500 of Figure 5 depict an embodiment where the functions of scheduler arbiter 90, resource budget allocator 91, and resource scheduler 96 are distributed across hosts 120 in control VMs 143 of hosts 120 as a distributed scheduler 520.
- Figure 6 depicts an example where control VMs 143A, 143B, 143C running in hosts 120A, 120B, 120C, respectively, cooperate with each other to execute the functions of scheduler arbiter 90, resource budget allocator 91, resource scheduler 96, and workload inventory 97, as distributed scheduler 520A,
- the fourth control VM, control VM 143D running in host 120D is a spare control VM that is able to replace any one of control VMs 143 A, 143B, 143C that fails.
- control VM 143D is not necessary'.
- resource scheduler 96 reserves spare capacity for control VM 143D in host 120D for control VM 143D to consume when instantiated, e.g., when one of control VMs 143A, 143B, 143C goes down.
- supervisor Kubernetes master 104 including those of Kubernetes scheduler 105 and workload inventory 106 may he distributed across hosts 120 in control VMs 143 of hosts 120.
- Figure 7 illustrates a distributed scheduler 520B that implements the functionality of and Kubernetes scheduler 105 and workload inventory 106, in addition to scheduler arbiter 90, resource budget allocator 91, resource scheduler 96, and workload inventor )' ⁇ 97.
- FIG. 8 depicts another example of the distributed scheduler, distributed scheduler 520C, which implements the functionality of three independent schedulers.
- distributed scheduler 520C includes a control VM scheduler 803 for scheduling workloads in its workload inventory 804 (e.g., control VMs 143, including control VMs 143A, 143B, 143C, 143D) on the same set of resources as resource scheduler 96 and Kubernetes scheduler 105.
- Scheduler arbiter 801 is a modified version of scheduler arbiter 90.
- scheduler arbiter 801 executes a high priority scheduler, middle priority scheduler, and a low priority scheduler in that order after executing resource budget allocator 802,
- resource budget allocator 802 is modified from resource budget allocator 91 to accommodate the third independent scheduler.
- resource budget allocator 802 sets the resource budget for the middle priority scheduler, in one embodiment, control VM scheduler 803 is the high priority scheduler, resource scheduler 96 the middle priority scheduler, and Kubernetes scheduler 105 the low pri ority sehedu ler.
- VMs represent the scheduled workloads and resources of the hosts in a cluster represent the common set of resources on which the workloads are scheduled
- the scheduled workloads may be any virtual object, including virtual compute, storage, and network resources, and also operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode.
- the scheduled workloads may be any process consuming resources that need to be scheduled.
- the independent schedulers may be two or more and in some instances one scheduler may he nested inside another scheduler,
- a host-level scheduler is also executed to schedule workloads (which are scheduled thereon by the independent cluster-level schedulers as described above) on the resources of the host.
- the host-level scheduling may be carried out: in various ways, two of which are described below.
- the host-level scheduler is operating strictly according to tire same priorities as the cluster-level schedulers and allocates available capacity to the workloads scheduled on that host, by the high-priority scheduler prior to scheduling the workloads scheduled on that host by the low-priority scheduler.
- tire host-level scheduler can preempt existing low-priority workloads (which are workloads scheduled thereon by the low-priority scheduler) in favor of scheduling high-priority workloads (which are workloads scheduled thereon by the high-priority scheduler).
- the host-level scheduler operates according to resource budgets specified for the workloads.
- These resource budgets may specify three settings — reservation (amount of host resources reserved for the workload), limit (limit on the host resource usage by the workload), and share (a value that indicates scheduling priority of the workload in relation to other workloads running on the same host).
- reservation an amount of host resources reserved for the workload
- limit limit on the host resource usage by the workload
- share a value that indicates scheduling priority of the workload in relation to other workloads running on the same host.
- These resource budgets can be specified directly on the workloads or can be a consequence of how the resource budget allocated to a duster-level scheduler is divvied out to the workloads managed by that scheduler, in this second technique, the host-level scheduler cannot preempt existing low-priority workloads in favor of high-priority workloads.
- the host resources axe guaranteed once granted to the workload.
- the duster-level scheduler needs to wait on workloads to be terminated regardless of the priority assigned to the cluster- level scheduler. Once capacity frees np, the capacity can be allocated to the cluster-level scheduler based on the priority of the cluster-level scheduler.
- the allocation of resource budgets is decoupled from the processes of the cluster-level schedulers.
- each cluster-level scheduler assigns the budgets set by the decoupled resource budget allocator to the hosts.
- the cluster level scheduler takes this host-level budget allocation as input to its workload scheduling decisions. This decoupling allows the budget allocator to operate at larger time intervals than the cluster-level scheduler and it does not need to know about the workload details (e.g., placement, policies and the like).
- live migration of workloads may be carried out for purposes of defragmentation to free up resources on one or more hosts. Beyond treeing up resources through defragmentation, there may be other technical/non- technical constraints that can require a workload to be migrated.
- An example of a technical constraint is the current GPU configuration. The current GPU configuration may not allow the desired workload to be placed until existing workloads are evacuated from the host, and the GPU be reconfigured to match the requirements of the desired workload.
- An example noil- technical constraint is anti-affinity between the new workload and an existing workload. If the new workload has to be run on a host that is currently running a workload with anti-affinity to the new workload, the existing workload will need to he migrated to another host.
- Embodiments described above depict hosts as resource providers for the common set of resources on which workloads are scheduled by the independent schedulers.
- Resource providers are not limited to hosts, in further embodiments, the resource providers may be datastores onto which workloads in the. form of disks are scheduled according to various technical constraints of the disks. For example, some disks may be thinly provisioned, which means that the capacity required by these disks may grow over time. There may be other disks that require encryption or to he stored in a redundant fashion.
- the embodiments described herein may employ various computer-implemented operations involving data stored in computer systems. For example, these operations may require physical manipulation of physical quantities. Usually, though not necessarily, these quantities may take the form of electrical or magnetic signals, where the quantities or representations of the quantities can be stored, transferred, combined, compared, or otherwise manipulated. Such manipulations are often referred to in terms such as producing, identifying, determining, or comparing. Any operations described herein that form part of one or more embodiments may be useful machine operations.
- One or more embodiments of the invention also relate to a device or an apparatus for performing these operations.
- the apparatus may be specially constructed for required purposes, or the apparatus may be a general-purpose computer selectively activated or configured by a computer program stored in the computer.
- Various general-purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
- One or more embodiments of the present invention may be implemented as one or more computer programs or as one or more computer program modules embodied in computer readable media.
- the term computer readable medium refers to any data storage device that can store data which can thereafter be input to a computer system.
- Computer readable media may be based on any existing or subsequently developed technology that embodies computer programs in a manner that enables a computer to read the programs.
- Examples of computer readable media are hard drives, NAS systems, read-only memory (ROM), RAM, compact disks (CDs), digital versatile disks (DVDs), magnetic tapes, and other optical and non-optical data storage devices.
- ROM read-only memory
- RAM random access memory
- CDs compact disks
- DVDs digital versatile disks
- a computer readable medium can also be distributed over a network-coupled computer system so that the computer readable code is stored and executed in a distributed fashion.
- Virtualization systems in accordance with the various embodiments may be implemented as hosted embodiments, non-hosted embodiments, or as embodiments that blur distinctions between the two.
- various virtualization operations may be wholly or partially implemented in hardware.
- a hardware implementation may employ a look-up table for modification of storage access requests to secure non-disk data.
- the virtualization software can therefore include components of a host, console, or guest OS that perform virtualization functions.
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Hardware Redundancy (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
Workloads are scheduled on a common set of resources distributed across a cluster of hosts using at least two schedulers that operate independently. The resources include CPU, memory, network, and storage, and the workloads may be virtual objects, including VMs, and also operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode. In addition, the at least two independent schedulers are assigned priorities such that the higher priority scheduler is executed to schedule workloads in its inventory on the common set of resources before the lower priority scheduler is executed to schedule workloads in its inventory on the common set of resources.
Description
SCHEDULING WORKLOADS ON A COMMON SET OF RESOURCES BY MULTIPLE SCHEDULERS OPERATING INDEPENDENTLY
Cross-Reference to Related Applications
[0001] This application claims priority to US Non-Provisional Patent Application No.
16/943,710, entitled “SCHEDULING WORKLOADS ON A COMMON SET OL RESOURCES BY MULTIPLE SCHEDULERS OPERATING INDEPENDENTLY” and filed on July 30, 2020, which is incorporated by reference as if set forth herein in its entirety. Background
[0002] Applications today are deployed onto a combination of virtual machines (VMs), containers, application services, and more. For deploying such applications, a container orchestration platform known as Kubernetes® has gained in popularity among application developers. Kubernetes provides a platform for automating deployment, scaling, and operations of application containers across clusters of hosts. It offers flexibility in application development and offers several useful tools for scaling.
[0003] In a Kubernetes system, containers are grouped into a logical unit called a
“pod.” Containers in the same pod share the same resources and network and maintain a degree of isolation from containers in other pods. The pods are distributed across nodes of the Kubernetes system and an image cache is provided on each node to speed up pod deployment. A node includes an operating system (OS), such as Linux®, and a container engine executing on top of the OS that supports the containers of the pod. Kubernetes control plane components (e.g., a kubelet) execute on the OS alongside the containers. Thus, a node includes multiple containers and control plane components executing on a shared OS.
[0004] Kubernetes nodes can be implemented in a virtualized computing system including a cluster of hosts having a virtualization layer executing on host hardware platforms to support execution of virtual machines (VMs). in this system, each host in the cluster operates as a Kubernetes node and Kubernetes pods are implemented as VMs (hereinafter referred to as “pod VMs”), each of which includes an OS and a container engine that supports execution of containers therein. Such a Kubernetes system further includes other VMs that implement the Kubernetes control plane components and support applications implemented using the pod VMs.
[0005] The integration of the Kubemetes control plane into the virtualization computing system results in scheduling complexities because the Kubemetes control plane employs a scheduler for placing pods on nodes (which, in the integrated system, means pod VMs being scheduled on hosts of the cluster), and the virtualization computing system employs a scheduler for placing VMs, including pod VMs, on the same hosts of the cluster. These schedulers, each running its own scheduling algorithm, may decide on different hosts to place a pod VM.
[0006] U.S. Patent Application No. 16/681,990 discloses a technique in which the VM scheduler cooperates with a Kubemetes scheduler when placing pod VMs on a cluster of hosts, in this technique, the Kubemetes scheduler includes an extension which communicates with the VM scheduler to request and acquire a host recommendation when placing a pod VM on the cluster of hosts.
Summary
[0007] One or more embodiments provide a method for scheduling workloads using at least two schedulers that operate independently. The workloads may be virtual objects, including VMs, and also operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode. According to embodiments, these workloads are scheduled on a common set of resources that are distributed across a cluster of hosts. These resources include CPU, memory, network, and storage. In addition, the at least two independent schedulers are assigned priorities such that the higher priority scheduler is executed to schedule workloads in its inventory on the common set of resources before the lower priority scheduler is executed to schedule workloads in its inventory on the common set of resources.
[6668] Further embodiments include, without limitation, a non-transiiory computer- readable storage medium that includes instructions for a processor to carry out the above method, and a computer system that includes a processor programmed to carry out the above method.
Brief Description. of the Drawings
[6609] Figure 1 is a block diagram of a virtualized computing system in which embodiments may be implemented.
[6616] Figure 2 is a flow' diagram depicting steps of a method carried out by a scheduler arbiter according to embodiments.
[0011] Figure 3 is a flow diagram depicting steps of a method carried out by a resource budget allocator according to embodiments.
[0012] Figure 4 is a flow diagram depicting steps of a method carried out by each scheduler according to embodiments.
[0013] Figure 5 is a block diagram of another virtualized computing system in which embodiments may be implemented.
[0014] Figure 6 is a conceptual diagram illustrating an implementation of a distributed scheduler in the virtualized computing system of Figure 5.
[0015] Figures 7-8 are conceptual diagrams illustrating other implementations of the distributed scheduler.
Detailed Description
[0016] Figure 1 is a block diagram of a virtualized computing system 100 in which embodiments may be implemented. Virtualized computing system 100 includes a cluster 118 of hosts 120 that may be constructed on server- grade hardware platforms such as an x86 architecture platforms (also referred to as “host cluster 118”). As shown, a hardware platform 122 of each host 120 includes conventional components of a computing device, such as one or more central processing units (CPUs) 160, system memory (e.g., random access memory (RAM) 162), one or more network interface controllers (NICs) 164, and optionally local storage 163. CPUs 160 are configured to execute instructions, for example, executable instructions that perform one or more operations described herein, which may be stored in RAM 162. NICs 164 enable host 120 to communicate with other devices through a network 180. Network 180 is a physical network that enables communication between hosts 120 and between other components and hosts 120 (other components discussed further herein).
[0017] In the embodiment illustrated in Figure 1, hosts 120 access shared storage 170 by using NICs 164 to connect to network 180. In another embodiment, each host 120 contains a host bus adapter (FIBA) through which input/output operations (IDs) are sent to shared storage 170 over a separate network (e.g., a fibre channel (FC) network). Shared storage 170 includes one or more storage arrays, such as a storage area network (SAN), network attached storage (NAS), or the like. Shared storage 170 may comprise magnetic disks, solid-state disks, flash memory, and the like as well as combinations thereof. In some embodiments, hosts 120 include local storage 163 (e.g., hard disk drives, solid-state drives, etc.). Local storage 163 in each host 120 can be aggregated and provisioned as part of a virtual SAN (vSAN), which is another form of shared storage 170.
[0018] A software platform 124 of each host 120 provides a virtualization layer, referred to herein as a hypervisor 150. Hypervisor 150 abstracts processor, memory, storage, and network resources of hardware platform 122 to provide a virtual machine execution space within which multiple virtual machines (VM) may be concurrently instantiated and executed. One example of hypervisor 150 that may be configured and used in embodiments described herein is a VMware ESXi™ hypervisor provided as part of the VMware vSphere® solution made commercially available by VMware, Inc. of Palo Alto, CA. As shown in Figure 1, VMs executing on each host 120 include pod VMs 130 and native VMs 140. A pod VM 130 is a virtual machine that includes an OS and container engine dial supports execution of containers, as well as an agent (referred to as a pod VM agent) that cooperates with a controller of orchestration control plane 115 executing in hypervisor 150 (referred to as a pod VM controller). Some native VMs 140 have specific functions within host cluster 118, such as control VMs 143 and support, VMs 145. Control VMs 143 are VMs that implement control planes as described further herein. Support VMs 145 are VMs that are created by a control plane to support applications implemented using pod VMs 130 and/or native VMs 140.
[0019] Software platform 124 is configured with software-defined (SD) networking
175. SD networking 175 includes a data plane having various logical components, such as routers, switches, gateways, firewalls, load balancers, and the like, coupled to form logical networks that overlay network 180. The terms “logical” and “virtual” are used interchangeably herein with respect, to SD networking 175. SD networking 175 includes a control plane configured to manage the data plane. Some components of the control and data planes are implemented as support VMs 145 (e.g., logical router control VMs, load balancers, edge gateways, etc.). Other components are implemented as part of hypervisor 150 (e.g., logical switches, logical routers, distributed firewalls, etc.).
[0020] VM management server 116 is a physical or virtual server that provisions VMs from the hardware resources of hosts 120. VM management server 116 installs a control plane agent 152 in hypervisor 150 to add a host 120 to as a managed entity. VM management server 116 logically groups hosts 120 into cluster 1.18 to provide cluster-level functions to hosts 120, such as VM migration between hosts 120 (e.g., for load balancing), distributed power management, dynamic VM placement according to affinity and anti-affinity rules, and high- availability. The number of hosts 120 in the duster may be one or many. Each host 120 in cluster 118 has access to shared storage 170 via network 180. VM management server 116 can
also communicate with shared storage 170 via network 180 to perform control operations thereon.
[0021] VM management server 116 further includes a supervisor cluster service 109.
Supervisor cluster service 109 configures host cluster 118 to be part of a supervisor cluster 119. Supervisor duster service 109 installs a control plane agent 152 in hypervisor 150 to add a host 120 to supervisor cluster 119. Supervisor duster 119 integrates an orchestration control plane, such as Kuhernetes, into host cluster 118. in supervisor duster 119, hosts 120 become nodes for use by the orchestration control plane.
[0022] Supervisor cluster service 109 provisions one or more virtual servers as “master servers” to manage the orchestration control plane. In the embodiment of Figure I, supervisor cluster 119 includes a supervisor Kubemetes master 104 that functions as a master server for an orchestration control plane 115 of supervisor cluster 119. For purposes of clarity, supervisor Kuhernetes master 104 is shown as a separate logical entity. In practice, supervisor Kuhernetes master 104 may be implemented as control VMs 143 in host, duster 118. Further, although only one supervisor Kubemetes master 104 is shown, supervisor cluster 119 can include more than one supervisor Kuhernetes master 104.
[0023] In the embodiment illustrated in Figure I, workloads that are scheduled on resources include pod VMs 130, native VMs 140, control VMs 143, and support VMs 145. These workloads are scheduled on a common set of resources, e.g,, resources of a set of hosts 120 that belong to both host duster 118 and supervisor cluster 119, by two independent schedulers — resource scheduler 96 and Kuhernetes scheduler 105. A workload inventory 97 contains workloads to be scheduled by resource scheduler 96 and a workload inventory 106 contains workloads to be scheduled by Kubemetes scheduler 105. Resource scheduler 96 runs as a process in VM management server 116 to schedule the workloads in its workload inventory 97 on a set of hosts 120 of host cluster 118 and Kubemetes scheduler 105 runs as a process in supervisor Kuhernetes master 104 to schedule the workloads in its workload inventory 106 on the same set of hosts 120 of supervisor cluster 119.
[0024] Workloads are added to workload inventories 97, 106 under various circumstances. In one embodiment, if a host 120 fails, control VMs 143 and support VMs 145 that were executing on the failed host (of host cluster 118) are added to workload inventory 97 and all pod VMs 130 that were executing on that same failed host (of supervisor cluster 119) are added to workload inventor)'· 106. Native VMs 140 executing on the failed host, which are components of the application deployed using orchestration control plane 115 are added to workload inventory' 106. Other native VMs 140 are added to workload inventory 97.
[0025] VM management server 116 further includes a scheduler arbiter 90 that enforces the order of scheduling priority given to independent schedulers. Generally, the relative scheduling priorities of independent schedulers are predefined by the developer of virtualized computing system 100. In the embodiments illustrated herein, resource scheduler 96 is assigned the higher priority relative to Kubernetes scheduler 105. Therefore, scheduler arbiter 90 allows resource scheduler 96 to execute (to schedule the workloads that are in its workload inventor}' 97) prior to allowing Kubernetes scheduler 105 to execute (to schedule the workloads in its workload inventory 106). In some embodiments, scheduler arbiter 90 executes a process, shown in Figure 1 as resource budget allocator 91, to set resource budgets for each of the independent schedulers. The resource budgets may be set at the cluster level or at the individual host level, in addition, the resource budget may be set for all or a subset of workloads managed by resource scheduler 96 or Kubernetes scheduler 105. When the resource budget is set for a scheduler, that scheduler is prevented from scheduling any workload in its workload inventory that will cause the scheduled resource usage to be in excess of the scheduler’s resource budget. When the resource budget is set for a subset of workloads managed by a scheduler, that scheduler is prevented from scheduling any workload in the subset and in its workload inventory that will cause the scheduled resource usage to be in excess of the scheduler’s resource budget for the subset. When the resource budgets are set at the individual host level, a granularity for the resource may be additionally set. The granularity defines the minimum size of a particular resource that can be set at the individual host level. Therefore, if the granularity for memory is 1 GB and the total memory budget across a cluster of 10 hosts is 5 GB, it will prevent the budget to he set at 0.5 GB per host across 10 hosts. Instead, the budget will be set at 1 GB (or more) across 5 hosts (or less) and 5 hosts will get a memory budget of 0 GB.
[0026] Virtualized computing system 100 further includes storage manager 110.
Storage manager 110 is a physical or virtual server that provisions virtual disks in shared storage 170 (or a vSAN formed from local storage 163) as independent objects. That is, virtual disks that persist apart from the lifecycle of any VM or container. Various components can interact with storage manager 110 to provision persistent storage, such as VM management server 116 and supervisor Kubernetes master 104. Storage manager 110 can operate independently from VM management server 116 (e.g., as an independent physical or virtual server). Alternatively, storage manager 110 can be a service in VM management server 116 (e.g., alongside components such as resource scheduler 108 and supervisor cluster service 109).
[0027] Virtualized computing system 100 further includes a network manager 112.
Network manager 112 is a physical or virtual server that manages SD networking 175 for hosts 120. Network manager 112 can install a control plane agent 152 in hypervisor 150 to add a host 120 as a managed entity. Network manager 112 configures host cluster 118 to be part of a transport zone. In such a transport zone, hosts 120 become transport nodes having shared logical networking resources. Network manager 112 can operate independently from VM management server 116 (e.g., as an independent physical or virtual server). Alternatively, network manager 112 can be a sendee of VM management server 116 (e.g., alongside components such as resource scheduler 108 and supervisor cluster service 109).
[0028] A VI administrator (VI admin) can interact with VM management server 116 through a VM management client 101. Through VM management client 101, a VI admin commands VM management server 116 to form host cluster 118, configure resource pools, resource allocation policies, and other cluster-level functions, configure storage and networking, and create supervisor cluster 119.
[0029] Kubernetes client 102 represents an input interface to supervisor Kubernetes master 104. Kubernetes client 102 is commonly referred to as kubectl. Through Kubernetes client 102, a user submits desired states of the Kubernetes system, e.g., as YAML documents, to supervisor Kubernetes master 104. In response, supervisor Kubernetes master 104 configures supervisor cluster 119 to match the desired state by creating pod VMs 130 and native VMs 140, connecting the VMs to storage and logical networks, destroying pod VMs 130 and native VMs 140, and the like. In this manner, the user interacts with supervisor Kubernetes master 104 to deploy applications in supervisor cluster 119.
[0030] Figure 2 is a flow diagram depicting steps of a method carried out by a scheduler arbiter 90 according to embodiments. Scheduler arbiter 90 enforces the scheduling priority of independent, schedulers by executing a high priority scheduler [process 220) prior to a low priority scheduler (process 230). In the embodiment illustrated in Figure 1, the high priority scheduler is resource scheduler 96 and the low priority scheduler is Kubernetes scheduler 105. In embodiments with more than two independent schedulers, the highest priority scheduler is executed first, the second highest, priority scheduler is executed second, and so forth until all schedulers are. executed.
[0031] Scheduler arbiter 90 also executes a process 210 (e.g., resource budget allocator
91) to set resource budgets to each of the independent schedulers. The steps executed by resource budget allocator 91 are illustrated in Figure 3. The method of Figure 3 begins at step 310, at which resource budget allocator 91 determines if resource budgets are allocated. If no
resource budget is allocated to a scheduler, no resource limit is imposed on the scheduler and the scheduler will atempt to schedule all workloads in its inventory until resources are no longer available. If resources are still available after all workloads in the scheduler’s inventory have been scheduled, the scheduler having the next highest priority will execute,
[0032] Steps 320 and 330 are executed if resource budgets are allocated. At step 320, resource budget allocator 91 sets the resource budget for the high priority scheduler, and at step 330, resource budget allocator 91 sets the resource budget for the low priority scheduler. In embodiments with more than two independent schedulers, additional steps are executed to set the resource budgets for all schedulers.
[0033] Figure 4 is a flow diagram depicting steps of a method carried out by each scheduler according to embodiments. The method of Figure 4 is applicable to any of the independent schedulers including the high priority scheduler and the low priority scheduler, and begins at step 410, where the scheduler selects the next workload in its inventory to schedule. Then, at step 412, the scheduler determines if there are sufficient resources for scheduling the selected workload and if the scheduling of the selected workload wdll cause it to exceed its resource budget. If there are sufficient resources for scheduling the selected workload and the scheduling of the selected workload will not cause it to exceed its resource budget (step 412, Yes), the scheduler schedules the selected workload on the resources at step 414. On the other hand, if the resources for scheduling the selected w'orkload are insufficient or the scheduling of the selected workload will cause the scheduler to exceed its resource budget (step 412, No), the scheduler examines the resource usage by workloads that it previously scheduled, to see if there is an opportunity to defragment (step 418). For example, if the memory requirement of a VM that needs to be scheduled is greater than what a single host in host cluster 118 can provide, a defragmentation process can be executed to live migrate one or more VMs from one host, in host cluster 118 to one or more other hosts in host cluster 118 to free up enough memory in the one host for the VM that needs to be scheduled. If there is no opportunity to defragment, an error is returned at step 420, If" there is opportunity to defragment, migration is carried out at step 422 to free up resources on one of the hosts in host cluster 118. Upon completion of the migration, step 414 is executed to schedule the selected wmrkload on the resources of the freed-up host, if the selected w'orkload is not a VM, which is stateful, but a different virtual object, which is stateless, migration is carried out by terminating the running instance of the virtual object in one host and instantiating the virtual object in another host.
[0034] In some embodiments, the opportunity to defragment to free up space for scheduling a workload by the high priority scheduler may be achieved by defragmenting workloads previously scheduled by the low priority scheduler. In such a case, the high priority scheduler makes such a defragmentation request to the lower priority scheduler (e.g., by calling an API exposed by the low priority scheduler).
[0035] In further embodiments, a high priority scheduler may request a larger budget allocation from resource budget allocator 91. Resource budget allocator 91. fulfills this request by reducing the resource budget allocated to a low priority scheduler or by setting up a buffer of resources and allocating resources from this buffer. The pool of resources available in this buffer is decreased as resources are allocated from this buffer to the schedulers, and increased as resources are freed up by the schedulers and returned to this buffer.
[0036] After step 414, the scheduler determines if there are any more workloads in its inventory to schedule. If there are, the process returns to step 410, where the scheduler selects the next workload in its inventory to schedule. If there are no more, the process ends.
[0037] in some embodiments, one or more of the functions of VM management server
116, network manager 112, and storage manager 110 may be implemented using control VMs 143. Virtualized computing system 500 of Figure 5 depict an embodiment where the functions of scheduler arbiter 90, resource budget allocator 91, and resource scheduler 96 are distributed across hosts 120 in control VMs 143 of hosts 120 as a distributed scheduler 520.
[0038] Figure 6 depicts an example where control VMs 143A, 143B, 143C running in hosts 120A, 120B, 120C, respectively, cooperate with each other to execute the functions of scheduler arbiter 90, resource budget allocator 91, resource scheduler 96, and workload inventory 97, as distributed scheduler 520A, The fourth control VM, control VM 143D running in host 120D is a spare control VM that is able to replace any one of control VMs 143 A, 143B, 143C that fails.
[00354] In some embodiments, a running instance of control VM 143D is not necessary'.
Instead of the running instance of control VM 143D, resource scheduler 96 reserves spare capacity for control VM 143D in host 120D for control VM 143D to consume when instantiated, e.g., when one of control VMs 143A, 143B, 143C goes down.
[0046] in a similar manner, the functions of supervisor Kubernetes master 104 including those of Kubernetes scheduler 105 and workload inventory 106 may he distributed across hosts 120 in control VMs 143 of hosts 120. Figure 7 illustrates a distributed scheduler 520B that implements the functionality of and Kubernetes scheduler 105 and workload
inventory 106, in addition to scheduler arbiter 90, resource budget allocator 91, resource scheduler 96, and workload inventor)'· 97.
[0041] Figure 8 depicts another example of the distributed scheduler, distributed scheduler 520C, which implements the functionality of three independent schedulers. In addition to resource scheduler 96 (and workload inventory 97) and Kubernetes scheduler 105 (and workload inventory 106), distributed scheduler 520C includes a control VM scheduler 803 for scheduling workloads in its workload inventory 804 (e.g., control VMs 143, including control VMs 143A, 143B, 143C, 143D) on the same set of resources as resource scheduler 96 and Kubernetes scheduler 105. Scheduler arbiter 801 is a modified version of scheduler arbiter 90. To accommodate a third independent scheduler, scheduler arbiter 801 executes a high priority scheduler, middle priority scheduler, and a low priority scheduler in that order after executing resource budget allocator 802, In a similar manner, resource budget allocator 802 is modified from resource budget allocator 91 to accommodate the third independent scheduler. In addition to setting the resource budgets for the high priority scheduler and the low priority scheduler, resource budget allocator 802 sets the resource budget for the middle priority scheduler, in one embodiment, control VM scheduler 803 is the high priority scheduler, resource scheduler 96 the middle priority scheduler, and Kubernetes scheduler 105 the low pri ority sehedu ler.
[0042] In the embodiments described above, VMs represent the scheduled workloads and resources of the hosts in a cluster represent the common set of resources on which the workloads are scheduled, in other embodiments, the scheduled workloads may be any virtual object, including virtual compute, storage, and network resources, and also operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode. More generally, the scheduled workloads may be any process consuming resources that need to be scheduled. Also, the independent schedulers may be two or more and in some instances one scheduler may he nested inside another scheduler,
[0043] Further, in the embodiments described above, the interaction between independent cluster- level schedulers is described. In each of hosts 120, a host-level scheduler is also executed to schedule workloads (which are scheduled thereon by the independent cluster-level schedulers as described above) on the resources of the host. The host-level scheduling according to embodiments may be carried out: in various ways, two of which are described below.
[0044] According to the first technique, the host-level scheduler is operating strictly according to tire same priorities as the cluster-level schedulers and allocates available capacity to the workloads scheduled on that host, by the high-priority scheduler prior to scheduling the workloads scheduled on that host by the low-priority scheduler. If there is resource shortage on that host, tire host-level scheduler can preempt existing low-priority workloads ( which are workloads scheduled thereon by the low-priority scheduler) in favor of scheduling high-priority workloads (which are workloads scheduled thereon by the high-priority scheduler).
[0045] According to the second technique, the host-level scheduler operates according to resource budgets specified for the workloads. These resource budgets may specify three settings — reservation (amount of host resources reserved for the workload), limit (limit on the host resource usage by the workload), and share (a value that indicates scheduling priority of the workload in relation to other workloads running on the same host). These resource budgets can be specified directly on the workloads or can be a consequence of how the resource budget allocated to a duster-level scheduler is divvied out to the workloads managed by that scheduler, in this second technique, the host-level scheduler cannot preempt existing low-priority workloads in favor of high-priority workloads. The host resources axe guaranteed once granted to the workload. Accordingly, if there is insufficient capacity in the cluster to schedule new workloads (or the capacity is fragmented across multiple hosts), then the duster-level scheduler needs to wait on workloads to be terminated regardless of the priority assigned to the cluster- level scheduler. Once capacity frees np, the capacity can be allocated to the cluster-level scheduler based on the priority of the cluster-level scheduler.
[0046] In another embodiment, the allocation of resource budgets, e.g., the process of resource budget allocator 210, is decoupled from the processes of the cluster-level schedulers. Before any workload gets scheduled, each cluster-level scheduler assigns the budgets set by the decoupled resource budget allocator to the hosts. The cluster level scheduler takes this host-level budget allocation as input to its workload scheduling decisions. This decoupling allows the budget allocator to operate at larger time intervals than the cluster-level scheduler and it does not need to know about the workload details (e.g., placement, policies and the like). In this embodiment, because the decoupled resource budget allocator assigns resource budgets to hosts independent of the workloads, this can end up causing a mismatch and fragmentation. Accordingly, a minimum chunk size is applied to the budget allocation on each of the hosts. [0047] In the embodiments described above, live migration of workloads may be carried out for purposes of defragmentation to free up resources on one or more hosts. Beyond treeing up resources through defragmentation, there may be other technical/non- technical
constraints that can require a workload to be migrated. An example of a technical constraint is the current GPU configuration. The current GPU configuration may not allow the desired workload to be placed until existing workloads are evacuated from the host, and the GPU be reconfigured to match the requirements of the desired workload. An example noil- technical constraint is anti-affinity between the new workload and an existing workload. If the new workload has to be run on a host that is currently running a workload with anti-affinity to the new workload, the existing workload will need to he migrated to another host.
[0048] Embodiments described above depict hosts as resource providers for the common set of resources on which workloads are scheduled by the independent schedulers. Resource providers are not limited to hosts, in further embodiments, the resource providers may be datastores onto which workloads in the. form of disks are scheduled according to various technical constraints of the disks. For example, some disks may be thinly provisioned, which means that the capacity required by these disks may grow over time. There may be other disks that require encryption or to he stored in a redundant fashion.
[0049] The embodiments described herein may employ various computer-implemented operations involving data stored in computer systems. For example, these operations may require physical manipulation of physical quantities. Usually, though not necessarily, these quantities may take the form of electrical or magnetic signals, where the quantities or representations of the quantities can be stored, transferred, combined, compared, or otherwise manipulated. Such manipulations are often referred to in terms such as producing, identifying, determining, or comparing. Any operations described herein that form part of one or more embodiments may be useful machine operations.
[0050] One or more embodiments of the invention also relate to a device or an apparatus for performing these operations. The apparatus may be specially constructed for required purposes, or the apparatus may be a general-purpose computer selectively activated or configured by a computer program stored in the computer. Various general-purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
[0051] The embodiments described herein may be practiced with other computer system configurations including hand-held devices, microprocessor systems, microprocessor- based or programmable consumer electronics, minicomputers, mainframe computers, etc. [0052] One or more embodiments of the present invention may be implemented as one or more computer programs or as one or more computer program modules embodied in
computer readable media. The term computer readable medium refers to any data storage device that can store data which can thereafter be input to a computer system. Computer readable media may be based on any existing or subsequently developed technology that embodies computer programs in a manner that enables a computer to read the programs. Examples of computer readable media are hard drives, NAS systems, read-only memory (ROM), RAM, compact disks (CDs), digital versatile disks (DVDs), magnetic tapes, and other optical and non-optical data storage devices. A computer readable medium can also be distributed over a network-coupled computer system so that the computer readable code is stored and executed in a distributed fashion.
[0053] Although one or more embodiments of the present invention have been described in some detail for clarity of understanding, certain changes may be made within the scope of the claims. Accordingly, the described embodiments are to be considered as illustrative and not restrictive, and the scope of the claims is not to be limited to details given herein but may be modified within the scope and equivalents of the claims. In the claims, elements and/or steps do not imply any particular order of operation unless explicitly stated in the claims.
[0054] Virtualization systems in accordance with the various embodiments may be implemented as hosted embodiments, non-hosted embodiments, or as embodiments that blur distinctions between the two. Furthermore, various virtualization operations may be wholly or partially implemented in hardware. For example, a hardware implementation may employ a look-up table for modification of storage access requests to secure non-disk data.
[0055] Many variations, additions, and improvements are possible, regardless of the degree of virtualization. The virtualization software can therefore include components of a host, console, or guest OS that perform virtualization functions.
[0056] Plural instances may be provided for components, operations, or structures described herein as a single instance. Boundaries between components, operations, and data stores are somewhat arbitrary, and particular operations are illustrated in the context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within the scope of the invention. In general, structures and functionalities presented as separate components in exemplary configurations may be implemented as a combined structure or component. Similarly, structures and functionalities presented as a single component may be implemented as separate components. These and other variations, additions, and improvements may fall within the scope of the appended claims.
Claims
1. A method of scheduling workloads on a common set of resources that are distributed across a cluster of hosts, using at least two independent schedulers including a high priority scheduler for scheduling high priority workloads and a low priority scheduler for scheduling low priority workloads, said method comprising: scheduling the high priority workloads on the common set of resources using the high priority scheduler; and then scheduling the low priority workloads on the common set of resources using the low priority scheduler.
2. The method of claim 1, further comprising: allocating a first resource budget from a total resource budget of the common set of resources to the high priority workloads and a second resource budget from the total resource budget of the common set of resources to the low priority workloads, wherein the high priority scheduler performs the scheduling of the high priority workloads in accordance with the first resource budget and the low priority scheduler performs the scheduling of the low priority workloads in accordance with the second resource budget.
3. The method of claim 1, wherein each of the at least two independent schedulers is a cluster-level scheduler and each of the first and second resource budgets is defined for the cluster.
4. The method of claim 1, wherein each of the at least two independent schedulers is a cluster-level scheduler and each of the first and second resource budgets is defined per individual host.
5. The method of claim 1, further comprising: scheduling workloads scheduled on an individual host by the at least two independent schedulers using a host- level scheduler.
6. The method of claim 1, further comprising: upon determining that a high priority workload cannot be scheduled on a host, migrating one or more workloads that are currently executing in the host to another host.
7. The method of claim 1, wherein the first resource budget is defined for a subset of high priority workloads managed by the high priority scheduler and the second resource budget is defined for a subset of low priority workloads managed by the low priority scheduler.
8. The method of claim 1, wherein
said scheduling the high priority workloads includes performing defragmentation of the high priority workloads across the cluster of hosts; and said scheduling the low priority workloads includes performing defragmentation of the low priority workloads across the cluster of hosts.
9. The method of claim 1, wherein the low priority workloads include pod virtual machines running on the hosts of the cluster, which correspond respectively to nodes of a Kubernetes platform, and high priority workloads include other virtual machines running on the hosts of the cluster that are not pod virtual machines.
10. The method of claim 1, wherein the high priority workloads include control virtual machines running on the hosts of the cluster, the control virtual machines performing virtual machine management operations for the cluster in a distributed manner, and low priority workloads include other virtual machines running on the hosts of the cluster that are not control virtual machines.
11. The method of claim 1, wherein the workloads include virtual objects and operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode.
12. The method of claim 1, wherein the resources include CPU, memory, network, and storage.
13. A computer system comprising: a set of resources distributed across a cluster of host computers; and one or more processors executing a method of scheduling workloads on the set of resources, using at least two independent schedulers including a high priority scheduler for scheduling high priority workloads and a low priority scheduler for scheduling low priority workloads, said method comprising: scheduling the high priority workloads on the common set of resources using the high priority scheduler; and then scheduling the low priority workloads on the common set of resources using the low priority scheduler.
14. The computer system of claim 13, wherein the method further comprises: allocating a first resource budget from a total resource budget of the common set of resources to the high priority workloads and a second resource budget from the total resource budget of the common set of resources to the low priority workloads,
wherein the high priority scheduler performs the scheduling of the high priority workloads in accordance with the first resource budget and the low priority scheduler performs the scheduling of the low priority workloads in accordance with the second resource budget.
15. The computer system of claim 14, wherein the method further comprises: upon determining that a high priority workload cannot be scheduled on a host, migrating one or more workloads that are currently executing in the host to another host.
16. The computer system of claim 13, wherein said scheduling the high priority workloads includes performing defragmentation of the high priority workloads across the cluster of hosts; and said scheduling the low priority workloads includes performing defragmentation of the low priority workloads across the cluster of hosts.
17. The computer system of claim 13, wherein the low priority workloads include pod virtual machines running on the hosts of the cluster, which correspond respectively to nodes of a Kubernetes platform, and high priority workloads include other virtual machines running on the hosts of the cluster that are not pod virtual machines.
18. The computer system of claim 13, wherein the high priority workloads include control virtual machines running on the hosts of the cluster, the control virtual machines performing virtual machine management operations for the cluster in a distributed manner, and low priority workloads include other virtual machines running on the hosts of the cluster that are not control virtual machines.
19. The computer system of claim 13 , wherein the workloads include virtual objects and operations including live migration of virtual objects, network file copy, reserving spare capacity for high availability restarts, and selecting hosts that are to go into maintenance mode.
20. A non-transitory computer readable medium comprising instructions to be executed in a computer system, wherein the instructions, when executed in the computer system, cause the computer system to carry out a method of scheduling workloads on a common set of resources that are distributed across a plurality of resource providers, using at least two independent schedulers including a high priority scheduler for scheduling high priority workloads and a low priority scheduler for scheduling low priority workloads, said method comprising: scheduling the high priority workloads on the common set of resources using the high priority scheduler; and then
scheduling the low priority workloads on the common set of resources using the low priority scheduler.
21. The non-transitory computer readable medium of claim 20, wherein the plurality of resource providers include one of: (a) a cluster of hosts; and (b) a plurality of datastores.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP21851062.6A EP4073641A4 (en) | 2020-07-30 | 2021-07-26 | Scheduling workloads on a common set of resources by multiple schedulers operating independently |
CN202180020543.8A CN115280285B (en) | 2020-07-30 | 2021-07-26 | Scheduling workload on a common set of resources by multiple schedulers operating independently |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/943,710 | 2020-07-30 | ||
US16/943,710 US11726816B2 (en) | 2020-07-30 | 2020-07-30 | Scheduling workloads on a common set of resources by multiple schedulers operating independently |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2022026426A1 true WO2022026426A1 (en) | 2022-02-03 |
Family
ID=80003165
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2021/043248 WO2022026426A1 (en) | 2020-07-30 | 2021-07-26 | Scheduling workloads on a common set of resources by multiple schedulers operating independently |
Country Status (4)
Country | Link |
---|---|
US (1) | US11726816B2 (en) |
EP (1) | EP4073641A4 (en) |
CN (1) | CN115280285B (en) |
WO (1) | WO2022026426A1 (en) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11595464B2 (en) * | 2021-07-23 | 2023-02-28 | Vmware, Inc. | Migration of network file copy operations between host computing devices |
US12032855B2 (en) | 2021-08-06 | 2024-07-09 | Commvault Systems, Inc. | Using an application orchestrator computing environment for automatically scaled deployment of data protection resources needed for data in a production cluster distinct from the application orchestrator or in another application orchestrator computing environment |
US20240045708A1 (en) * | 2022-08-08 | 2024-02-08 | Google Llc | Coordinated Maintenance For Virtual Machine (VM) Clusters/Pods |
US20240241759A1 (en) * | 2023-01-18 | 2024-07-18 | Vmware, Inc. | Unified resource management architecture for workload schedulers |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080028411A1 (en) * | 2006-07-26 | 2008-01-31 | Ludmila Cherkasova | System and method for controlling aggregate CPU usage by virtual machines and driver domains over a plurality of scheduling intervals |
US7707578B1 (en) * | 2004-12-16 | 2010-04-27 | Vmware, Inc. | Mechanism for scheduling execution of threads for fair resource allocation in a multi-threaded and/or multi-core processing system |
US20100325637A1 (en) | 2009-06-18 | 2010-12-23 | Microsoft Corporation | Allocation of resources to a scheduler in a process |
US20110141655A1 (en) | 2009-12-10 | 2011-06-16 | Samsung Electro-Mechanics Co., Ltd. | Multilayer ceramic capacitor |
US20140137104A1 (en) | 2012-11-12 | 2014-05-15 | Vmware, Inc. | Cooperative Application Workload Scheduling for a Consolidated Virtual Environment |
US20150143381A1 (en) * | 2013-11-20 | 2015-05-21 | International Business Machines Corporation | Computing session workload scheduling and management of parent-child tasks |
Family Cites Families (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7203944B1 (en) * | 2003-07-09 | 2007-04-10 | Veritas Operating Corporation | Migrating virtual machines among computer systems to balance load caused by virtual machines |
US7657508B2 (en) * | 2006-12-29 | 2010-02-02 | Teradata Us, Inc. | Automated block size management for database objects |
US8667500B1 (en) | 2006-10-17 | 2014-03-04 | Vmware, Inc. | Use of dynamic entitlement and adaptive threshold for cluster process balancing |
US8037280B2 (en) * | 2008-06-11 | 2011-10-11 | Vmware, Inc. | System and method for improving memory locality of virtual machines |
US8775413B2 (en) * | 2008-06-30 | 2014-07-08 | Teradata Us, Inc. | Parallel, in-line, query capture database for real-time logging, monitoring and optimizer feedback |
US8850432B2 (en) | 2012-05-30 | 2014-09-30 | Red Hat, Inc. | Controlling utilization in a multi-tenant platform-as-a-service (PaaS) environment in a cloud computing system |
CA2867589A1 (en) * | 2013-10-15 | 2015-04-15 | Coho Data Inc. | Systems, methods and devices for implementing data management in a distributed data storage system |
US9513962B2 (en) * | 2013-12-03 | 2016-12-06 | International Business Machines Corporation | Migrating a running, preempted workload in a grid computing system |
KR102366526B1 (en) | 2014-08-27 | 2022-02-23 | 아씨아 에스피이, 엘엘씨 | Systems, methods, and apparatuses for implementing the virtualization of access node functions |
US10389598B2 (en) | 2015-10-29 | 2019-08-20 | Cisco Technology, Inc. | Container management and application ingestion engine |
US10241840B2 (en) * | 2016-09-30 | 2019-03-26 | Vmware, Inc. | Resource based virtual computing instance scheduling |
US10379908B2 (en) | 2017-05-30 | 2019-08-13 | Red Hat, Inc. | Merging scaled-down container clusters using vitality metrics |
CN109582433B (en) * | 2017-09-29 | 2022-02-01 | 腾讯科技(深圳)有限公司 | Resource scheduling method and device, cloud computing system and storage medium |
US20190223023A1 (en) | 2018-01-17 | 2019-07-18 | Netsia, Inc. | System and method for an integrated virtual customer premises equipment |
US10871998B2 (en) | 2018-01-18 | 2020-12-22 | Red Hat, Inc. | Usage instrumented workload scheduling |
US10977086B2 (en) | 2018-11-14 | 2021-04-13 | Vmware, Inc. | Workload placement and balancing within a containerized infrastructure |
CN110515730A (en) * | 2019-08-22 | 2019-11-29 | 北京宝兰德软件股份有限公司 | Resource secondary dispatching method and device based on kubernetes container arranging system |
CN110780998A (en) * | 2019-09-29 | 2020-02-11 | 武汉大学 | Kubernetes-based dynamic load balancing resource scheduling method |
US11182196B2 (en) | 2019-11-13 | 2021-11-23 | Vmware, Inc. | Unified resource management for containers and virtual machines |
-
2020
- 2020-07-30 US US16/943,710 patent/US11726816B2/en active Active
-
2021
- 2021-07-26 WO PCT/US2021/043248 patent/WO2022026426A1/en unknown
- 2021-07-26 EP EP21851062.6A patent/EP4073641A4/en active Pending
- 2021-07-26 CN CN202180020543.8A patent/CN115280285B/en active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7707578B1 (en) * | 2004-12-16 | 2010-04-27 | Vmware, Inc. | Mechanism for scheduling execution of threads for fair resource allocation in a multi-threaded and/or multi-core processing system |
US20080028411A1 (en) * | 2006-07-26 | 2008-01-31 | Ludmila Cherkasova | System and method for controlling aggregate CPU usage by virtual machines and driver domains over a plurality of scheduling intervals |
US20100325637A1 (en) | 2009-06-18 | 2010-12-23 | Microsoft Corporation | Allocation of resources to a scheduler in a process |
US20110141655A1 (en) | 2009-12-10 | 2011-06-16 | Samsung Electro-Mechanics Co., Ltd. | Multilayer ceramic capacitor |
US20140137104A1 (en) | 2012-11-12 | 2014-05-15 | Vmware, Inc. | Cooperative Application Workload Scheduling for a Consolidated Virtual Environment |
US20150143381A1 (en) * | 2013-11-20 | 2015-05-21 | International Business Machines Corporation | Computing session workload scheduling and management of parent-child tasks |
Non-Patent Citations (4)
Title |
---|
ANONYMOUS: "vSphere with Kubernetes Configuration and Management", 19 May 2020, VMWARE, INC. |
CHAO TIAN ; HAOJIE ZHOU ; YONGQIANG HE ; LI ZHA: "A Dynamic MapReduce Scheduler for Heterogeneous Workloads", GRID AND COOPERATIVE COMPUTING, 2009. GCC '09. EIGHTH INTERNATIONAL CONFERENCE ON, IEEE, PISCATAWAY, NJ, USA, 27 August 2009 (2009-08-27), Piscataway, NJ, USA , pages 218 - 224, XP031542077, ISBN: 978-0-7695-3766-5 * |
GRANDL ROBERT A-ROBERG@MICROSOFT.COM; ANANTHANARAYANAN GANESH GA@MICROSOFT.COM; KANDULA SRIKANTH SRIKANTH@MICROSOFT.COM; RAO SRIRA: "Multi-resource packing for cluster schedulers", COMPUTER COMMUNICATION REVIEW., ACM, NEW YORK, NY., US, vol. 44, no. 4, 17 August 2014 (2014-08-17), US , pages 455 - 466, XP058493005, ISSN: 0146-4833, DOI: 10.1145/2740070.2626334 * |
See also references of EP4073641A4 |
Also Published As
Publication number | Publication date |
---|---|
EP4073641A1 (en) | 2022-10-19 |
EP4073641A4 (en) | 2023-12-27 |
US20220035662A1 (en) | 2022-02-03 |
US11726816B2 (en) | 2023-08-15 |
CN115280285A (en) | 2022-11-01 |
CN115280285B (en) | 2024-08-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3803596B1 (en) | Automatic cluster consolidation for efficient resource management | |
US11221884B2 (en) | Hybrid virtual machine configuration management | |
US11726816B2 (en) | Scheduling workloads on a common set of resources by multiple schedulers operating independently | |
US10474488B2 (en) | Configuration of a cluster of hosts in virtualized computing environments | |
US9977688B2 (en) | Live migration of virtual machines across virtual switches in virtual infrastructure | |
US10693806B2 (en) | Network bandwidth reservations for system traffic and virtual computing instances | |
US11237856B2 (en) | Mobility operation resource allocation | |
US9183016B2 (en) | Adaptive task scheduling of Hadoop in a virtualized environment | |
US8589554B2 (en) | Intelligent and elastic resource pools for heterogeneous datacenter environments | |
US9329889B2 (en) | Rapid creation and reconfiguration of virtual machines on hosts | |
US11070492B2 (en) | Pooling public cloud resources from different subscriptions using reservations | |
US11403150B1 (en) | Replenishment-aware resource usage management | |
US12086634B2 (en) | Optimizing VM NUMA configuration and workload placement in a heterogeneous cluster | |
US11036555B2 (en) | Virtual processor allocation with execution guarantee | |
US20230229476A1 (en) | Flexible infrastructure for provisioning virtual computing instances | |
US20180145925A1 (en) | Subscription-agnostic deployment of workloads to a public cloud | |
EP4390683A1 (en) | Techniques for migrating containerized workloads across different container orchestration platform offerings |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 21851062 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2021851062 Country of ref document: EP Effective date: 20220711 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |