-
Notifications
You must be signed in to change notification settings - Fork 304
Developer Guide
- Warning
- Assumptions
- Build and install a Kata Containers runtime
- Build and install Kata proxy
- Build and install Kata shim
- Create an image
- Install the image
- Install guest kernel images
- Update Docker config
- Test
- Appendices
This document is written specifically for developers to allow them to try out this early version of Kata Containers.
-
You are working on a non-critical test or development system.
-
You already have the following installed:
-
You have installed the Clear Containers
linux-container
andqemu-lite
packages containing the guest kernel images and hypervisor. These packages are automatically installed when you install Clear Containers, but can be installed separately:https://github.com/clearcontainers/runtime/wiki/Installation
Currently, there are two available runtimes:
- The Intel® Clear Containers based-runtime (
KATA_RUNTIME=cc
). - The Hyper
runv
-based runtime (KATA_RUNTIME=runv
).
go get -d -u github.com/kata-containers/runtime
cd $GOPATH/src/github.com/kata-containers/runtime
# Set to either 'cc' or 'runv'.
runtime=
make KATA_RUNTIME=$runtime && sudo -E PATH=$PATH make KATA_RUNTIME=$runtime install
Whichever runtime you build with, the build will create a /usr/local/bin/kata-runtime
symlink. This links to the particular build variant you selected using the KATA_RUNTIME
variable.
If you are using a Clear Containers-based runtime (KATA_RUNTIME=cc
), you can now check if your system is capable of creating a Kata Container by running:
$ sudo kata-runtime kata-check
If your system is not able to run Kata Containers, this command will error and explain why.
If you are using a Clear Containers-based runtime (KATA_RUNTIME=cc
), enable full debug as follows:
sudo sed -i -e 's/^# *\(enable_debug\).*=.*$/\1 = true/g' /usr/share/defaults/kata-containers/configuration.toml
go get -d -u github.com/kata-containers/proxy
cd $GOPATH/src/github.com/kata-containers/proxy && make && sudo make install
go get -d -u github.com/kata-containers/shim
cd $GOPATH/src/github.com/kata-containers/shim && make && sudo make install
Note:
- You only do this step if you wish to test with the latest version of the agent.
go get -d -u github.com/kata-containers/agent
cd $GOPATH/src/github.com/kata-containers/agent && make
go get -d -u github.com/kata-containers/osbuilder
cd $GOPATH/src/github.com/kata-containers/osbuilder/rootfs-builder
script -fec 'sudo -E GOPATH=$GOPATH USE_DOCKER=true ./rootfs.sh clearlinux'
Note:
- You must ensure that the default Docker runtime is
runc
to make use of theUSE_DOCKER
variable. If that is not the case, simply remove the variable from the command above. See Checking Docker default runtime.
Note:
- You only do this step if you wish to test with the latest version of the agent.
sudo install -o root -g root -m 0550 -t rootfs/bin ../../agent/kata-agent
sudo install -o root -g root -m 0440 ../../agent/kata-agent.service rootfs/usr/lib/systemd/system/
sudo install -o root -g root -m 0440 ../../agent/kata-containers.target rootfs/usr/lib/systemd/system/
cd $GOPATH/src/github.com/kata-containers/osbuilder/image-builder
script -fec 'sudo -E USE_DOCKER=true ./image_builder.sh ../rootfs-builder/rootfs'
Note:
- You must ensure that the default Docker runtime is
runc
to make use of theUSE_DOCKER
variable. If that is not the case, simply remove the variable from the command above. See Checking Docker default runtime.
commit=$(git log --format=%h -1 HEAD)
date=$(date +%Y-%m-%d-%T.%N%z)
image="kata-containers-${date}-${commit}"
sudo install -o root -g root -m 0640 -D kata-containers.img "/usr/share/kata-containers/${image}"
(cd /usr/share/kata-containers && sudo ln -sf "$image" kata-containers.img)
Note: these currently come from the Clear Containers linux-container
package. See Assumptions.
sudo ln -s /usr/share/clear-containers/vmlinux.container /usr/share/kata-containers/
sudo ln -s /usr/share/clear-containers/vmlinuz.container /usr/share/kata-containers/
dir=/etc/systemd/system/docker.service.d
file="$dir/kata-containers.conf"
sudo mkdir -p "$dir"
sudo test -e "$file" || echo -e "[Service]\nType=simple\nExecStart=\nExecStart=/usr/bin/dockerd -D --default-runtime runc" | sudo tee "$file"
sudo sed -i 's!^\(ExecStart=[^$].*$\)!\1 --add-runtime kata-runtime=/usr/local/bin/kata-runtime!g' "$file"
sudo systemctl daemon-reload
sudo systemctl restart docker
sudo docker run -ti --runtime kata-runtime busybox sh
sudo docker info|grep -i "default runtime"|cut -d: -f2-|grep -q runc && echo "SUCCESS" || echo "ERROR: Wrong default runtime"