0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Containerd基础用法

阿铭linux 来源:阿铭linux 2023-04-11 10:50 次阅读

1)关于Containerd的基础知识

从 Docker 1.11 版本开始,Docker 容器运行就不是简单通过 Docker Daemon 来启动了,而是通过集成containerd、runc等多个组件来完成的。 虽然Docker Daemon守护进程模块在不停地重构,但是基本功能和定位没有太大的变化,一直都是CS架构,守护进程负责和Docker Client端交互,并管理Docker镜像和容器。 现在的架构中组件containerd就会负责集群节点上容器的生命周期管理,并向上为Docker Daemon提供gRPC接口

a9cc0438-d812-11ed-bfe3-dac502259ad0.png

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 containerd
systemctl 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的命令行工具用起来还是有不少差异的。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口
    +关注

    关注

    33

    文章

    8493

    浏览量

    150815
  • 容器
    +关注

    关注

    0

    文章

    494

    浏览量

    22043
  • 进程
    +关注

    关注

    0

    文章

    201

    浏览量

    13947
  • 镜像
    +关注

    关注

    0

    文章

    162

    浏览量

    10697
  • Docker
    +关注

    关注

    0

    文章

    454

    浏览量

    11807

原文标题:Containerd基础用法

文章出处:【微信号:aming_linux,微信公众号:阿铭linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Containerd常见命令操作

    作为接替 Docker 运行时的 Containerd 在早在 Kubernetes1.7 时就能直接与 Kubelet 集成使用,只是大部分时候我们因熟悉 Docker,在部署集群时采用了默认
    的头像 发表于 08-30 10:08 4886次阅读

    SQLx的基础用法和进阶用法

    SQLx是一个Rust语言的异步SQL数据库访问库,支持多种数据库,包括PostgreSQL、MySQL、SQLite等。本教程将以SQLite为例,介绍SQLx的基础用法和进阶用法。 基础用法
    的头像 发表于 09-19 14:29 2233次阅读

    Stream模块的基础用法和进阶用法

    有用。在本教程中,我们将介绍 Stream 模块的基础用法和进阶用法,并提供示例。 基础用法 在本节中,我们将介绍 Stream 模块的基础用法,并提供基础示例。 从 Vec 中创建
    的头像 发表于 09-19 15:33 1149次阅读

    常用灯头规格及用法介绍

    常用灯头规格及用法介绍 简述常用灯头规格及用法介绍
    发表于 04-19 15:40 56次下载

    状态机原理及用法

    状态机原理及用法状态机原理及用法状态机原理及用法
    发表于 03-15 15:25 0次下载

    电阻的巧妙用法

    电阻的巧妙用法
    发表于 12-16 12:59 0次下载

    MSF及Unicorn的介绍及用法

    MSF及Unicorn的介绍及用法
    发表于 09-07 15:09 3次下载
    MSF及Unicorn的介绍及<b class='flag-5'>用法</b>

    AI UX :设计助手用法

    本集讨论了具有高投资回报率的用法类型,以及如何以及为什么要优先使用帮助用法
    的头像 发表于 11-13 06:40 1856次阅读

    重磅!阿里巴巴工程师获得 containerd 社区席位,与社区共建云时代容器标准

    重磅!阿里巴巴工程师获得 containerd 社区席位,与社区共建云时代容器标准11 月 29 日,CNCF containerd 社区正式宣布:两位阿里巴巴工程师正式获得 containerd
    发表于 12-11 17:25 315次阅读

    attribute 用法 section 部分

    attribute 用法 section 部分
    发表于 11-16 18:21 87次下载
    attribute <b class='flag-5'>用法</b> section 部分

    Containerd控制runC的守护进程

    ./oschina_soft/containerd.zip
    发表于 05-11 10:05 0次下载
    <b class='flag-5'>Containerd</b>控制runC的守护进程

    CMake用法详解

    CMake用法详解
    发表于 10-25 16:28 2次下载

    Containerd的Bug导致容器被重建!如何避免?

    该 issue 在 2022 年 12 月 20 日被提交,RKE2 团队在 2023 年 1 月 6 日紧急合并了 containerd 中修复该 issue 的 commit,发布了 k3s-containerd v1.6.14+k3s1 版本,并发布了新的 rke2
    的头像 发表于 02-10 13:55 1495次阅读

    分享《verdi用法小结》的pdf

    分享Verdi用法小结的pdf文档
    的头像 发表于 02-18 20:21 1163次阅读
    分享《verdi<b class='flag-5'>用法</b>小结》的pdf

    pcb插针的用法

    pcb插针的用法
    的头像 发表于 12-13 16:58 1765次阅读