k8s将节点容器运行时从Docker迁移到Containerd

简介: 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.执行uncordon操作

1

kubectl uncordon k8s-node01  #剩余节点依次操作即可

7.删除docker

1

yum remove docker-ce docker-ce-cli


相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
8月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
650 57
|
8月前
|
存储 监控 Java
如何对迁移到Docker容器中的应用进行性能优化?
如何对迁移到Docker容器中的应用进行性能优化?
543 59
|
11月前
|
存储 Kubernetes 调度
Kubernetes、Docker和Containerd的关系解析
总的来说,Docker、Containerd和Kubernetes之间的关系可以用一个形象的比喻来描述:Docker就像是一辆装满货物的卡车,Containerd就像是卡车的引擎,而Kubernetes就像是调度中心,负责指挥卡车何时何地送货。
486 12
|
存储 缓存 Docker
docker: No space left on device处理与迁移目录
通过以上方法,可以有效地管理 Docker 的磁盘使用情况,并确保 Docker 运行环境的稳定性和效率。
1370 34
|
存储 Kubernetes C++
Docker、containerd、CRI-O 和 runc 之间的区别
通过理解这些组件的角色和功能,可以更好地选择和配置容器环境,以满足特定的需求和应用场景。
944 25
|
存储 Kubernetes Docker
Kubernetes(k8s)和Docker Compose本质区别
理解它们的区别和各自的优势,有助于选择合适的工具来满足特定的项目需求。
1656 19
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
3684 11
|
Kubernetes Docker 容器
容器运行时Containerd k8s
容器运行时Containerd k8s
248 3
|
Kubernetes Docker 容器
rancher docker k8s安装(一)
rancher docker k8s安装(一)
175 2
|
Kubernetes Docker 容器
rancher docker k8s安装(二)
rancher docker k8s安装(二)
370 1