A quick start guide to get KubeVirt up and running inside our container based development cluster.
The KubeVirt build system runs completely inside docker. In order to build
KubeVirt you need to have docker
and rsync
installed.
Runs master and nodes containers, when each one of them run virtual machine via QEMU. In additional it runs dnsmasq and docker registry containers.
Build all required artifacts and launch the dockerizied environment:
# Build and deploy KubeVirt on Kubernetes 1.9.3 in our vms inside containers
export KUBEVIRT_PROVIDER=k8s-1.9.3 # this is also the default if no KUBEVIRT_PROVIDER is set
make cluster-up
make cluster-sync
This will create a VM called node01
which acts as node and master. To create
more nodes which will register themselves on master, you can use the
KUBEVIRT_NUM_NODES
environment variable. This would create a master and one
node:
export KUBEVIRT_NUM_NODES=2 # schedulable master + one additional node
make cluster-up
You could also run some build steps individually:
# To build all binaries
make
# Or to build just one binary
make build WHAT=cmd/virt-controller
# To build all kubevirt containers
make docker
To destroy the created cluster, type
make cluster-down
Note: Whenever you type make cluster-down && make cluster-up
, you will
have a completely fresh cluster to play with.
The containerized nodes are named starting from node01
, node02
, and so
forth. node01
is always the master of the cluster.
Every node can be accessed via its name:
cluster/cli.sh ssh node01
To execute a remote command, e.g ls
, simply type
cluster/cli.sh ssh node01 -- ls -lh
Note: This is only important if you plan to modify sources, you don't need code generators just for building
To invoke all code-generators and regenerate generated code, run:
make generate
Typical code changes where running the generators is needed:
- When changing APIs, REST paths or their comments (gets reflected in the api documentation, clients, generated cloners, ...)
- When changing mocked interfaces (the mock generator needs to update the generated mocks then)
We have a check in our CI system, so that you don't miss when make generate
needs to be called.
After a successful build you can run the unit tests:
make test
They don't real environment. To run the functional tests, make sure you have set up dockerizied environment. Then run
make cluster-sync # synchronize with your code, if necessary
make functest # run the functional tests against the VMs
If you'd like to run specific functional tests only, you can leverage ginkgo
command line options as follows:
FUNC_TEST_ARGS='-ginkgo.focus=vm_networking_test -ginkgo.regexScansFilePath' make functest
Congratulations you are still with us and you have build KubeVirt.
Now it's time to get hands on and give it a try.
Finally start a VM called vm-ephemeral
:
# This can be done from your GIT repo, no need to log into a VM
# Create a VM
./cluster/kubectl.sh create -f cluster/examples/vm-ephemeral.yaml
# Sure? Let's list all created VMs
./cluster/kubectl.sh get vms
# Enough, let's get rid of it
./cluster/kubectl.sh delete -f cluster/examples/vm-ephemeral.yaml
# You can actually use kubelet.sh to introspect the cluster in general
./cluster/kubectl.sh get pods
This will start a VM on master or one of the running nodes with a macvtap and a tap networking device attached.
$ ./cluster/kubectl.sh create -f cluster/examples/vm-ephemeral.yaml
vm "vm-ephemeral" created
$ ./cluster/kubectl.sh get pods
NAME READY STATUS RESTARTS AGE
virt-api 1/1 Running 1 10h
virt-controller 1/1 Running 1 10h
virt-handler-z90mp 1/1 Running 1 10h
virt-launcher-vm-ephemeral9q7es 1/1 Running 0 10s
$ ./cluster/kubectl.sh get vms
NAME LABELS DATA
vm-ephemera kubevirt.io/nodeName=node01 {"apiVersion":"kubevirt.io/v1alpha1","kind":"VM","...
$ ./cluster/kubectl.sh get vms -o json
{
"kind": "List",
"apiVersion": "v1",
"metadata": {},
"items": [
{
"apiVersion": "kubevirt.io/v1alpha1",
"kind": "VirtualMachine",
"metadata": {
"creationTimestamp": "2016-12-09T17:54:52Z",
"labels": {
"kubevirt.io/nodeName": "master"
},
"name": "vm-ephemeral",
"namespace": "default",
"resourceVersion": "102534",
"selfLink": "/apis/kubevirt.io/v1alpha1/namespaces/default/virtualmachines/testvm",
"uid": "7e89280a-be62-11e6-a69f-525400efd09f"
},
"spec": {
...
First make sure you have remote-viewer
installed. On Fedora run
dnf install virt-viewer
Then, after you made sure that the VM vm-ephemeral
is running, type
cluster/virtctl.sh vnc vm-ephemeral
to start a remote session with remote-viewer
.
cluster/virtctl.sh
is a wrapper around virtctl
. virtctl
brings all
virtual machine specific commands with it. It is supplement to kubectl
.