k8s初始化报错 [ERROR CRI]: container runtime is not running: ......

天行健,君子以自强不息;地势坤,君子以厚德载物。


每个人都有惰性,但不断学习是好好生活的根本,共勉!


文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。

文章目录

  • 一、环境参数
  • 二、报错内容
  • 三、解决方式
    • [1. 查看containerd状态](#1. 查看containerd状态)
    • [2. config.toml文件查看](#2. config.toml文件查看)
    • [3. 修改文件](#3. 修改文件)
    • [4. 重启containerd](#4. 重启containerd)
  • 四、原因分析及参考
    • [1. 一个关于版本的背景故事](#1. 一个关于版本的背景故事)
    • [2. 关于containerd的介绍](#2. 关于containerd的介绍)
    • [3. 报错内容中的内容分析](#3. 报错内容中的内容分析)
    • [4. containerd安装的默认禁用(重点)](#4. containerd安装的默认禁用(重点))

一、环境参数

  • linux系统为ubuntu版本为22.04.3
  • kubernetes版本为1.28.2
  • containerd版本为1.6.25
  • 虚拟机软件vmware pro 17

二、报错内容

执行初始化命令kubeadm init命令时报错,内容如下

l 复制代码
error execution phase preflight: [preflight] Some fatal errors occurred:
        [ERROR CRI]: container runtime is not running: output: time="2023-12-07T06:26:18Z" level=fatal msg="validate service connection: CRI v1 runtime API is not implemented for endpoint \"unix:///var/run/containerd/containerd.sock\": rpc error: code = Unimplemented desc = unknown service runtime.v1.RuntimeService"
, error: exit status 1

三、解决方式

参考第部分的第4小节

1. 查看containerd状态

l 复制代码
systemctl status containerd

如果containerd正常运行(Active状态为active(running))

如下

2. config.toml文件查看

查看containerd的config.toml文件

l 复制代码
cat /etc/containerd/config.toml

3. 修改文件

如果有内容如下

l 复制代码
disabled_plugins = ["cri"]

则修改文件

l 复制代码
sudo vim /etc/containerd/config.toml

i进入编辑模式,注释掉

l 复制代码
#disabled_plugins = ["cri"]

或者将"cri"删掉,如下

l 复制代码
disabled_plugins = []

esc退出编辑然后按shift+zz保存退出

4. 重启containerd

修改的内容重启后生效

l 复制代码
systemctl restart containerd

四、原因分析及参考

1. 一个关于版本的背景故事

根据k8s官网的介绍,kubernets 自v 1.24.0 后,移除了 docker.shim(k8s集成的docker),替换采用 containerd 作为容器运行时。因此需要安装 containerd

而containerd是docker的子项目,现在他俩分开了,所以可以单独安装containerd

2. 关于containerd的介绍

常用的容器运行时有docker、containerd、CRI-O等

containerd是一个CRI(Container Runtime Interface)组件,在容器运行时调用containerd组件来创建、运行、销毁容器等

CRI组件遵循OCI规范,通过runc实现与操作系统内核的交互,然后实现创建和运行容器

docker使用containerd作为运行时,k8s使用containerd、CRI-O等

3. 报错内容中的内容分析

CRI Container Runtime Interface 容器运行时接口

container runtime is not running 容器运行时未启动

validate service connection 无效的服务连接

CRI v1 runtime API is not implemented for endpoint "unix:///var/run/containerd/containerd.sock" 容器运行时接口 v1 运行时 接口 没有实现节点文件sock,应该就是此文件未找到

4. containerd安装的默认禁用(重点)

使用安装包安装的containerd会默认禁用作为容器运行时的功能,即安装包安装containerd后默认禁用containerd作为容器运行时

这个时候使用k8s就会报错了,因为没有容器运行时可以用

开启方法就是将/etc/containerd/config.toml文件中的disabled_plugins的值的列表中不包含cri

修改后重启containerd才会生效


感谢阅读,祝君暴富!

相关推荐
疯子@1232 小时前
nacos1.3.2 ARM 版容器镜像制作
java·linux·docker·容器
NineData3 小时前
NineData云原生智能数据管理平台新功能发布|2025年8月版
数据库·mongodb·云原生·数据库管理工具·ninedata·数据库迁移·数据复制
Serverless社区5 小时前
函数计算进化之路:AI Sandbox 新基座
阿里云·云原生·serverless
沐雨风栉6 小时前
自建云音乐服务器:Navidrome+cpolar让无损音乐随身听
运维·服务器·redis·缓存·docker·容器
喂完待续8 小时前
【Big Data】Amazon S3 专为从任何位置检索任意数量的数据而构建的对象存储
大数据·云原生·架构·big data·对象存储·amazon s3·序列晋升
油条不卖8 小时前
搞坏了docker 双系统下重装ubuntu22.04
运维·docker·容器
程序猿阿伟8 小时前
《云原生边缘与AI训练场景:2类高频隐蔽Bug的深度排查与架构修复》
人工智能·云原生·bug
麦兜*9 小时前
Docker 部署 MongoDB:单节点与副本集的最佳实践
java·spring boot·mongodb·spring cloud·docker·容器·maven
智码看视界10 小时前
老梁聊全栈系列:(阶段一)从单体到云原生的演进脉络
java·云原生·c5全栈