Kubernetes Virtualization API and runtime in order to define and manage virtual machines.
Clone or download
davidvossel Merge pull request #1926 from mfranczy/go-1.11.2
Update golang to 1.11.2 version
Latest commit 8dec75f Jan 17, 2019
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github Prepare Issues and PRs for Prow Jun 21, 2018
api/openapi-spec Generated artifacts Jan 14, 2019
automation Use operator in CI Jan 11, 2019
cluster Generated artifacts Jan 14, 2019
cmd Initial very simple version of the KubeVirt Operator Jan 11, 2019
docs Merge pull request #1844 from booxter/sriov-ansible-refer Jan 11, 2019
hack Merge pull request #1926 from mfranczy/go-1.11.2 Jan 17, 2019
images move iscsi server to the cdi-http-import-server container Dec 13, 2018
manifests Fixed RBAC for restart subresource Jan 16, 2019
pkg Merge pull request #1926 from mfranczy/go-1.11.2 Jan 17, 2019
tests Merge pull request #1926 from mfranczy/go-1.11.2 Jan 17, 2019
tools Correct errors introduced by rebase Jan 14, 2019
vendor Added SCC handling for openshift Jan 11, 2019
.gitattributes Add .gitattributes to hide vendor/ in diffs Jun 13, 2018
.gitignore Add coverage html to gitignore Jan 10, 2019
.mailmap hack: Update release script and mailMap Jul 19, 2018
.rsynctemp Wait for rsyncd to be ready Jan 15, 2018
.travis.yml Moved KubeVirt CR manifest to release dir Jan 11, 2019
CODE_OF_CONDUCT.md Make CoC render as Markdown May 9, 2018
CONTRIBUTING.md English change of tone Nov 28, 2018
FAQ.md Add FAQ.md Jan 26, 2017
LICENSE LICENSE: Add date and owner Feb 27, 2017
Makefile Propagate some more env vars in build scripts Jan 11, 2019
README.md correct link to the user guide Nov 28, 2018
glide.lock Added SCC handling for openshift Jan 11, 2019
glide.yaml Added SCC handling for openshift Jan 11, 2019
stdci.yaml Enable subresource feature-gate on the 1.10 cluster Dec 31, 2018



Build Status Go Report Card Licensed under Apache License version 2.0 Coverage Status Visit our IRC channel

KubeVirt is a virtual machine management add-on for Kubernetes. The aim is to provide a common ground for virtualization solutions on top of Kubernetes.

Note: KubeVirt is a heavy work in progress.


Virtualization extension for Kubernetes

At its core, KubeVirt extends Kubernetes by adding additional virtualization resource types (especially the VM type) through Kubernetes's Custom Resource Definitions API. By using this mechanism, the Kubernetes API can be used to manage these VM resources alongside all other resources Kubernetes provides.

The resources themselves are not enough to launch virtual machines. For this to happen the functionality and business logic needs to be added to the cluster. The functionality is not added to Kubernetes itself, but rather added to a Kubernetes cluster by running additional controllers and agents on an existing cluster.

The necessary controllers and agents are provided by KubeVirt.

As of today KubeVirt can be used to declaratively

  • Create a predefined VM
  • Schedule a VM on a Kubernetes cluster
  • Launch a VM
  • Stop a VM
  • Delete a VM



To start using KubeVirt

Try our quickstart at kubevirt.io.

See our user documentation at kubevirt.io/docs.

To start developing KubeVirt

To set up a development environment please read our Getting Started Guide. To learn how to contribute, please read our contribution guide.

You can learn more about how KubeVirt is designed (and why it is that way), and learn more about the major components by taking a look at our developer documentation:


If you got enough of code and want to speak to people, then you got a couple of options:

Related resources

Submitting patches

When sending patches to the project, the submitter is required to certify that they have the legal right to submit the code. This is achieved by adding a line

Signed-off-by: Real Name <email@address.com>

to the bottom of every commit message. Existence of such a line certifies that the submitter has complied with the Developer's Certificate of Origin 1.1, (as defined in the file docs/developer-certificate-of-origin).

This line can be automatically added to a commit in the correct format, by using the '-s' option to 'git commit'.


KubeVirt is distributed under the Apache License, Version 2.0.

Copyright 2016

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at


Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
See the License for the specific language governing permissions and
limitations under the License.