Containerd基础用法

文章介绍了containerd在Docker生态系统中的角色,作为容器运行时管理容器生命周期,与runc协作遵循OCI标准启动和管理容器。还详细说明了如何在Rocky8/RHEL8上安装containerd,并提到了ctr作为containerd的命令行工具,用于开发和调试环境中的镜像管理和容器操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1)关于Containerd的基础知识

从 Docker 1.11 版本开始,Docker 容器运行就不是简单通过 Docker Daemon 来启动了,而是通过集成containerd、runc等多个组件来完成的。

虽然Docker Daemon守护进程模块在不停地重构,但是基本功能和定位没有太大的变化,一直都是CS架构,守护进程负责和Docker Client端交互,并管理Docker镜像和容器。

现在的架构中组件containerd就会负责集群节点上容器的生命周期管理,并向上为Docker Daemon提供gRPC接口。

Containerd-shim是Containerd的一个插件,它用来扮演进程管理器的角色,接收来自containerd的命令,并在容器内部创建和管理进程。它可以与Runc协同工作,使得容器的创建、启动、停止、暂停和恢复等操作都能够得到有效的处理。一句话,创建容器这件事是由Containerd-shim来完成的。

我们都知道,创建容器是需要做一些namespaces和cgroups的配置,以及挂载root文件系统的操作。这些操作其实已经有了标准的规范,那就是OCI(开放容器标准)。

OCI本质上就是一个规范文档,主要规定了容器镜像的结构标准以及容器接收操作指令的标准,比如create、start、stop、delete 等这些命令。而Runc其实就是按照这个OCI的各种规范来实现管理容器的。

所以真正启动容器是通过containerd-shim去调用runc来启动容器的,runc 启动完容器后本身会直接退出,containerd-shim 则会成为容器进程的父进程, 负责收集容器进程的状态, 上报给 containerd, 并在容器中 pid 为 1 的进程退出后接管容器中的子进程进行清理, 确保不会出现僵尸进程。

Containerd 是一个工业级标准的容器运行时,它强调简单性、健壮性和可移植性,containerd 可以负责干下面这些事情:

  • 管理容器的生命周期(从创建容器到销毁容器)

  • 拉取/推送容器镜像

  • 存储管理(管理镜像及容器数据的存储)

  • 调用 runc 运行容器(与 runc 等容器运行时交互)

  • 管理容器网络接口及网络

2)containerd安装

下面步骤为在Rocky8/RHEL8上安装containerd

先安装yum-utils工具

yum install -y yum-utils

配置Docker官方的yum仓库,如果做过,可以跳过

yum-config-manager \    --add-repo \    https://download.docker.com/linux/centos/docker-ce.repo

安装containerd

yum install containerd.io -y

启动服务并设置为开机自启

systemctl enable containerdsystemctl start containerd

3)containerd命令行工具ctr

Ctr就是containerd的命令行工具,可以用来执行和管理containerd中的任务。ctr主要用于开发和调试,而不是在生产环境中使用。常见用法如下:

查看containerd版本

ctr version

拉取镜像

ctr images pull  docker.io/library/busybox:latest #其中images可以简写为i

列出本地镜像

ctr  images list #或者简写ctr i ls

修改tag

ctr i tag  docker.io/library/busybox:latest  busybox:latest

删除镜像

ctr i rm docker.io/library/busybox:latest

运行容器

ctr run  -d  busybox:latest busybox

列出运行的容器​​​​​​​

ctr containers  list  #或者简写为ctr c  ls

列出任务​​​​​​​

ctr tasks  ls #或者简写ctr t  ls

容器里执行命令

ctr t exec --exec-id 1860 busybox ls  #1860为任务ID

进入容器内部

ctr t exec -t --exec-id 1860 busybox sh

删除容器​​​​​​​

ctr t kill -s SIGKILL busybox #先杀掉进程ctr c  rm  busybox #再删除容器

总之,这个ctr工具跟docker的命令行工具用起来还是有不少差异的。

 

### 部署 Containerd 教程 Containerd 是一种流行的容器运行时,广泛用于生产环境中。以下是关于如何部署和配置 containerd 的详细说明。 #### 1. 下载并安装 containerd 可以通过包管理器下载最新版本的 containerd 软件包。例如,在基于 RedHat 或 CentOS 的系统中,可以使用 `yum` 命令来完成安装: ```bash yum list containerd --showduplicates | sort -r yum install containerd -y ``` 这一步会自动获取最新的稳定版 containerd 并将其安装到系统中[^4]。 #### 2. 启动并启用 containerd 服务 为了使 containerd 正常工作,需要确保 systemd 中的服务已启动并设置为开机自启: ```bash systemctl start containerd systemctl enable containerd ``` 如果需要手动调整 service 文件的内容,则可以从官方仓库获取标准模板文件: ```bash curl -O https://raw.githubusercontent.com/containerd/containerd/main/containerd.service mv containerd.service /etc/systemd/system/ systemctl daemon-reload ``` 此操作允许用户根据需求修改 service 文件中的参数[^1]。 #### 3. 初始化默认配置 containerd 提供了一个内置命令用来生成初始配置文件 `/etc/containerd/config.toml`: ```bash containerd config default > /etc/containerd/config.toml ``` 该配置包含了大多数场景下的合理默认值,但在某些情况下可能还需要进一步定制化设置,比如更改 cgroup driver 类型等。 #### 4. 修改 CGroup Driver (可选) Kubernetes 推荐使用 Systemd 作为 cgroup manager 来获得更好的性能表现以及与其他组件之间的兼容性。因此建议将原有的配置项替换掉: 编辑 `/etc/containerd/config.toml` 文件并将其中的一行改为如下所示: ```toml [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc.options] SystemdCgroup = true ``` 保存之后重新加载守护进程和服务本身即可生效: ```bash sed -i 's/SystemdCgroup = false/SystemdCgroup = true/' /etc/containerd/config.toml systemctl daemon-reload systemctl restart containerd ``` 这样就完成了针对 Kubernetes 场景优化后的 containerd 设置过程。 #### 5. 测试基本功能 最后验证一下当前环境是否能够正常运作。利用自带客户端工具 `ctr` 查看现有容器列表或者尝试创建新的命名空间实例来进行简单实验: ```bash ctr containers list # 显示所有正在运行或停止状态下的容器对象 ctr ns create testns # 新建名为testns的空间单元以便隔离不同业务逻辑模块之间的影响关系 ``` 以上步骤展示了完整的从零开始搭建一套基础可用性的 containerd 实例的方法论框架结构图谱[^2][^5]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值