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 分钟前
k8s ssl 漏洞修复
容器·kubernetes·ssl
ITPUB-微风19 分钟前
云原生监控体系建设:Kubernetes架构下的全面监控策略
云原生·架构·kubernetes
hjnjmjkj25 分钟前
基于windows的docker-desktop安装kubenetes以及dashboard
docker·容器·kubernetes
Libby博仙1 小时前
docker 改了镜像源为阿里云,还是下载失败
阿里云·docker·容器
钗头风2 小时前
3.Docker常用命令
运维·docker·容器
ITPUB-微风3 小时前
网易严选DevOps实践:从传统到云原生的演进
运维·云原生·devops
桂月二二3 小时前
基于eBPF的全栈可观测性系统:重新定义云原生环境诊断范式
云原生
ITPUB-微风5 小时前
云原生数据抽象与弹性加速:Fluid开源系统的技术解析
云原生·开源
爬山算法5 小时前
Zookeeper(58)如何在Zookeeper中实现分布式锁?
分布式·zookeeper·云原生
圣心5 小时前
Ollama Docker 镜像部署
运维·docker·容器