k8s将节点容器运行时从Docker迁移到Containerd
1.执行drain操作
1 | kubectl drain k8s-node01 --ignore-daemonsets # |
2.对应节点上关闭docker
1 2 3 4 | #注意,是要迁移的节点 systemctl stop kubelet systemctl stop docker.socket systemctl stop docker |
3.安装、配置 Containerd
1 2 3 4 5 6 7 8 9 10 11 12 13 | yum install containerd.io cri-tools -y #就是docker的yum源 mkdir -p /etc/containerd crictl config runtime-endpoint unix: ///var/run/containerd/containerd.sock containerd config default #生成默认配置文件 vim /etc/containerd/config.toml 61 sandbox_image = "registry.aliyuncs.com/google_containers/pause:3.7" #修改镜像下载地址 125 SystemdCgroup = true #使用systemdcgroup驱动 参考文档:https: //kubernetes.io/zh-cn/docs/setup/production-environment/container-runtimes/ 153 [plugins. "io.containerd.grpc.v1.cri" .registry.mirrors] 添加 [plugins. "io.containerd.grpc.v1.cri" .registry.mirrors. "docker.io" ] #设置镜像加速 endpoint = [ "https://j7ih9k5f.mirror.aliyuncs.com" ] |
4.加载模块及修改参数(转发IPv4并让iptables看到桥接流量)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | cat << EOF > /etc/modules-load.d/containerd.conf overlay br_netfilter EOF modprobe overlay modprobe br_netfilter lsmod | egrep 'overlay|br_netfilter' #docker版本以下配置应该已经存在,确认后操作 cat <<EOF > /etc/sysctl.d/k8s.conf net.bridge.bridge-nf-call-ip6tables = 1 net.bridge.bridge-nf-call-iptables = 1 net.ipv4.ip_forward = 1 EOF sysctl -p /etc/sysctl.d/k8s.conf systemctl enable containerd ; systemctl restart containerd systemctl status containerd |
5.修改kubelet配置
1 2 3 4 5 6 | cat /etc/sysconfig/kubelet KUBELET_EXTRA_ARGS= "--container-runtime=remote --runtime-request-timeout=15m --container-runtime-endpoint=unix:///run/containerd/containerd.sock" #设置kubelet使用系统套接字 ,参考文档:https://kubernetes.io/zh-cn/docs/reference/command-line-tools-reference/kubelet/ systemctl restart kubelet systemctl status kubelet root@k8s-master manifests]# kubectl get node -o wide|grep k8s-node01 #检查节点 k8s-node01 Ready <none> 41h v1.20.11 192.168.1.132 <none> CentOS Linux 7 (Core) 6.0.2-1.el7.elrepo.x86_64 containerd: //1.6.8 |
6
1 | kubectl uncordon k8s-node01 #剩余节点依次操作即可 |
7.删除docker
1 | yum remove docker-ce docker-ce-cli |
"一劳永逸" 的话,有是有的,而 "一劳永逸" 的事却极少
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· Qt个人项目总结 —— MySQL数据库查询与断言