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


感谢阅读,祝君暴富!

相关推荐
网络研究院1 小时前
Am I Isolated:一款安全态势基准测试工具
容器·工具·基准测试·安全态势
颜淡慕潇5 小时前
【K8S问题系列 | 9】如何监控集群CPU使用率并设置告警?
后端·云原生·容器·kubernetes·问题解决
运维&陈同学5 小时前
【模块一】kubernetes容器编排进阶实战之k8s基础概念
运维·docker·云原生·容器·kubernetes·云计算
信子姚青5 小时前
K8s使用nfs
容器
葡萄皮Apple5 小时前
[CKS] K8S RuntimeClass SetUp
java·容器·kubernetes
mit6.8246 小时前
[Docker#4] 镜像仓库 | 部分常用命令
linux·运维·docker·容器·架构
诡异森林。8 小时前
Docker--Docker是什么和对Docker的了解
运维·docker·容器
老大白菜8 小时前
goframe开发一个企业网站 验证码17
运维·docker·容器·golang·goframe
研究司马懿10 小时前
【Golang】Go语言环境安装
开发语言·后端·云原生·golang·二开
zhangxueyi11 小时前
OpenEuler 下 Docker 安装、配置与测试实例
运维·docker·容器