Skip to content
Kata Containers runtime
Go Makefile Shell
Branch: master
Clone or download

Latest commit

likebreath Merge pull request #2721 from likebreath/fix_2720
clh: Support to add block device and volumes from host to container
Latest commit 36f25dc Jun 5, 2020

Files

Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.ci ci: Do not install virtcontainers with podman clh May 28, 2020
.github github: add auto comment bot Jun 3, 2020
arch qemu: Fix Qemu binary path for Power across distros Jun 3, 2020
cli clh: Allow add virtiofs args and cache options from config Jun 3, 2020
containerd-shim-v2 shimv2: check correct error variable for deferred func in service#Sta… Jun 3, 2020
data Merge pull request #1721 from devimc/topic/data/kataCollectSupportSnap May 24, 2019
hack virtcontainers: Add SELinux support for running VM Confinement Apr 2, 2020
netmon ipv6: Add support for ipv6 for netmon as well. Jan 29, 2020
pkg clh: Allow add virtiofs args and cache options from config Jun 3, 2020
protocols/cache factory: Make factory status can show status of VMCache server Apr 10, 2019
vendor Merge pull request #2672 from amshinde/add-arp-neighbors May 29, 2020
virtcontainers Merge pull request #2721 from likebreath/fix_2720 Jun 5, 2020
.gitignore katautils: Use config paths set during the build Apr 15, 2020
.gitmodules submodules: Remove cc-runtime and runv Mar 21, 2018
.travis.yml versions: Update go to 1.13.9 Apr 7, 2020
CODEOWNERS ci: Add a CODEOWNERS file for github ack checks Jan 30, 2019
CODE_OF_CONDUCT.md docs: Add missing standard docs Feb 9, 2018
CONTRIBUTING.md docs: Add missing standard docs Feb 9, 2018
Gopkg.lock Merge pull request #2672 from amshinde/add-arp-neighbors May 29, 2020
Gopkg.toml Merge pull request #2672 from amshinde/add-arp-neighbors May 29, 2020
LICENSE Initial commit Nov 21, 2017
Makefile clh: Allow add virtiofs args and cache options from config Jun 3, 2020
README.md README: logging: add shimv2 information Mar 10, 2020
VERSION release: Kata Containers 1.11.0-rc0 Apr 17, 2020
golang.mk Makefile: Change "GOPATH not set" to "No GO command or GOPATH not set" Mar 1, 2019
versions.yaml versions: Move to cloud-hypervisor v0.7.0 Apr 30, 2020

README.md

Build Status Build Status Go Report Card GoDoc

Runtime

This repository contains the runtime for the Kata Containers project.

For details of the other Kata Containers repositories, see the repository summary.

Introduction

kata-runtime, referred to as "the runtime", is the Command-Line Interface (CLI) part of the Kata Containers runtime component. It leverages the virtcontainers package to provide a high-performance standards-compliant runtime that creates hardware-virtualized Linux containers running on Linux hosts.

The runtime is OCI-compatible, CRI-O-compatible, and Containerd-compatible, allowing it to work seamlessly with both Docker and Kubernetes respectively.

License

The code is licensed under an Apache 2.0 license.

See the license file for further details.

Platform support

Kata Containers currently works on systems supporting the following technologies:

  • Intel VT-x technology.
  • ARM Hyp mode (virtualization extension).
  • IBM Power Systems.
  • IBM Z mainframes.

Hardware requirements

The runtime has a built-in command to determine if your host system is capable of running and creating a Kata Container:

$ kata-runtime kata-check

Note:

  • By default, only a brief success / failure message is printed. If more details are needed, the --verbose flag can be used to display the list of all the checks performed.

  • root permission is needed to check if the system is capable of running Kata containers. In this case, additional checks are performed (e.g., if another incompatible hypervisor is running).

Download and install

Get it from the Snap Store

See the installation guides available for various operating systems.

Quick start for developers

See the developer guide.

Architecture overview

See the architecture overview for details on the Kata Containers design.

Configuration

The runtime uses a TOML format configuration file called configuration.toml. The file contains comments explaining all options.

Note:

The initial values in the configuration file provide a good default configuration. You may need to modify this file to optimise or tailor your system, or if you have specific requirements.

Since the runtime supports a stateless system, it checks for this configuration file in multiple locations, two of which are built in to the runtime. The default location is /usr/share/defaults/kata-containers/configuration.toml for a standard system. However, if /etc/kata-containers/configuration.toml exists, this takes priority.

The below command lists the full paths to the configuration files that the runtime attempts to load. The first path that exists will be used:

$ kata-runtime --kata-show-default-config-paths

Aside from the built-in locations, it is possible to specify the path to a custom configuration file using the --kata-config option:

$ kata-runtime --kata-config=/some/where/configuration.toml ...

The runtime will log the full path to the configuration file it is using. See the logging section for further details.

To see details of your systems runtime environment (including the location of the configuration file being used), run:

$ kata-runtime kata-env

Logging

For detailed information and analysis on obtaining logs for other system components, see the documentation for the kata-log-parser tool.

For runtime logs, see the following sections for the CRI-O and containerd shimv2 based runtimes.

Kata OCI

The Kata OCI runtime (including when used with CRI-O), provides --log= and --log-format= options. However, the runtime also always logs to the system log (syslog or journald).

To view runtime log output:

$ sudo journalctl -t kata-runtime

Kata containerd shimv2

The Kata containerd shimv2 runtime logs through containerd, and its logs will be sent to wherever the containerd logs are directed. However, the shimv2 runtime also always logs to the system log (syslog or journald) under the identifier name of kata.

To view the shimv2 runtime log output:

$ sudo journalctl -t kata

Debugging

See the debugging section of the developer guide.

Limitations

See the limitations file for further details.

Community

See the community repository.

Contact

See how to reach the community.

Further information

See the project table of contents and the documentation repository.

Additional packages

For details of the other packages contained in this repository, see the package documentation.

You can’t perform that action at this time.