返回顶部
首页 > 资讯 > 服务器 >聊聊kubernetes1.20用containerd替换docker(shim)的问题
  • 182
分享到

聊聊kubernetes1.20用containerd替换docker(shim)的问题

2024-04-02 19:04:59 182人浏览 薄情痞子
摘要

目录A. 在work节点上替换B. 在master节点上替换kubernetes 1.20 要去掉对 Docker的支持,具体看这里,本篇文章介绍用 containerd 替换 do

kubernetes 1.20 要去掉对 Docker的支持,具体看这里,本篇文章介绍用 containerd 替换 docker,从work节点开始,然后才到master节点。

首先查看集群

[root@node1 ~]# kubectl get node
NAME    	 	STATUS   ROLES    					AGE     VERSioN
k8s-master   	Ready    control-plane,master  		101d    v1.20.1
k8s-worker-01   Ready    <none>  					101d    v1.20.1
k8s-worker-02   Ready    <none>  					2d22h   v1.20.1

ssh连接到 k8s-worker-01

A. 在work节点上替换

  • 从服务中删除一个节点

使用 kubectl drain 从节点安全地逐出所有 Pods。 安全的驱逐过程允许 Pod 的容器 体面地终止, 并确保满足指定的 PodDisruptionBudgets。

kubectl drain k8s-worker-01 --ignore-daemonsets --delete-emptydir-data
  • 停止 kubelet
sudo systemctl stop kubelet
  • 卸载docker
sudo apt remove docker-ce docker-ce-cli
sudo apt autoremove
  • 启用containerd的前置条件

为了containerd能和kubernetes正常运行,需加载overlay和br_netfilter两个模块。

下面创建containerd.conf,在启动时加载这些模块

cat <<EOF | sudo tee /etc/modules-load.d/containerd.conf
overlay
br_netfilter
EOF

下一条命令将加载所需的模块

sudo modprobe overlay
sudo modprobe br_netfilter

创建一个文件,用于系统启动时设置其他参数

cat <<EOF | sudo tee /etc/sysctl.d/99-kubernetes-cri.conf
net.bridge.bridge-nf-call-iptables  = 1
net.ipv4.ip_forward                 = 1
net.bridge.bridge-nf-call-ip6tables = 1
EOF

应用一下设置

sudo sysctl --system

安装以下软件包以允许apt通过https使用仓库。

sudo apt-get update && sudo apt-get install -y apt-transport-Https ca-certificates curl software-properties-common

添加Docker官方GPG key,为啥要这样呢?因为containerd 也需要使用Docker镜像仓库去搜索镜像。

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key --keyring /etc/apt/trusted.gpg.d/docker.gpg add -

添加docker源

sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu focal stable"
  • 安装containerd
sudo apt-get update && sudo apt-get install -y containerd.io
  • 配置containerd
sudo mkdir -p /etc/containerd
sudo containerd config default | sudo tee /etc/containerd/config.toml
  • 使用systemd cgroup driver
sudo vim /etc/containerd/config.toml

找到下面这行,添加SystemdCgroup = true,例子如下:

[plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc]
  ...
  [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc.options]
    SystemdCgroup = true
  • 启动服务
sudo systemctl enable containerd
sudo systemctl start containerd
sudo systemctl status containerd
  • 配置Kubelet以使用containerd

修改 /var/lib/kubelet/kubeadm-flags.env 文件,改为如下

KUBELET_KUBEADM_ARGS="--container-runtime=remote --container-runtime-endpoint=/run/containerd/containerd.sock"
  • 启动kubernetes
sudo systemctl daemon-reload
sudo systemctl start kubelet

验证

[root@node1 ~]# kubectl get node
NAME    	 	STATUS   					ROLES    					AGE     VERSION
k8s-master   	Ready    					control-plane,master  		101d    v1.20.1
k8s-worker-01   Ready,SchedulingDisabled    <none>  					101d    v1.20.1
k8s-worker-02   Ready    					<none>  					3D      v1.20.1

如果一切正常,你刚刚操作的机器就会显示Ready,SchedulingDisabled,如果显示Not ready,你就要检查是否严格按照我的步骤来操作的。

  • 启用调度
kubectl Uncordon k8s-worker-01

重新查看集群状态,会发现k8s-worker-01的 STATUS 已经变成了 Ready,你可以对其他节点进行操作了。

B. 在master节点上替换

  • 停止master节点

由于master节点不能drain ,所以只能停止kubelet,work节点和pods会继续运行,但无法进行管理。

sudo systemctl stop kubelet

执行前面的 3-10 步骤

  • 修改kubernetes配置文件

最后一步是从kubernetes修改配置文件。尽管此阶段的主节点和工作节点已经在使用containerd,但是还需要调整配置设置,否则在运行kubeadm命令时会出错(例如,将kubernetes升级到新版本)

在master节点执行

kubectl edit node k8s-master

kubeadm.alpha.kubernetes.io/cri-Socket: /var/run/dockershim.sock 

修改为

kubeadm.alpha.kubernetes.io/cri-socket: /run/containerd/containerd.sock

您可以运行以下命令检查kubeadm是否正常运行。通过运行以下命令,该命令将检查集群是否可以升级。

sudo kubeadm upgrade plan

到此这篇关于kubernetes1.20用containerd替换docker(shim)的文章就介绍到这了,更多相关kubernetes替换docker内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 聊聊kubernetes1.20用containerd替换docker(shim)的问题

本文链接: https://lsjlt.com/news/142422.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 聊聊kubernetes1.20用containerd替换docker(shim)的问题
    目录A. 在work节点上替换B. 在master节点上替换kubernetes 1.20 要去掉对 Docker的支持,具体看这里,本篇文章介绍用 containerd 替换 do...
    99+
    2024-04-02
  • 聊聊docker 单机部署redis集群的问题
    目录docker部署redis集群1、创建redis网卡2、创建redis配置使用cluster集群配置3、创建redis集群测试docker 部署redis集群 1、创建redis...
    99+
    2024-04-02
  • 聊聊Docker中容器的创建与启停问题
    目录1. 镜像和容器2. 新建并启动容器3. 使用第一个容器4. 容器命名5.重启容器6. 附着到容器上1. 镜像和容器 看待镜像和容器的一种方式是将它们类比成程序与进程。一个进程可...
    99+
    2024-04-02
  • 聊聊使用docker安装nginx提供web服务的问题
    目录一、拉取镜像二、运行镜像启动容器三、文件映射四、再次启动容器服务 一、拉取镜像 docker pull命令用于拉取应用镜像,docker pull nginx命令用于拉取最新版本...
    99+
    2024-04-02
  • 聊聊php中浮点数转换出现的常见问题
    浮点数在编程中扮演着非常重要的角色,包括经济计算、数据记录、物理模拟等多个领域都需要使用。但是,由于计算机的存储和处理机制导致在涉及到浮点数计算时,可能会出现一些问题。本文将介绍PHP中的浮点数转换、精度问题以及解决方案和最佳实践。一、浮点...
    99+
    2023-05-14
    浮点数 php
  • 聊聊PHP escapeshellarg函数使用的中文问题
    本篇文章给大家带来了关于PHP escapeshellarg函数的相关知识,其中主要介绍了在命令行中调用 escapeshellarg函数有关中文字符的问题,感兴趣的朋友,下面一起来看一下吧,希望对大家有帮助。PHP 中命令行调用 esca...
    99+
    2023-05-14
    escapeshellarg php
  • 聊聊SpringCloud中的Ribbon进行服务调用的问题
    目录1、Robbon1.1、Ribbon概述1.2、Ribbon负载均衡演示1.3、Ribbon核心组件IRule1.4、Ribbon负载均衡算法1.4.1、轮询算法原理 负载均衡算...
    99+
    2024-04-02
  • 聊聊使用RedisTemplat实现简单的分布式锁的问题
    目录不使用redisson框架实现Redis分布式锁1.在SpringBootTest中编写测试模块1.1:使用占位符加锁:1.2:使用占位符设置有效时间解决死锁问题:1.3:使用l...
    99+
    2024-04-02
  • Vue+tsx使用slot没有被替换的问题
    目录前言发现问题解决后记前言 最近自己准备写一个 UI 组件,想对 vue 的 2.x、3.x 可以更深层次的掌握 在架构时,准备全部使用 tsx 书写组件 但遇到了 tsx 中使用...
    99+
    2024-04-02
  • Vue+tsx使用slot没有被替换的问题怎么解决
    本篇内容介绍了“Vue+tsx使用slot没有被替换的问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录前言发现问题解决后记前言...
    99+
    2023-06-20
  • 怎样解决CSS超出文本指定宽度用省略号代替和文本不换行的问题
    本篇文章为大家展示了怎样解决CSS超出文本指定宽度用省略号代替和文本不换行的问题,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一般的文字截断(适用于内联与块):CS...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作