镜像下载、域名解析、时间同步请点击 阿里云开源镜像站
从kubernetes 1.24开始,dockershim已经从kubelet中移除,但因为历史问题docker却不支持kubernetes主推的CRI(容器运行时接口)标准,所以docker不能再作为kubernetes的容器运行时了,即从kubernetesv1.24开始不再使用docker了。
但是如果想继续使用docker的话,可以在kubelet和docker之间加上一个中间层cri-docker。cri-docker是一个支持CRI标准的shim(垫片)。一头通过CRI跟kubelet交互,另一头跟docker api交互,从而间接的实现了kubernetes以docker作为容器运行时。但是这种架构缺点也很明显,调用链更长,效率更低。
虽然本文演示了cri-docker的使用,但是更推荐使用containerd作为kubernetes的容器运行时。
实验环境
两台机器,vms41和vms42
系统:centos7.4
vms41为master,vms42是worker
一.所有节点的基本设置
1.所有节点设置好/etc/hosts,使它们之间能互相解析
[root@vms4X ~]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.26.41 vms41.rhce.cc vms41
192.168.26.42 vms42.rhce.cc vms42
[root@vms4X ~]#
2.在所有节点上关闭swap分区
[root@vms4X ~]# swapoff -a ; sed -i '/fstab/d' /etc/fstab
[root@vms4X ~]#
3.在所有节点上更新yum源
[root@vms4X ~]# rm -rf /etc/yum.repos.d/* ; wget ftp://ftp.rhce.cc/k8s/* -P /etc/yum.repos.d/
[root@vms4X ~]# yum clean all
[root@vms4X ~]#
4.在所有节点安装docker
所有节点安装docker-ce。
[root@vms4X ~]# yum install docker-ce -y
在所有节点启动docker并设置开机自动启动
[root@vms4X ~]# systemctl enable docker --now
所有节点设置docker加速器
cat > /etc/docker/daemon.json <<