KubeVirt is built using a service oriented architecture and a choreography pattern.
+---------------------+
| KubeVirt |
~~+---------------------+~~
| Orchestration (K8s) |
+---------------------+
| Scheduling (K8s) |
+---------------------+
| Container Runtime |
~~+---------------------+~~
| Operating System |
+---------------------+
| (Virtual) |
~~+---------------------+~~
| Physical |
+---------------------+
Users requiring virtualization services are speaking to the Virtualization API (see below) which in turn is speaking to the Kubernetes cluster to schedule requested VMs. Scheduling, networking, and storage are all delegated to Kubernetes, while KubeVirt provides the virtualization functionality.
KubeVirt provides additional functionality to your Kubernetes cluster, to perform virtual machine management
If we recall how Kubernetes is handling Pods, then we remember that Pods are
created by posting a Pod specification to the Kubernetes API Server.
This specification is then transformed into an object inside the API Server,
this object is of a specific type or kind - that is how it's called in the
specification.
A Pod is of the type Pod
. Controllers within Kubernetes know how to handle
these Pod objects. Thus once a new Pod object is seen, those controllers
perform the necessary actions to bring the Pod alive, and to match the
required state.
This same mechanism is used by KubeVirt. Thus KubeVirt delivers three things to provide the new functionality:
- Additional types - so called 3rd party resources - are added to the Kubernetes API
- Additional controllers for cluster wide logic associated with this new types
- Additional daemons for node specific logic associated with new types
Once all three steps have been completed, you are able to
- create new objects of these new types in Kubernetes (VMs in our case)
- and the new controllers take care to get the VMs scheduled on some host,
- and a daemon - the
virt-handler
- is taking care on a host - alongside thekubelet
- to launch the VM and configure it until it matches the required state.
One a final note it is to say that both, the controllers and daemons are running as Pods (or similar) on top of the Kubernetes cluster, and are not installed alongside of it. The type is - as said before - even defined inside the Kubernetes API server. This allows users to speak to Kubernetes, but modify VMs.
The following diagram illustrates how the addditional controllers and daemons communicate with Kubernetes and where the additional types are stored:
- Cluster
- KubeVirt Components
- virt-controller
- virt-handler
- libvirtd
- …
- KubeVirt Managed Pods
- VM Foo
- VM Bar
- …
- KubeVirt Components
KubeVirt is deployed on top of a Kubernetes cluster. This means that you can continue to run your Kubernetes-native workloads next to the VMs managed through KubeVirt.