准确-K8s系列文章-修改containerd 默认数据目录

修改 Kubernetes 集群中 containerd 默认数据目录为 /data/containerd

前言

本文档适用于 Kubernetes 1.24 及以上版本的集群,介绍如何将 containerd 默认的数据目录从 /var/lib/containerd 修改为 /data/containerd

步骤

1. 停止 containerd 服务(慎重!!!需评估风险!!!)

bash 复制代码
sudo systemctl stop containerd

2. 修改配置文件

编辑 containerd 的配置文件 /etc/containerd/config.toml

bash 复制代码
sudo vim /etc/containerd/config.toml

将配置文件中默认的 root 目录从 /var/lib/containerd 修改为 /data/containerd

bash 复制代码
默认是:root = "/var/lib/containerd"
修改为:root = "/data/containerd"

保存并退出编辑器。

3. 创建新目录

创建新的 containerd 数据目录:

bash 复制代码
sudo mkdir -p /data/containerd

4. 拷贝数据到新目录

使用 rsync 工具将原目录中的数据拷贝到新目录:

bash 复制代码
sudo rsync -avzh /var/lib/containerd/ /data/containerd/

5. 启动 containerd 服务

重新启动 containerd 服务:

bash 复制代码
sudo systemctl start containerd

6. 检查 containerd 服务状态

确保 containerd 服务已成功启动:

bash 复制代码
sudo systemctl status containerd

验证

1. 使用 crictl 工具验证

通过 crictl 工具查看 containerd 的 root 目录:

bash 复制代码
sudo crictl info | grep -i root

2. 使用 df 工具验证

检查新目录的挂载情况:

bash 复制代码
df -Th

3. 检查目录容量

进入新目录查看其容量:

bash 复制代码
du -lh --max-depth=1 /data/containerd

4. 发布新容器进行验证

发布新的容器应用,确认新的应用数据存储在新的路径下 。请注意,之前启动的容器仍然使用旧的目录,除非这些容器被重启。

总结

通过上述步骤,可以成功地将 Kubernetes 集群中 containerd 的默认数据目录从 /var/lib/containerd 修改为了 /data/containerd。可以通过多种方式验证变更是否生效,并确保新的应用数据存储在新的路径上。

相关推荐
Patrick_Wilson4 小时前
Node.js SSR 内存治理:为什么 --max-old-space-size 不等于进程内存
kubernetes·node.js·v8
开发者联盟league4 小时前
使用k8s安装Jenkins
容器·kubernetes·jenkins
正经教主5 小时前
【docker基础】 第七课:Docker Compose 多容器实战
运维·docker·容器
正经教主5 小时前
【docker基础】Redis的docker部署
redis·docker·容器
DolphinScheduler社区5 小时前
Apache DolphinScheduler 3.4.2 正式发布!新增 Amazon EMR Serverless 插件,增强监控与补数据能力
大数据·云原生·serverless·apache·海豚调度·版本发版
成为你的宁宁5 小时前
【基于 Prometheus Operator 实现 K8s 环境下 Redis Cluster 集群监控部署】
redis·kubernetes·prometheus
是一个Bug6 小时前
Docker 与 Kubernetes:从“集装箱”到“远洋舰队”
docker·容器·kubernetes
heimeiyingwang6 小时前
【架构实战】注册中心选型:Nacos vs Eureka vs Consul
微服务·云原生·架构
java_cj6 小时前
阅读 k8s 源码的准备工作
云原生·容器·kubernetes
开发者联盟league6 小时前
使用Jenkins整合Sonarqube/Gitlab/Harbor/Kubernetes实现CICD
kubernetes·gitlab·jenkins