【k8s003】k8s与docker的依赖关系

‌一、早期版本对应关系(Kubernetes 1.20 之前)‌

‌Kubernetes 1.13--1.19‌

‌支持的 Docker 版本范围‌:1.13.1 至 19.03.x‌

‌说明‌:此阶段 Kubernetes 直接依赖 Docker 作为默认容器运行时,需严格匹配版本以避免兼容性问题‌。

二、Kubernetes 1.20 及之后的版本演进‌

Kubernetes 从 1.20 版本开始逐步弃用对 Docker 的直接支持,转为通过 ‌CRI(容器运行时接口)‌ 与容器运行时交互‌。

Docker 仍可间接支持 Kubernetes,因其底层使用 containerd(符合 CRI 标准)‌。

实际上就是脱裤子放屁,是k8s为了摆脱docker依赖故意做的一种选择(一家之言)。

‌‌containerd‌:Kubernetes 官方推荐的 CRI 兼容运行时,与 Docker 共享底层组件‌。

‌CRI-O‌:专为 Kubernetes 设计的轻量级运行时‌。

三、版本选择建议‌

‌兼容性优先级‌

若使用 ‌Kubernetes 1.20+‌:建议直接采用 containerd 或 CRI-O,而非依赖 Docker‌。

若仍需使用 ‌Docker‌:确保其版本为 20.10.x 或更高(因底层 containerd 需兼容 Kubernetes CRI)‌。

‌生产环境优先选择 Kubernetes 和 Docker 的 ‌长期支持(LTS)版本‌,例如 Kubernetes 1.27(LTS)与 Docker 24.0.x‌。

更新前需验证版本兼容性,并备份关键配置‌。

四、依赖关系排查命令‌

检查当前 Kubernetes 集群使用的容器运行时:kubectl get nodes -o wide # 查看节点运行时类型(如 containerd、docker)‌

验证 Docker 版本兼容性:docker version

‌五、小结

‌技术趋势‌:Kubernetes 逐步脱离对 Docker 的强依赖,转向标准化 CRI 接口‌18。

‌实践建议‌:新集群优先采用 containerd 或 CRI-O,遗留系统可沿用 Docker(需版本匹配)‌

相关推荐
陌上阳光2 小时前
docker搭建ray集群
docker·容器·ray
这就是佬们吗2 小时前
初识 docker [上]
java·开发语言·笔记·docker·容器
BigBigHang3 小时前
【docker】DM8达梦数据库的docker-compose以及一些启动踩坑
数据库·docker·容器
云道轩3 小时前
使用Docker在Rocky Linux 9.5上在线部署LangFlow
linux·人工智能·docker·容器·langflow
伟大的大威3 小时前
Docker 部署 Supabase并连接
运维·docker·容器
专家大圣4 小时前
轻量级远程开发利器:Code Server与cpolar协同实现安全云端编码
网络·docker·树莓派·香橙派·casaos·code server
杰克逊的日记4 小时前
k8s的csi对接GPFS
云原生·容器·kubernetes·存储·gpfs
岚天start4 小时前
云服务器以域名形式访问机房Kubernetes集群服务之解决方案
nginx·docker·kubernetes·kubesphere·解决方案·云服务器·机房
cici158747 小时前
Docker搭建Hadoop集群
hadoop·docker·eureka
容器魔方8 小时前
「中科类脑」正式加入 Karmada 用户组!携手社区共建多集群生态
云原生·容器·云计算