K8S运行时切换-从Docker到Containerd的切换实战
1. 切换的原因
-
性能提升:Containerd通过减少抽象层提升了整体性能。
-
安全性增强:它提供了更直接的系统调用,减少了潜在的安全风险。
-
简化架构:Containerd拥有更简洁的设计,使得维护和故障排除更为容易。
-
官方支持趋势:Kubernetes官方团队逐步转向对Containerd的支持。
-
cadvisor采集不到container级别的资源使用情况。
2. 准备工作
-
Kubernetes版本至少为1.20+,因为较新版本已经弃用了Docker作为默认容器运行时。
-
备份现有配置和数据,以防迁移过程中出现问题。
-
确认所有节点上的操作系统兼容Containerd。
3. 迁移步骤
3.1. 前置步骤
# 腾空节点
$ kubectl drain --ignore-daemonsets k8s-node02
node/master03 cordoned
WARNING: ignoring DaemonSet-managed Pods: kube-system/calico-node-fbzqw, kube-system/kube-proxy-95hst
node/master03 drained# 停止相关服务
$ systemctl stop kubelet
$ systemctl stop containerd
$ systemctl disable docker --now
3.2. 部署containerd服务
参考 Kubernetes实战(三十一)-安装containerd_containerd配置镜像仓库-CSDN博客
3.3. 拷贝其他节点的镜像配置
$ scp -r /etc/containerd/certs.d 172.139.20.75:/tmp
$ sudo mv /tmp/certs.d /etc/containerd/
$ sudo crictl pull 172.139.20.170:5000/library/pause:3.9
3.4. 修改kubelet参数
$ vim /var/lib/kubelet/kubeadm-flags.env
KUBELET_KUBEADM_ARGS="--container-runtime-endpoint=unix:///run/containerd/containerd.sock --pod-infra-container-image=172.139.20.170:5000/library/pause:3.9"
Tip:修改container-runtime-endpoint参数
3.5. 重启kubelet服务
$ systemctl start kubelet
3.6. 恢复可调度
$ kubectl uncordon k8s-node02
4. 验证
4.1. 查看节点runtime
$ kubectl get nodes k8s-node02 -owide
NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP OS-IMAGE KERNEL-VERSION CONTAINER-RUNTIME
k8s-node02 Ready <none> 152d v1.27.16 172.139.20.75 <none> CentOS Linux 7 (Core) 5.4.278-1.el7.elrepo.x86_64 containerd://1.6.34
4.2. 确保节点能正常启动pod
$ kubectl get pod -owide -A| grep k8s-node02
gitlab gitlab-gitaly-0 0/1 Init:CrashLoopBackOff 8 (15s ago) 2d5h 10.244.58.246 k8s-node02 <none> <none>
gitlab gitlab-gitlab-shell-66c9f95c84-zz5ld 0/1 Init:CrashLoopBackOff 8 (48s ago) 2d5h 10.244.58.242 k8s-node02 <none> <none>
gitlab gitlab-kas-7b987c7c4c-2qcvh 1/1 Running 2 2d5h 10.244.58.245 k8s-node02 <none> <none>
harbor harbor-core-58cff667b8-275gc 1/1 Running 1 6h19m 10.244.58.237 k8s-node02 <none> <none>
harbor harbor-exporter-8bf987cb7-t5rbs 1/1 Running 10 2d3h 10.244.58.232 k8s-node02 <none> <none>
harbor harbor-jobservice-847b864c7f-hgr4b 1/1 Running 2 (6m37s ago) 6h19m 10.244.58.233 k8s-node02 <none> <none>
harbor harbor-registry-656468fdb4-ck5cn 2/2 Running 2 6h20m 10.244.58.234 k8s-node02 <none> <none>
kube-system calico-node-ns7s9 1/1 Running 2 2d 172.139.20.75 k8s-node02 <none> <none>
kube-system calicoctl-5976bd6ff7-jjsxh 1/1 Running 2 2d6h 172.139.20.75 k8s-node02 <none> <none>
kube-system cert-manager-bb9c6b9ff-6jqc9 0/1 ImagePullBackOff 1 (24h ago) 2d6h 10.244.58.236 k8s-node02 <none> <none>
kube-system cert-manager-cainjector-bbf9dcf9b-cwtg9 1/1 Running 3 2d6h 10.244.58.239 k8s-node02 <none> <none>
kube-system coredns-68d697fb69-lc7sc 1/1 Running 2 2d6h 10.244.58.235 k8s-node02 <none> <none>
kube-system csi-cephfsplugin-m6b66 3/3 Running 6 2d6h 172.139.20.75 k8s-node02 <none> <none>
kube-system csi-rbdplugin-provisioner-867ccf48d7-85z5k 7/7 Running 25 2d6h 10.244.58.244 k8s-node02 <none> <none>
kube-system csi-rbdplugin-sq5q8 3/3 Running 6 2d6h 172.139.20.75 k8s-node02 <none> <none>
kube-system grafana-cdn-8c6cddddc-ft745 1/1 Running 2 2d6h 10.244.58.249 k8s-node02 <none> <none>
kube-system ingress-nginx-controller-7bfc8b7797-gktxv 1/1 Running 3 2d6h 10.244.58.240 k8s-node02 <none> <none>
kube-system kube-proxy-tl7cw 1/1 Running 2 2d1h 172.139.20.75 k8s-node02 <none> <none>
kube-system kube-state-metrics-76f85d6777-pl5t8 1/1 Running 4 2d6h 10.244.58.243 k8s-node02 <none> <none>
kube-system minio-1 1/1 Running 1 6h25m 10.244.58.248 k8s-node02 <none> <none>
kube-system nfs-dynamic-provisioner-7d7ccf88fb-hg779 1/1 Running 4 2d6h 10.244.58.241 k8s-node02 <none> <none>
kube-system node-exporter-n8jbl 1/1 Running 2 2d6h 172.139.20.75 k8s-node02 <none> <none>
kube-system prometheus-dd5446b59-cdrfg 2/2 Running 0 2m29s 10.244.58.250 k8s-node02 <none> <none>
kube-system smtp-proxy-network-7f97749595-bmcw2 1/1 Running 2 2d6h 10.244.58.238 k8s-node02 <none> <none>相关文章:
K8S运行时切换-从Docker到Containerd的切换实战
1. 切换的原因 性能提升:Containerd通过减少抽象层提升了整体性能。 安全性增强:它提供了更直接的系统调用,减少了潜在的安全风险。 简化架构:Containerd拥有更简洁的设计,使得维护和故障排除更为容易。 官方支持趋…...
腾讯会议win7二维码展示不出来
问题:win64更新后二维码展示不出来,手机等登陆都不行 安装所在位置创建文档命名TBSDEBUG并去掉后缀...
swift 专题三 swift 规范一
一、Swift编码命名规范 对类、结构体、枚举和协议等类型的命名应该采用大驼峰法,如 SplitViewController。 文件名采用大驼峰法,如BlockOperation.swift。 对于扩展文件,有时扩展定义在一个独立的文件中,用“原始类型名 扩展名…...
WPS计算机二级•幻灯片放映与会议
听说这是目录哦 放映PPT时常用的快捷技巧🥬设置放映模式🥕演讲备注的添加和隐藏🫚在PPT中插入附件并放映时打开🫛隐藏幻灯片 不被放映和打印🍄🟫演讲计时模式🥦能量站😚 放映PPT时…...
联想拯救者开机进入bios
如果你的联想拯救者(Lenovo Legion)笔记本电脑开机后直接进入 BIOS 设置界面,可能是以下原因之一导致的。以下是解决方法: 1. 检查启动顺序 进入 BIOS 后,找到 Boot(启动)选项卡。检查启动顺序…...
云原生周刊:K8s引领潮流
开源项目推荐 KWOK KWOK(Kubernetes WithOut Kubelet)是一个开源项目,旨在提供一个轻量级的 K8s 集群模拟环境,允许用户在不依赖真实节点的情况下,本地模拟整个 K8s 集群。它通过模拟 Kubelet 和其他集群组件的行为&…...
FBX SDK的使用:基础知识
Windows环境配置 FBX SDK安装后,目录下有三个文件夹: include 头文件lib 编译的二进制库,根据你项目的配置去包含相应的库samples 官方使用案列 动态链接 libfbxsdk.dll, libfbxsdk.lib是动态库,需要在配置属性->C/C->预…...
计算机网络笔记再战——理解几个经典的协议6——TCP与UDP
目录 先说端口号 TCP 使用序号保证顺序性和应答来保证有效性 超时重传机制 TCP窗口机制 UDP 路由协议 协议分类:IGP和EGP 几个经典的路由算法 RIP OSPF 链路状态数据库(LSDB) LSA(Link State Advertisement࿰…...
Android 单例模式:实现可复用数据存储
引言 在 Java 开发中,我们经常会遇到需要在整个应用程序中共享数据的场景。例如,配置信息、缓存数据等,这些数据需要在不同的模块或类中被访问和使用。为了确保数据的一致性和避免重复创建,我们可以使用单例模式来实现一个可复用的…...
【技海登峰】Kafka漫谈系列(二)Kafka高可用副本的数据同步与选主机制
【技海登峰】Kafka漫谈系列(二)Kafka高可用副本的数据同步与选主机制 一. 数据同步 在之前的学习中有了副本Replica的概念,解决了数据备份的问题。我们还需要面临一个设计难题即:如何处理分区中Leader与Follwer节点数据同步不匹配问题所带来的风险,这也是保证数据高可用的…...
【Linux】curl命令详解
【Linux】curl命令详解 【一】curl命令介绍【1】curl命令简介【2】curl命令的基本语法【3】常用的curl命令选项【4】常用的curl命令参数 【二】curl命令示例用法【1】下载文件【2】发送 POST 请求【3】发送请求时附加头部信息【4】请求方法【5】指定用户名和密码进行身份验证【…...
创建模态框和非模态框
主要的精简代码就这些 #include <QDialog>// 创建模态框 QDialog dialog(this); // 添加各种部件 // ... // 因为创建在栈上面,所以需要阻止程序继续运行 dialog.exec();// 非模态框 QDialog dialog new Dialog(this); // 添加各种部件 // ... dialog.show(…...
电商用户画像数据可视化分析
电商用户画像数据可视化分析 作者:i阿极 作者简介:Python领域新星作者、多项比赛获奖者:博主个人首页 😊😊😊如果觉得文章不错或能帮助到你学习,可以点赞👍收藏📁评论&am…...
Vue3.5常用特性整理
Vue3.5 发布已近半年,抽空整理下常用的新增/改动特性 响应式 Props 解构 Vue3.5 中 Props 正式支持解构了,并添加了响应式跟踪 设置默认值 使用 JavaScript 原生的默认值语法声明 props 默认值 以前 const props withDefaults(defineProps<{ co…...
Android Studio:Application 和 Activity的区别
Application 和 Activity 是 Android 中非常重要的两个组件,它们分别负责不同的生命周期管理和应用的不同层次的操作。 Application 是应用级别的生命周期管理,它在整个应用运行时只有一个实例,负责应用的全局初始化和资源管理。Activity 是…...
深入解析“Self-Contained”——从技术到日常的全方位应用
深入解析“Self-Contained”——从技术到日常的全方位应用 一、引言 在阅读技术文档、编程指南或产品说明时,你可能经常看到 self-contained 这个短语。例如: Our end goal is a self-contained project containing two parts. https://howistart.org/p…...
2024年12月 Scratch 图形化(一级)真题解析 中国电子学会全国青少年软件编程等级考试
202412 Scratch 图形化(一级)真题解析 中国电子学会全国青少年软件编程等级考试 一、单选题(共25题,共50分) 第 1 题 点击下列哪个按钮,可以将红框处的程序放大?( ) A. B. C. D. 标…...
llama.cpp GGML Quantization Type
llama.cpp GGML Quantization Type 1. GGML Quantization Type2. static const struct ggml_type_traits type_traits[GGML_TYPE_COUNT]3. Q#_K_M and Q#_KReferences 什么神仙妖魔,不过是他们禁锢异族命运的枷锁! GGUF https://huggingface.co/docs/hu…...
【深度学习框架】MXNet(Apache MXNet)
MXNet(Apache MXNet)是一个 高性能、可扩展 的 开源深度学习框架,支持 多种编程语言(如 Python、R、Scala、C 和 Julia),并能在 CPU、GPU 以及分布式集群 上高效运行。MXNet 是亚马逊 AWS 官方支持的深度学…...
游戏引擎学习第87天
当直接使用内存时,可能会发生一些奇怪的事情 在直接操作内存时,一些意外的情况可能会发生。由于内存实际上只是一个大块的空间,开发者可以完全控制它,而不像高级语言那样必须遵守许多规则,因此很容易发生错误。在一个…...
【物联网】ARM核常用指令(详解):数据传送、计算、位运算、比较、跳转、内存访问、CPSR/SPSR
文章目录 指令格式(重点)1. 立即数2. 寄存器位移 一、数据传送指令1. MOV指令2. MVN指令3. LDR指令 二、数据计算指令1. ADD指令1. SUB指令1. MUL指令 三、位运算指令1. AND指令2. ORR指令3. EOR指令4. BIC指令 四、比较指令五、跳转指令1. B/BL指令2. l…...
Qt展厅播放器/多媒体播放器/中控播放器/帧同步播放器/硬解播放器/监控播放器
一、前言说明 音视频开发除了应用在安防监控、视频网站、各种流媒体app开发之外,还有一个小众的市场,那就是多媒体展厅场景,这个场景目前处于垄断地位的软件是HirenderS3,做的非常早而且非常全面,都是通用的需求&…...
VSCode源码分析参考资料
VSCode Architecture Analysis - Electron Project Cross-Platform Best Practices 中文版 VSCode 架构分析 - Electron 项目跨平台最佳实践 Sihan Li博客上的vscode源码分析系列:分析了微服务架构、事件体系、资源管理、配置系统等 文召博客上的vscode 源码解析…...
html中的表格属性以及合并操作
表格用table定义,标签标题用caption标签定义;用tr定义表格的若干行;用td定义若干个单元格;(当单元格是表头时,用th标签定义)(th标签会略粗于td标签) table的整体外观取决…...
html的字符实体和颜色表示
在HTML中,颜色可以通过以下几种方式表示,以下是具体的示例: 1. 十六进制颜色代码 十六进制颜色代码以#开头,后面跟随6个字符,每两个字符分别表示红色、绿色和蓝色的强度。例如: • #FF0000:纯红…...
unordered_map/set的哈希封装
【C笔记】unordered_map/set的哈希封装 🔥个人主页:大白的编程日记 🔥专栏:C笔记 文章目录 【C笔记】unordered_map/set的哈希封装前言一. 源码及框架分析二.迭代器三.operator[]四.使用哈希表封装unordered_map/set后言 前言 哈…...
运算符(C#)
运算符(C#) 算数运算符 - * / % //算数运算符// - * / %//这跟我们初中的运算符一样// 加号Console.WriteLine(12);//3int a 5 6;Console.WriteLine(a);//11// - 减号Console.WriteLine(6-3);//3int b 10 - 6;Console.WriteLine(b);//4// * 乘号Console.WriteL…...
idea中git的简单使用
提交,推送直接合并 合到哪个分支就到先切到哪个分支...
Fastdds学习分享_xtpes_发布订阅模式及rpc模式
在之前的博客中我们介绍了dds的大致功能,与组成结构。本篇博文主要介绍的是xtypes.分为理论和实际运用两部分.理论主要用于梳理hzy大佬的知识,对于某些一带而过的部分作出更为详细的阐释,并在之后通过实际案例便于理解。案例分为普通发布订阅…...
SQLite Update 语句详解
SQLite Update 语句详解 SQLite 是一款轻量级的数据库管理系统,以其简单、易用和高效的特点在全球范围内得到了广泛的应用。在 SQLite 中,UPDATE 语句是用于修改数据库表中记录的常用命令。本文将详细解析 SQLite 的 UPDATE 语句,包括其语法…...
