您的位置:

containerd命令详解

一、containerd概述

containerd是一个轻量级的容器运行时管理工具,它由Docker团队开发并贡献给CNCF开源组织。containerd通过提供一组API来管理容器生命周期,并具有以下特点:

1. 将容器生命周期管理与容器运行时进行了分离,将其作为独立的进程运行。

2. 支持多种容器管理工具,如Docker、Kubernetes等。

3. 支持CRI(Container Runtime Interface),使得可以通过CRI来管理容器的生命周期。

二、containerd架构

containerd包含下面几个核心模块:

1. containerd-shim: 它负责与containerd交互并管理容器的启动、停止、重启操作。

2. containerd-ctr: 它是一个命令行工具,提供了一组可用的API,允许用户执行容器操作,例如启动、停止、重启等。

3. containerd: 它是一个后台进程,负责管理镜像、容器、快照等资源,并提供API进行管理。

例子:通过containerd-ctr命令获取所有的容器信息
sudo containerd-ctr --address /run/containerd/containerd.sock --namespace /run/containerd/io.containerd.runtime.v1.linux list

三、containerd-ctr使用

containerd-ctr是一个命令行工具,通过它可以很方便的管理容器。下面介绍一些常用命令:

1. 获取所有容器信息

sudo containerd-ctr --address /run/containerd/containerd.sock --namespace /run/containerd/io.containerd.runtime.v1.linux list

2. 启动容器

sudo containerd-ctr --address /run/containerd/containerd.sock --namespace /run/containerd/io.containerd.runtime.v1.linux start [容器ID]

3. 停止容器

sudo containerd-ctr --address /run/containerd/containerd.sock --namespace /run/containerd/io.containerd.runtime.v1.linux kill [容器ID]

4. 容器日志输出

sudo containerd-ctr --address /run/containerd/containerd.sock --namespace /run/containerd/io.containerd.runtime.v1.linux logs [容器ID]

四、与Docker结合

containerd是由Docker团队开发的工具,因此与Docker的结合也非常容易。Docker默认是使用containerd作为其容器运行时管理工具。

1. Docker中使用的containerd socket地址为:/run/docker/containerd/docker-containerd.sock。

2. Docker提供了管理容器的CLI工具docker,但实际上它也是通过调用containerd API来实现容器管理的。

3. 如果使用containerd实现容器管理,可以直接使用containerd-ctr命令来替代docker命令进行容器管理。

五、容器快照

容器快照是指将容器文件系统的状态进行持久化,以便于后续重复使用。在containerd中,可以通过执行以下命令来进行容器快照管理:

1. 获取快照列表

sudo ctr --address /run/containerd/containerd.sock snapshot ls [容器ID] 

2. 创建容器快照

sudo ctr --address /run/containerd/containerd.sock snapshot create [容器ID] [快照名字]

3. 恢复容器快照

sudo ctr --address /run/containerd/containerd.sock snapshot restore [快照名字] [新容器名字]

六、容器镜像

与Docker相同,containerd也支持容器镜像管理。可以使用containerd-cli或ctr工具来拉取、推送、删除等容器镜像。

1. 获取镜像列表

sudo ctr --address /run/containerd/containerd.sock image list

2. 拉取镜像

sudo ctr --address /run/containerd/containerd.sock image pull busybox

3. 推送镜像

sudo ctr --address /run/containerd/containerd.sock image push busybox

4. 删除镜像

sudo ctr --address /run/containerd/containerd.sock image remove busybox

七、容器网络

容器网络是指一组容器互相通讯的集合。在containerd中,可以使用CNI(Container Network Interface)插件来管理容器网络。

1. 安装CNI插件

sudo mkdir -p /opt/cni/bin
wget -qO- --show-progress https://github.com/containernetworking/plugins/releases/download/v0.9.1/cni-plugins-linux-amd64-v0.9.1.tgz | sudo tar xvz -C /opt/cni/bin/

2. 创建容器网络

sudo mkdir -p /etc/cni/net.d
sudo cp /opt/cni/bin/bridge /etc/cni/net.d/
sudo cp /opt/cni/bin/host-local /etc/cni/net.d/
sudo cp /opt/cni/bin/null /etc/cni/net.d/

3. 创建容器并加入容器网络

sudo ctr --address /run/containerd/containerd.sock container create --name test busybox 
sudo ctr --address /run/containerd/containerd.sock container start test
sudo ctr --address /run/containerd/containerd.sock container list
sudo ctr --address /run/containerd/containerd.sock task list test

八、结语

以上就是containerd命令的详细介绍。containerd是一个轻量级的容器运行时管理工具,非常适合作为容器引擎的后台组件来管理容器生命周期,同时也可以与Docker等容器管理工具进行无缝集成。