开发者社区> 问答> 正文

通过containerd命令行运行Kata-Containers:ctr:connect:conne

我试图通过containerd命令行使用Kata-Containers运行一个容器,但报错了。

$ sudo ctr run --runtime io.containerd.run.kata.v2 -t --rm docker.io/library/busybox:latest hello sh ctr: dial unix /run/containerd/s/f89a747f6a50d5c2ffc699d28a658410899f12d03fa638893cc55d2da1cf53f6: connect: connection refused: unknown

Ubuntu 版本: 22.04

我是这么做的:

首先,我按照开发人员指南来安装组件。动作如下:

-构建并安装Kata Containers运行时 -配置为使用rootfs映像 $sudo sed-i的/^\(initrd=.*\)/#\1/g'/etc/kata-containers/configuration.toml -启用seccomp -启用完整容器调试 [debug]     level = "debug" -日志限制 -创建本地根 -安装rootfs映像 -使用kernel 版本v5.19.2安装 guest kernel 映像 -构建自定义QEMU -为aarch64/arm64构建自定义QEMU -构建virtiofsd -检查硬件需求 $sudo-kata运行时检查

INFO[0000] IOMMUPlatform is disabled by default. WARN[0000] Not running network checks as super user      arch=amd64 name=kata-runtime pid=356121 source=runtime System is capable of running Kata Containers System can currently create Kata Containers

然后,我尝试使用containerd运行Kata Containers

-检查conainer是否可用 $command-v containerd /usr/local/bin/containerd -安装CNI插件 -安装cri工具 -配置containerd以使用Kata Containers

    [plugins."io.containerd.grpc.v1.cri".containerd]     snapshotter = "overlayfs"     default_runtime_name = "runc"     no_pivot = false     [plugins."io.containerd.grpc.v1.cri".containerd.default_runtime]       runtime_type = ""       runtime_engine = ""       runtime_root = ""       privileged_without_host_devices = false     [plugins."io.containerd.grpc.v1.cri".containerd.untrusted_workload_runtime]       runtime_type = ""       runtime_engine = ""       runtime_root = ""       privileged_without_host_devices = false     [plugins."io.containerd.grpc.v1.cri".containerd.runtimes]       [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc]         runtime_type = "io.containerd.runc.v2"         runtime_engine = ""         runtime_root = ""         privileged_without_host_devices = false         [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc.options]           BinaryName = ""           CriuImagePath = ""           CriuPath = ""           CriuWorkPath = ""           IoGid = 0       [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.kata]          runtime_type = "io.containerd.kata.v2"          pod_annotations = ["io.kata-containers.*"]          privileged_without_host_devices = true          container_annotations = ["io.katacontainers.*"]        [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.kata.options]           ConfigPath = "/etc/kata-containers/configuration.toml"   [plugins."io.containerd.grpc.v1.cri".cni]     bin_dir = "/opt/cni/bin"     conf_dir = "/etc/cni/net.d"     max_conf_num = 1     conf_template = ""

-cri工具配置 将CNI配置设置为/etc/CNI/net.d/10-mynet.conf:

{   "cniVersion": "0.2.0",   "name": "mynet",   "type": "bridge",   "bridge": "cni0",   "isGateway": true,   "ipMasq": true,   "ipam": {   "type": "host-local",   "subnet": "172.19.0.0/24",   "routes": [   { "dst": "0.0.0.0/0" }           ]   } }

最后,我试图用ctr命令行启动容器,但在第二个命令中出错: $sudo-ctr-image pull-docker.io/library/bussybox:最新

$ sudo ctr run --cni --runtime io.containerd.run.kata.v2 -t --rm docker.io/library/busybox:latest hello sh ctr: dial unix /run/containerd/s/f89a747f6a50d5c2ffc699d28a658410899f12d03fa638893cc55d2da1cf53f6: connect: connection refused: unknown

我的qemu版本:

$ /usr/bin/qemu-system-x86_64 --version QEMU emulator version 6.2.0 (kata-static) Copyright (c) 2003-2021 Fabrice Bellard and the QEMU Project developers

容器状态:

$ systemctl status containerd  ● containerd.service - containerd container runtime      Loaded: loaded (/etc/systemd/system/containerd.service; enabled; vendor preset: enabled)      Active: active (running) since Sat 2022-11-26 15:18:59 CET; 20h ago        Docs: https://containerd.io    Main PID: 3958910 (containerd)       Tasks: 27 (limit: 153351)      Memory: 32.5M         CPU: 1min 21.403s      CGroup: /system.slice/containerd.service              └─3958910 /usr/local/bin/containerd

jouranlctl:

Nov 27 11:42:40 Epyc-condor sudo[389269]:     ziyi : TTY=pts/4 ; PWD=/home/ziyi ; USER=root ; COMMAND=/usr/local/bin/ctr run --runtime io.containerd.run.kata.v2 -t --rm docker.io/library/busybox:latest hello sh Nov 27 11:42:40 Epyc-condor sudo[389269]: pam_unix(sudo:session): session opened for user root(uid=0) by (uid=1005) Nov 27 11:42:41 Epyc-condor sudo[389269]: pam_unix(sudo:session): session closed for user root Nov 27 11:42:48 Epyc-condor systemd[324736]: run.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345-userdata.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345-userdata-shm.mount: Changed dead -> mounted Nov 27 11:42:48 Epyc-condor systemd[324736]: run.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345-userdata.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-netns.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-ipcns.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-utsns.mount: Failed to load configuration: No such file or directory Nov 27 11:42:48 Epyc-condor systemd[324736]: run-netns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Changed dead -> mounted Nov 27 11:42:48 Epyc-condor systemd[324736]: run-ipcns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Changed dead -> mounted Nov 27 11:42:48 Epyc-condor systemd[324736]: run-utsns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Changed dead -> mounted Nov 27 11:42:48 Epyc-condor systemd[324736]: run-utsns.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-ipcns.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-netns.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-netns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Deactivated successfully. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-netns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Changed mounted -> dead Nov 27 11:42:48 Epyc-condor systemd[324736]: run-ipcns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Deactivated successfully. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-ipcns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Changed mounted -> dead Nov 27 11:42:48 Epyc-condor systemd[324736]: run-utsns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Deactivated successfully. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-utsns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Changed mounted -> dead Nov 27 11:42:48 Epyc-condor systemd[324736]: run-utsns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-ipcns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-netns-b59a509d\x2d22aa\x2d4106\x2db242\x2dfc2f4b14c9b2.mount: Collecting. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345-userdata-shm.mount: Deactivated successfully. Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345-userdata-shm.mount: Changed mounted -> dead Nov 27 11:42:48 Epyc-condor systemd[324736]: run-containers-storage-overlay\x2dcontainers-153207f7528cdca6c69ce3a16274fae1fffc515eccb44bcb0591f8f0fe8f2345-userdata-shm.mount: Collecting. Nov 27 11:42:49 Epyc-condor systemd[324736]: sys-subsystem-net-devices-vethe4fc543a.device: Changed dead -> plugged Nov 27 11:42:49 Epyc-condor systemd[324736]: sys-devices-virtual-net-vethe4fc543a.device: Changed dead -> plugged Nov 27 11:42:49 Epyc-condor systemd[324736]: sys-subsystem-net-devices-vethe4fc543a.device: Changed plugged -> dead Nov 27 11:42:49 Epyc-condor systemd[324736]: sys-devices-virtual-net-vethe4fc543a.device: Changed plugged -> dead Nov 27 11:42:49 Epyc-condor systemd[324736]: sys-devices-virtual-net-vethe4fc543a.device: Collecting. Nov 27 11:42:49 Epyc-condor systemd[324736]: sys-subsystem-net-devices-vethe4fc543a.device: Collecting.

/etc/kata-containers/configuration.toml:

Copyright (c) 2017-2019 Intel Corporation

Copyright (c) 2021 Adobe Inc.

SPDX-License-Identifier: Apache-2.0

XXX: WARNING: this file is auto-generated.

XXX:

XXX: Source file: "config/configuration-qemu.toml.in"

XXX: Project:

XXX:   Name: Kata Containers

XXX:   Type: kata

[hypervisor.qemu] path = "/usr/bin/qemu-system-x86_64" kernel = "/usr/share/kata-containers/vmlinux.container" image = "/usr/share/kata-containers/kata-containers.img"

initrd = "/usr/share/kata-containers/kata-containers-initrd.img"

machine_type = "q35"

Enable confidential guest support.

Toggling that setting may trigger different hardware features, ranging

from memory encryption to both memory and CPU-state encryption and integrity.

The Kata Containers runtime dynamically detects the available feature set and

aims at enabling the largest possible one, returning an error if none is

available, or none is supported by the hypervisor.

Known limitations:

* Does not work by design:

#   - CPU Hotplug  #   - Memory Hotplug #   - NVDIMM devices

Default false

confidential_guest = true

Choose AMD SEV-SNP confidential guests

In case of using confidential guests on AMD hardware that supports both SEV

and SEV-SNP, the following enables SEV-SNP guests. SEV guests are default.

Default false

sev_snp_guest = true

Enable running QEMU VMM as a non-root user.

By default QEMU VMM run as root. When this is set to true, QEMU VMM process runs as

a non-root random user. See documentation for the limitations of this mode.

rootless = true

List of valid annotation names for the hypervisor

Each member of the list is a regular expression, which is the base name

of the annotation, e.g. "path" for io.katacontainers.config.hypervisor.path"

enable_annotations = ["enable_iommu"]

List of valid annotations values for the hypervisor

Each member of the list is a path pattern as described by glob(3).

The default if not set is empty (all annotations rejected.)

Your distribution recommends: ["/usr/bin/qemu-system-x86_64"]

valid_hypervisor_paths = ["/usr/bin/qemu-system-x86_64"]

Optional space-separated list of options to pass to the guest kernel.

For example, use kernel_params = "vsyscall=emulate" if you are having

trouble running pre-2.15 glibc.

WARNING: - any parameter specified here will take priority over the default

parameter value of the same name used to start the virtual machine.

Do not set values here unless you understand the impact of doing so as you

may stop the virtual machine from booting.

To see the list of default parameters, enable hypervisor debug, create a

container and look for 'default-kernel-parameters' log entries.

kernel_params = " agent.log=debug initcall_debug"

Path to the firmware.

If you want that qemu uses the default firmware leave this option empty

firmware = ""

Path to the firmware volume.

firmware TDVF or OVMF can be split into FIRMWARE_VARS.fd (UEFI variables

as configuration) and FIRMWARE_CODE.fd (UEFI program image). UEFI variables

can be customized per each user while UEFI code is kept same.

firmware_volume = ""

Machine accelerators

comma-separated list of machine accelerators to pass to the hypervisor.

For example, machine_accelerators = "nosmm,nosmbus,nosata,nopit,static-prt,nofw"

machine_accelerators=""

Qemu seccomp sandbox feature

comma-separated list of seccomp sandbox features to control the syscall access.

For example, seccompsandbox= "on,obsolete=deny,spawn=deny,resourcecontrol=deny"

Note: "elevateprivileges=deny" doesn't work with daemonize option, so it's removed from the seccomp sandbox

Another note: enabling this feature may reduce performance, you may enable

/proc/sys/net/core/bpf_jit_enable to reduce the impact. see https://man7.org/linux/man-pages/man8/bpfc.8.html

#seccompsandbox="on,obsolete=deny,spawn=deny,resourcecontrol=deny"

CPU features

comma-separated list of cpu features to pass to the cpu

For example, `cpu_features = "pmu=off,vmx=off"

cpu_features="pmu=off"

vCPUs pinning settings

if enabled, each vCPU thread will be scheduled to a fixed CPU

qualified condition: num(vCPU threads) == num(CPUs in sandbox's CPUSet)

enable_vcpus_pinning = false

Default number of vCPUs per SB/VM:

unspecified or 0                --> will be set to 1

< 0                             --> will be set to the actual number of physical cores

> 0 <= number of physical cores --> will be set to the specified number

> number of physical cores      --> will be set to the actual number of physical cores

default_vcpus = 1

Default maximum number of vCPUs per SB/VM:

unspecified or == 0             --> will be set to the actual number of physical cores or to the maximum number

#                                     of vCPUs supported by KVM if that number is exceeded

> 0 <= number of physical cores --> will be set to the specified number

> number of physical cores      --> will be set to the actual number of physical cores or to the maximum number

#                                     of vCPUs supported by KVM if that number is exceeded

WARNING: Depending of the architecture, the maximum number of vCPUs supported by KVM is used when

the actual number of physical cores is greater than it.

WARNING: Be aware that this value impacts the virtual machine's memory footprint and CPU

the hotplug functionality. For example, default_maxvcpus = 240 specifies that until 240 vCPUs

can be added to a SB/VM, but the memory footprint will be big. Another example, with

default_maxvcpus = 8 the memory footprint will be small, but 8 will be the maximum number of

vCPUs supported by the SB/VM. In general, we recommend that you do not edit this variable,

unless you know what are you doing.

NOTICE: on arm platform with gicv2 interrupt controller, set it to 8.

default_maxvcpus = 0

Bridges can be used to hot plug devices.

Limitations:

* Currently only pci bridges are supported

* Until 30 devices per bridge can be hot plugged.

* Until 5 PCI bridges can be cold plugged per VM.

#   This limitation could be a bug in qemu or in the kernel

Default number of bridges per SB/VM:

unspecified or 0   --> will be set to 1

> 1 <= 5           --> will be set to the specified number

> 5                --> will be set to 5

default_bridges = 1

Default memory size in MiB for SB/VM.

If unspecified then it will be set 2048 MiB.

default_memory = 2048

Default memory slots per SB/VM.

If unspecified then it will be set 10.

This is will determine the times that memory will be hotadded to sandbox/VM.

#memory_slots = 10

Default maximum memory in MiB per SB / VM

unspecified or == 0           --> will be set to the actual amount of physical RAM

> 0 <= amount of physical RAM --> will be set to the specified number

> amount of physical RAM      --> will be set to the actual amount of physical RAM

default_maxmemory = 0

The size in MiB will be plused to max memory of hypervisor.

It is the memory address space for the NVDIMM devie.

If set block storage driver (block_device_driver) to "nvdimm",

should set memory_offset to the size of block device.

Default 0

#memory_offset = 0

Specifies virtio-mem will be enabled or not.

Please note that this option should be used with the command

"echo 1 > /proc/sys/vm/overcommit_memory".

Default false

#enable_virtio_mem = true

Disable block device from being used for a container's rootfs.

In case of a storage driver like devicemapper where a container's

root file system is backed by a block device, the block device is passed

directly to the hypervisor for performance reasons.

This flag prevents the block device from being passed to the hypervisor,

virtio-fs is used instead to pass the rootfs.

disable_block_device_use = false

Shared file system type:

#   - virtio-fs (default) #   - virtio-9p #   - virtio-fs-nydus shared_fs = "virtio-fs"

Path to vhost-user-fs daemon.

virtio_fs_daemon = "/usr/bin/virtiofsd"

List of valid annotations values for the virtiofs daemon

The default if not set is empty (all annotations rejected.)

Your distribution recommends: ["/usr/libexec/virtiofsd"]

valid_virtio_fs_daemon_paths = ["/usr/libexec/virtiofsd"]

Default size of DAX cache in MiB

virtio_fs_cache_size = 0

Extra args for virtiofsd daemon

Format example:

#   ["-o", "arg1=xxx,arg2", "-o", "hello world", "--arg3=yyy"]

Examples:

#   Set virtiofsd log level to debug : ["-o", "log_level=debug"] or ["-d"]

see virtiofsd -h for possible options.

virtio_fs_extra_args = ["--thread-pool-size=1", "-o", "announce_submounts"]

Cache mode:

#  - none #    Metadata, data, and pathname lookup are not cached in guest. They are #    always fetched from host and any changes are immediately pushed to host.

#  - auto #    Metadata and pathname lookup cache expires after a configured amount of #    time (default is 1 second). Data is cached while the file is open (close #    to open consistency).

#  - always #    Metadata, data, and pathname lookup are cached in guest and never expire. virtio_fs_cache = "auto"

Block storage driver to be used for the hypervisor in case the container

rootfs is backed by a block device. This is virtio-scsi, virtio-blk

or nvdimm.

block_device_driver = "virtio-scsi"

aio is the I/O mechanism used by qemu

Options:

#   - threads #     Pthread based disk I/O.

#   - native #     Native Linux I/O.

#   - io_uring #     Linux io_uring API. This provides the fastest I/O operations on Linux, requires kernel>5.1 and #     qemu >=5.0. block_device_aio = "io_uring"

Specifies cache-related options will be set to block devices or not.

Default false

#block_device_cache_set = true

Specifies cache-related options for block devices.

Denotes whether use of O_DIRECT (bypass the host page cache) is enabled.

Default false

#block_device_cache_direct = true

Specifies cache-related options for block devices.

Denotes whether flush requests for the device are ignored.

Default false

#block_device_cache_noflush = true

Enable iothreads (data-plane) to be used. This causes IO to be

handled in a separate IO thread. This is currently only implemented

for SCSI.

enable_iothreads = false

Enable pre allocation of VM RAM, default false

Enabling this will result in lower container density

as all of the memory will be allocated and locked

This is useful when you want to reserve all the memory

upfront or in the cases where you want memory latencies

to be very predictable

Default false

#enable_mem_prealloc = true

Enable huge pages for VM RAM, default false

Enabling this will result in the VM memory

being allocated using huge pages.

This is useful when you want to use vhost-user network

stacks within the container. This will automatically

result in memory pre allocation

#enable_hugepages = true

Enable vhost-user storage device, default false

Enabling this will result in some Linux reserved block type

major range 240-254 being chosen to represent vhost-user devices.

enable_vhost_user_store = false

The base directory specifically used for vhost-user devices.

Its sub-path "block" is used for block devices; "block/sockets" is

where we expect vhost-user sockets to live; "block/devices" is where

simulated block device nodes for vhost-user devices to live.

vhost_user_store_path = "/var/run/kata-containers/vhost-user"

Enable vIOMMU, default false

Enabling this will result in the VM having a vIOMMU device

This will also add the following options to the kernel's

command line: intel_iommu=on,iommu=pt

#enable_iommu = true

Enable IOMMU_PLATFORM, default false

Enabling this will result in the VM device having iommu_platform=on set

#enable_iommu_platform = true

List of valid annotations values for the vhost user store path

The default if not set is empty (all annotations rejected.)

Your distribution recommends: ["/var/run/kata-containers/vhost-user"]

valid_vhost_user_store_paths = ["/var/run/kata-containers/vhost-user"]

Enable file based guest memory support. The default is an empty string which

will disable this feature. In the case of virtio-fs, this is enabled

automatically and '/dev/shm' is used as the backing folder.

This option will be ignored if VM templating is enabled.

#file_mem_backend = ""

List of valid annotations values for the file_mem_backend annotation

The default if not set is empty (all annotations rejected.)

Your distribution recommends: [""]

valid_file_mem_backends = [""]

-pflash can add image file to VM. The arguments of it should be in format

of ["/path/to/flash0.img", "/path/to/flash1.img"]

pflashes = []

This option changes the default hypervisor and kernel parameters

to enable debug output where available.

Default false

enable_debug = true

Disable the customizations done in the runtime when it detects

that it is running on top a VMM. This will result in the runtime

behaving as it would when running on bare metal.

#disable_nesting_checks = true

This is the msize used for 9p shares. It is the number of bytes

used for 9p packet payload.

#msize_9p = 8192

If false and nvdimm is supported, use nvdimm device to plug guest image.

Otherwise virtio-block device is used.

nvdimm is not supported when confidential_guest = true.

Default is false

#disable_image_nvdimm = true

VFIO devices are hotplugged on a bridge by default.

Enable hotplugging on root bus. This may be required for devices with

a large PCI bar, as this is a current limitation with hotplugging on

a bridge.

Default false

#hotplug_vfio_on_root_bus = true

Before hot plugging a PCIe device, you need to add a pcie_root_port device.

Use this parameter when using some large PCI bar devices, such as Nvidia GPU

The value means the number of pcie_root_port

This value is valid when hotplug_vfio_on_root_bus is true and machine_type is "q35"

Default 0

#pcie_root_port = 2

If vhost-net backend for virtio-net is not desired, set to true. Default is false, which trades off

security (vhost-net runs ring0) for network I/O performance.

#disable_vhost_net = true

Default entropy source.

The path to a host source of entropy (including a real hardware RNG)

/dev/urandom and /dev/random are two main options.

Be aware that /dev/random is a blocking source of entropy.  If the host

runs out of entropy, the VMs boot time will increase leading to get startup

timeouts.

The source of entropy /dev/urandom is non-blocking and provides a

generally acceptable source of entropy. It should work well for pretty much

all practical purposes.

#entropy_source= "/dev/urandom"

List of valid annotations values for entropy_source

The default if not set is empty (all annotations rejected.)

Your distribution recommends: ["/dev/urandom","/dev/random",""]

valid_entropy_sources = ["/dev/urandom","/dev/random",""]

Path to OCI hook binaries in the guest rootfs.

This does not affect host-side hooks which must instead be added to

the OCI spec passed to the runtime.

You can create a rootfs with hooks by customizing the osbuilder scripts:

https://github.com/kata-containers/kata-containers/tree/main/tools/osbuilder

Hooks must be stored in a subdirectory of guest_hook_path according to their

hook type, i.e. "guest_hook_path/{prestart,poststart,poststop}".

The agent will scan these directories for executable files and add them, in

lexicographical order, to the lifecycle of the guest container.

Hooks are executed in the runtime namespace of the guest. See the official documentation:

https://github.com/opencontainers/runtime-spec/blob/v1.0.1/config.md#posix-platform-hooks

Warnings will be logged if any error is encountered while scanning for hooks,

but it will not abort container execution.

#guest_hook_path = "/usr/share/oci/hooks"

Use rx Rate Limiter to control network I/O inbound bandwidth(size in bits/sec for SB/VM).

In Qemu, we use classful qdiscs HTB(Hierarchy Token Bucket) to discipline traffic.

Default 0-sized value means unlimited rate.

#rx_rate_limiter_max_rate = 0

Use tx Rate Limiter to control network I/O outbound bandwidth(size in bits/sec for SB/VM).

In Qemu, we use classful qdiscs HTB(Hierarchy Token Bucket) and ifb(Intermediate Functional Block)

to discipline traffic.

Default 0-sized value means unlimited rate.

#tx_rate_limiter_max_rate = 0

Set where to save the guest memory dump file.

If set, when GUEST_PANICKED event occurred,

guest memeory will be dumped to host filesystem under guest_memory_dump_path,

This directory will be created automatically if it does not exist.

The dumped file(also called vmcore) can be processed with crash or gdb.

WARNING:

#   Dump guest’s memory can take very long depending on the amount of guest memory #   and use much disk space. #guest_memory_dump_path="/var/crash/kata"

If enable paging.

Basically, if you want to use "gdb" rather than "crash",

or need the guest-virtual addresses in the ELF vmcore,

then you should enable paging.

See: https://www.qemu.org/docs/master/qemu-qmp-ref.html#Dump-guest-memory for details

#guest_memory_dump_paging=false

Enable swap in the guest. Default false.

When enable_guest_swap is enabled, insert a raw file to the guest as the swap device

if the swappiness of a container (set by annotation "io.katacontainers.container.resource.swappiness")

is bigger than 0.

The size of the swap device should be

swap_in_bytes (set by annotation "io.katacontainers.container.resource.swap_in_bytes") - memory_limit_in_bytes.

If swap_in_bytes is not set, the size should be memory_limit_in_bytes.

If swap_in_bytes and memory_limit_in_bytes is not set, the size should

be default_memory.

#enable_guest_swap = true

use legacy serial for guest console if available and implemented for architecture. Default false

#use_legacy_serial = true

disable applying SELinux on the VMM process (default false)

disable_selinux=false

[factory]

VM templating support. Once enabled, new VMs are created from template

using vm cloning. They will share the same initial kernel, initramfs and

agent memory by mapping it readonly. It helps speeding up new container

creation and saves a lot of memory if there are many kata containers running

on the same host.

When disabled, new VMs are created from scratch.

Note: Requires "initrd=" to be set ("image=" is not supported).

Default false

#enable_template = true

Specifies the path of template.

Default "/run/vc/vm/template"

#template_path = "/run/vc/vm/template"

The number of caches of VMCache:

unspecified or == 0   --> VMCache is disabled

> 0                   --> will be set to the specified number

VMCache is a function that creates VMs as caches before using it.

It helps speed up new container creation.

The function consists of a server and some clients communicating

through Unix socket.  The protocol is gRPC in protocols/cache/cache.proto.

The VMCache server will create some VMs and cache them by factory cache.

It will convert the VM to gRPC format and transport it when gets

requestion from clients.

Factory grpccache is the VMCache client.  It will request gRPC format

VM and convert it back to a VM.  If VMCache function is enabled,

kata-runtime will request VM from factory grpccache when it creates

a new sandbox.

Default 0

#vm_cache_number = 0

Specify the address of the Unix socket that is used by VMCache.

Default /var/run/kata-containers/cache.sock

#vm_cache_endpoint = "/var/run/kata-containers/cache.sock"

[agent.kata]

If enabled, make the agent display debug-level messages.

(default: disabled)

enable_debug = true

Enable agent tracing.

If enabled, the agent will generate OpenTelemetry trace spans.

Notes:

- If the runtime also has tracing enabled, the agent spans will be

#   associated with the appropriate runtime parent span.

- If enabled, the runtime will wait for the container to shutdown,

#   increasing the container shutdown time slightly.

(default: disabled)

#enable_tracing = true

Comma separated list of kernel modules and their parameters.

These modules will be loaded in the guest kernel using modprobe(8).

The following example can be used to load two kernel modules with parameters

#  - kernel_modules=["e1000e InterruptThrottleRate=3000,3000,3000 EEE=1", "i915 enable_ppgtt=0"]

The first word is considered as the module name and the rest as its parameters.

Container will not be started when:

#  * A kernel module is specified and the modprobe command is not installed in the guest #    or it fails loading the module. #  * The module is not available in the guest or it doesn't met the guest kernel #    requirements, like architecture and version.

kernel_modules=[]

Enable debug console.

If enabled, user can connect guest OS running inside hypervisor

through "kata-runtime exec " command

#debug_console_enabled = true

Agent connection dialing timeout value in seconds

(default: 30)

#dial_timeout = 30

[runtime]

If enabled, the runtime will log additional debug messages to the

system log

(default: disabled)

enable_debug = true

Internetworking model

Determines how the VM should be connected to the

the container network interface

Options:

#   - macvtap #     Used when the Container network interface can be bridged using #     macvtap.

#   - none #     Used when customize network. Only creates a tap device. No veth pair.

#   - tcfilter #     Uses tc filter rules to redirect traffic from the network interface #     provided by plugin to a tap interface connected to the VM.

internetworking_model="tcfilter"

disable guest seccomp

Determines whether container seccomp profiles are passed to the virtual

machine and applied by the kata agent. If set to true, seccomp is not applied

within the guest

(default: true)

disable_guest_seccomp=false

If enabled, the runtime will create opentracing.io traces and spans.

(See https://www.jaegertracing.io/docs/getting-started).

(default: disabled)

#enable_tracing = true

Set the full url to the Jaeger HTTP Thrift collector.

The default if not set will be "http://localhost:14268/api/traces"

#jaeger_endpoint = ""

Sets the username to be used if basic auth is required for Jaeger.

#jaeger_user = ""

Sets the password to be used if basic auth is required for Jaeger.

#jaeger_password = ""

If enabled, the runtime will not create a network namespace for shim and hypervisor processes.

This option may have some potential impacts to your host. It should only be used when you know what you're doing.

disable_new_netns conflicts with internetworking_model=tcfilter and internetworking_model=macvtap. It works only

with internetworking_model=none. The tap device will be in the host network namespace and can connect to a bridge

(like OVS) directly.

(default: false)

#disable_new_netns = true

if enabled, the runtime will add all the kata processes inside one dedicated cgroup.

The container cgroups in the host are not created, just one single cgroup per sandbox.

The runtime caller is free to restrict or collect cgroup stats of the overall Kata sandbox.

The sandbox cgroup path is the parent cgroup of a container with the PodSandbox annotation.

The sandbox cgroup is constrained if there is no container type annotation.

See: https://pkg.go.dev/github.com/kata-containers/kata-containers/src/runtime/virtcontainers#ContainerType

sandbox_cgroup_only=false

If enabled, the runtime will attempt to determine appropriate sandbox size (memory, CPU) before booting the virtual machine. In

this case, the runtime will not dynamically update the amount of memory and CPU in the virtual machine. This is generally helpful

when a hardware architecture or hypervisor solutions is utilized which does not support CPU and/or memory hotplug.

Compatibility for determining appropriate sandbox (VM) size:

- When running with pods, sandbox sizing information will only be available if using Kubernetes >= 1.23 and containerd >= 1.6. CRI-O

#   does not yet support sandbox sizing annotations.

- When running single containers using a tool like ctr, container sizing information will be available.

static_sandbox_resource_mgmt=false

If specified, sandbox_bind_mounts identifieds host paths to be mounted (ro) into the sandboxes shared path.

This is only valid if filesystem sharing is utilized. The provided path(s) will be bindmounted into the shared fs directory.

If defaults are utilized, these mounts should be available in the guest at /run/kata-containers/shared/containers/sandbox-mounts

These will not be exposed to the container workloads, and are only provided for potential guest services.

sandbox_bind_mounts=[]

VFIO Mode

Determines how VFIO devices should be be presented to the container.

Options:

#  - vfio #    Matches behaviour of OCI runtimes (e.g. runc) as much as #    possible.  VFIO devices will appear in the container as VFIO #    character devices under /dev/vfio.  The exact names may differ #    from the host (they need to match the VM's IOMMU group numbers #    rather than the host's)

#  - guest-kernel #    This is a Kata-specific behaviour that's useful in certain cases. #    The VFIO device is managed by whatever driver in the VM kernel #    claims it.  This means it will appear as one or more device nodes #    or network interfaces depending on the nature of the device. #    Using this mode requires specially built workloads that know how #    to locate the relevant device interfaces within the VM.

vfio_mode="guest-kernel"

If enabled, the runtime will not create Kubernetes emptyDir mounts on the guest filesystem. Instead, emptyDir mounts will

be created on the host and shared via virtio-fs. This is potentially slower, but allows sharing of files from host to guest.

disable_guest_empty_dir=false

Enabled experimental feature list, format: ["a", "b"].

Experimental features are features not stable enough for production,

they may break compatibility, and are prepared for a big version bump.

Supported experimental features:

(default: [])

experimental=[]

If enabled, user can run pprof tools with shim v2 process through kata-monitor.

(default: false)

enable_pprof = true

WARNING: All the options in the following section have not been implemented yet.

This section was added as a placeholder. DO NOT USE IT!

[image]

Container image service.

Offload the CRI image management service to the Kata agent.

(default: false)

#service_offload = true

Container image decryption keys provisioning.

Applies only if service_offload is true.

Keys can be provisioned locally (e.g. through a special command or

a local file) or remotely (usually after the guest is remotely attested).

The provision setting is a complete URL that lets the Kata agent decide

which method to use in order to fetch the keys.

Keys can be stored in a local file, in a measured and attested initrd:

#provision=data:///local/key/file

Keys could be fetched through a special command or binary from the

initrd (guest) image, e.g. a firmware call:

#provision=file:///path/to/bin/fetcher/in/guest

Keys can be remotely provisioned. The Kata agent fetches them from e.g.

a HTTPS URL:

#provision=https://my-key-broker.foo/tenant/

这是容器日志: $ sudo journalctl -xe -t containerd 然后得到了下面这些:

Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386022105+01:00" level=debug msg="removed snapshot" key=default/38/hello snapshotter=overlayfs Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386252281+01:00" level=debug msg="snapshot garbage collected" d=2.159584ms snapshotter=overlayfs Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386271561+01:00" level=debug msg="garbage collected" d=2.049551ms Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.752608985+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.772114713+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.777016286+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.780666537+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.800455671+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.803254761+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.823704423+01:00" level=error msg="copy shim log" error="reading from a closed fifo" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.824785970+01:00" level=debug msg="remove snapshot" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.826851982+01:00" level=debug msg="event published" ns=default topic=/snapshot/remove type=containerd.events.SnapshotRemove Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.829030276+01:00" level=debug msg="event published" ns=default topic=/containers/delete type=containerd.events.ContainerDelete Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.883283133+01:00" level=debug msg="schedule snapshotter cleanup" snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885191070+01:00" level=debug msg="removed snapshot" key=default/39/hello snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885446547+01:00" level=debug msg="snapshot garbage collected" d=2.125703ms snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885466677+01:00" level=debug msg="garbage collected" d=2.102232ms Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.012030209+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.029897337+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.034329977+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.039313962+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.058789059+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.061611229+01:00" level=debug msg="get Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386022105+01:00" level=debug msg="re> Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386252281+01:00" level=debug msg="sn> Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386271561+01:00" level=debug msg="ga> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.752608985+01:00" level=debug msg="st> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.772114713+01:00" level=debug msg="pr> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.777016286+01:00" level=debug msg="ev> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.780666537+01:00" level=debug msg="ge> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.800455671+01:00" level=debug msg="ev> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.803254761+01:00" level=debug msg="ge> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.823704423+01:00" level=error msg="co> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.824785970+01:00" level=debug msg="re> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.826851982+01:00" level=debug msg="ev> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.829030276+01:00" level=debug msg="ev> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.883283133+01:00" level=debug msg="sc> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885191070+01:00" level=debug msg="re> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885446547+01:00" level=debug msg="sn> Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885466677+01:00" level=debug msg="ga> Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.012030209+01:00" level=debug msg="st> Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.029897337+01:00" level=debug msg="pr> Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.034329977+01:00" level=debug msg="ev> Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.039313962+01:00" level=debug msg="ge> Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.058789059+01:00" level=debug msg="ev> Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.061611229+01:00" level=debug Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386022105+01:00" level=debug msg="removed snapshot" key=default/38/hello snapshotter=overlayfs Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386252281+01:00" level=debug msg="snapshot garbage collected" d=2.159584ms snapshotter=overlayfs Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386271561+01:00" level=debug msg="garbage collected" d=2.049551ms Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.752608985+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.772114713+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.777016286+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.780666537+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.800455671+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.803254761+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.823704423+01:00" level=error msg="copy shim log" error="reading from a closed fifo" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.824785970+01:00" level=debug msg="remove snapshot" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.826851982+01:00" level=debug msg="event published" ns=default topic=/snapshot/remove type=containerd.events.SnapshotRemove Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.829030276+01:00" level=debug msg="event published" ns=default topic=/containers/delete type=containerd.events.ContainerDelete Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.883283133+01:00" level=debug msg="schedule snapshotter cleanup" snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885191070+01:00" level=debug msg="removed snapshot" key=default/39/hello snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885446547+01:00" level=debug msg="snapshot garbage collected" d=2.125703ms snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885466677+01:00" level=debug msg="garbage collected" d=2.102232ms Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.012030209+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.029897337+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.034329977+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.039313962+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.058789059+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.061611229+01:00" level=debug msg="get Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386022105+01:00" level=debug msg="removed snapshot" key=default/38/hello snapshotter=overlayfs Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386252281+01:00" level=debug msg="snapshot garbage collected" d=2.159584ms snapshotter=overlayfs Nov 27 11:37:19 Epyc-condor containerd[3958910]: time="2022-11-27T11:37:19.386271561+01:00" level=debug msg="garbage collected" d=2.049551ms Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.752608985+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.772114713+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.777016286+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.780666537+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.800455671+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.803254761+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.823704423+01:00" level=error msg="copy shim log" error="reading from a closed fifo" Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.824785970+01:00" level=debug msg="remove snapshot" key=hello Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.826851982+01:00" level=debug msg="event published" ns=default topic=/snapshot/remove type=containerd.events.SnapshotRemove Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.829030276+01:00" level=debug msg="event published" ns=default topic=/containers/delete type=containerd.events.ContainerDelete Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.883283133+01:00" level=debug msg="schedule snapshotter cleanup" snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885191070+01:00" level=debug msg="removed snapshot" key=default/39/hello snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885446547+01:00" level=debug msg="snapshot garbage collected" d=2.125703ms snapshotter=overlayfs Nov 27 11:41:33 Epyc-condor containerd[3958910]: time="2022-11-27T11:41:33.885466677+01:00" level=debug msg="garbage collected" d=2.102232ms Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.012030209+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.029897337+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.034329977+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.039313962+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.058789059+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.061611229+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.078311366+01:00" level=error msg="copy shim log" error="reading from a closed fifo" Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.079392814+01:00" level=debug msg="remove snapshot" key=hello Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.081360543+01:00" level=debug msg="event published" ns=default topic=/snapshot/remove type=containerd.events.SnapshotRemove Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.086517372+01:00" level=debug msg="event published" ns=default topic=/containers/delete type=containerd.events.ContainerDelete Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.170713057+01:00" level=debug msg="schedule snapshotter cleanup" snapshotter=overlayfs Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.172722757+01:00" level=debug msg="removed snapshot" key=default/40/hello snapshotter=overlayfs Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.172953733+01:00" level=debug msg="snapshot garbage collected" d=2.212885ms snapshotter=overlayfs Nov 27 11:42:41 Epyc-condor containerd[3958910]: time="2022-11-27T11:42:41.172974453+01:00" level=debug msg="garbage collected" d=1.943199ms Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.607562751+01:00" level=debug msg="stat snapshot" key="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.626513345+01:00" level=debug msg="prepare snapshot" key=hello parent="sha256:40cf597a9181e86497f4121c604f9f0ab208950a98ca21db883f26b0a548a2eb" Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.630988227+01:00" level=debug msg="event published" ns=default topic=/snapshot/prepare type=containerd.events.SnapshotPrepare Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.635402797+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.646910084+01:00" level=debug msg="event published" ns=default topic=/containers/create type=containerd.events.ContainerCreate Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.649614422+01:00" level=debug msg="get snapshot mounts" key=hello Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.667079478+01:00" level=error msg="copy shim log" error="reading from a closed fifo" Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.668022012+01:00" level=debug msg="remove snapshot" key=hello Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.670075893+01:00" level=debug msg="event published" ns=default topic=/snapshot/remove type=containerd.events.SnapshotRemove Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.672154775+01:00" level=debug msg="event published" ns=default topic=/containers/delete type=containerd.events.ContainerDelete Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.739818316+01:00" level=debug msg="schedule snapshotter cleanup" snapshotter=overlayfs Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.741725053+01:00" level=debug msg="removed snapshot" key=default/41/hello snapshotter=overlayfs Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.741987830+01:00" level=debug msg="snapshot garbage collected" d=2.129043ms snapshotter=overlayfs Nov 27 11:55:08 Epyc-condor containerd[3958910]: time="2022-11-27T11:55:08.742010781+01:00" level=debug msg="garbage collected" d=2.799329ms

不知道是什么导致的报错。

原提问者GitHub用户immersommer 如对项目有进一步反馈,请在 GitHub 提交 issue https://github.com/kata-containers/kata-containers/issues

展开
收起
码字王 2023-05-17 16:10:53 553 0
2 条回答
写回答
取消 提交回答
  • 值得去的地方都没有捷径

    你的错误信息表明与containerd的连接被拒绝,而这可能是由多种原因引起的。这里有几种解决方法:

    确保Kata-Containers已正确安装并配置 请检查Kata-Containers的安装和配置,确保它已正确安装并与你的containerd集成。你可以查看Kata-Containers的文档以获取更多信息:https://katacontainers.io/docs/getting-started/

    确认containerd正在运行 请检查你的containerd是否正在运行。你可以运行以下命令来检查:

    systemctl status containerd 如果它未在运行中,则需启动containerd服务。

    检查containerd的配置 请检查containerd的配置文件是否有必要的设置以运行Kata-Containers。你可以查看containerd的文档以获取更多信息:https://containerd.io/docs/

    检查容器运行时版本 请确保你正在使用与Kata-Containers兼容的containerd版本。你可以参考官方文档以查看哪些版本与Kata-Containers兼容:https://katacontainers.io/docs/installation/requirements/#containerd-requirements

    如果尝试了以上几种方法,仍然遇到问题,请检查Kata-Containers的GitHub问题跟踪器以获取帮助:https://github.com/kata-containers/kata-containers/issues.

    2023-05-18 18:42:37
    赞同 展开评论 打赏
  • 随心分享,欢迎友善交流讨论:)

    这个错误可能是由于Kata-Containers运行时未正确安装或配置导致的。建议您先检查一下Kata-Containers运行时是否正确安装和配置,可以按照以下步骤进行操作:

    确认您的Ubuntu版本是否支持Kata-Containers运行时。Kata-Containers支持的Ubuntu版本包括Ubuntu 18.04、20.04和21.04,不支持Ubuntu 22.04。

    安装Kata-Containers运行时。可以按照官方文档的指引,通过apt-get命令或deb包的方式安装Kata-Containers运行时。安装完成后,需要配置containerd以使用Kata-Containers运行时。

    配置containerd以支持Kata-Containers运行时。可以按照官方文档的指引,编辑containerd的配置文件,添加Kata-Containers运行时的配置项。确保配置信息正确无误,并重启containerd服务。

    使用ctr命令行启动容器。可以使用ctr命令行来启动容器,并指定Kata-Containers运行时。例如,可以使用以下命令行启动一个busybox容器:

    sudo ctr run --runtime io.containerd.runtime.v2.task.kata.v2 -t --rm docker.io/library/busybox:latest hello sh

    需要注意的是,以上步骤仅供参考,具体操作方式可能因不同版本的Kata-Containers和Ubuntu而有所不同。建议您参考Kata-Containers和Ubuntu的官方文档,或向技术支持人员咨询,以获取更准确的帮助和指导。

    2023-05-17 17:20:15
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载