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才会生效


感谢阅读,祝君暴富!

相关推荐
炸炸鱼.5 小时前
Kubernetes高级调度02:Taint/Toleration、Cordon/Drain、亲和性与反亲和性完全指南
云原生·容器·kubernetes
海兰8 小时前
Kibana Dashboard as Code:Elastic 9.4 如何用 Terraform 和类型化 API 终结“JSON 垃圾袋“
云原生·json·terraform
geshifei10 小时前
K8s 容器运行 UnixBench — 代理机器执行记录
云原生·容器·kubernetes
Albert Edison12 小时前
【Docker】Ubuntu22.04 安装 Docker 教程
运维·docker·容器
codefan※13 小时前
一键部署私人 LLM:Ollama + Docker 极简指南
运维·docker·容器·大模型·llm·本地部署·ollama
阿里云云原生14 小时前
可观测性的终局?从“面向数据”到“面向对象”,UModel 如何为 AI Agent 注入认知地图
云原生·agent
李南想做条咸鱼15 小时前
k8s集群容器访问域名第一次不通,第二次必通如何解决
云原生·容器·kubernetes
FelixBitSoul15 小时前
K8s 调度器黑盒全拆解:拓扑约束数学陷阱 + Go 插件二开实战(避坑全记录)
容器·kubernetes
叶~小兮15 小时前
K8s常用组件学习笔记
笔记·学习·kubernetes
ん贤15 小时前
Volcano 详细笔记
云原生·volcano