news 2026/6/26 0:11:59

Containerd 运行时的 K8S 集群离线导入镜像的方案

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Containerd 运行时的 K8S 集群离线导入镜像的方案

目录

1. 准备与传输镜像

2. 导入镜像

3. 部署应用

4. 技巧与注意事项


在 Containerd 运行时的 K8S 集群中离线导入应用镜像,关键在于将镜像正确导入到 containerd 的k8s.io命名空间,并确保 K8S部署时能使用这些本地镜像。

1. 准备与传输镜像

首先,你需要在可以访问互联网的环境中,准备好要部署的应用镜像。

拉取并保存镜像:使用 Docker 拉取镜像,重新标记为符合 K8s 需求的标签(如需),然后导出为.tar文件。

docker pull <原镜像名称:标签> docker tag <原镜像名称:标签> <新镜像名称:标签> # 可选,使镜像标签符合部署要求 docker save -o <镜像文件名>.tar <新镜像名称:标签>
docker pull nginx:latest docker save -o nginx.tar nginx:latest
  • 提示docker save保存的是展开后的格式,文件可能较大。虽然docker save也支持输出为.tar.gz,但ctr image import命令不支持直接导入压缩格式,如果得到的是.tar.gz文件,需要先解压 。

  • 举例:如需部署nginx:latest,操作如下:

  • 传输镜像文件:将生成的.tar文件复制到离线环境中的 K8s 工作节点(如果需要部署到多个节点,则每个节点都需要复制)。scp <镜像文件名>.tar <用户名>@<节点IP>:<目

2. 导入镜像

这是最关键的一步,需要将镜像导入到 containerd 的正确命名空间中。

  • 导入镜像:登录到目标 K8s 节点,使用ctr命令导入镜像。务必使用-n k8s.io参数,这能确保镜像被导入到 Kubernetes 使用的命名空间 。

    ctr -n k8s.io image import <镜像文件名>.tar
    • 注意如果镜像文件是.tar.gz格式,需要先解压:

  • 验证导入:导入完成后,使用以下命令检查镜像是否存在。

    # 使用 ctr 查看 ctr -n k8s.io images list | grep <镜像名称> # 或者使用与 CRI 接口兼容的 crictl 查看 crictl images | grep <镜像名称>

3. 部署应用

镜像准备就绪后,就可以在 K8s 集群中部署你的应用了。

  • 创建部署配置文件:编写一个 K8s 的 Deployment YAML 文件。关键点在于需要设置imagePullPolicy: IfNotPresentimagePullPolicy: Never这会指示 Kubelet 不要尝试从远程仓库拉取镜像,而是直接使用本地已存在的镜像 。

    apiVersion: apps/v1 kind: Deployment metadata: name: your-app spec: replicas: 1 selector: matchLabels: app: your-app template: metadata: labels: app: your-app spec: containers: - name: your-app-container image: <你在节点上导入的完整镜像名称和标签> # 例如: nginx:latest imagePullPolicy: IfNotPresent # 重要! ports: - containerPort: 80
  • 应用配置:使用kubectl部署你的应用。

    kubectl apply -f your-deployment.yaml

4. 技巧与注意事项

  • 批量操作:如果需要导入多个镜像,可以写一个简单的循环脚本 。

    for image in /path/to/your/*.tar; do ctr -n k8s.io image import "$image" done
  • 镜像已经存在:如果导入时提示镜像已存在,可以使用ctr -n k8s.io images rm <镜像名>先删除旧镜像再导入,或者使用--force选项强制替换(如果ctr版本支持)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 21:31:53

28、保护用户数据与BitLocker全磁盘加密指南

保护用户数据与BitLocker全磁盘加密指南 在当今数字化时代,用户数据的安全保护至关重要。以下将为大家介绍一些保护用户数据的基本措施,以及BitLocker全磁盘加密的相关知识和操作方法。 1. 用户数据保护基础 加密文件识别 :确保用户了解在Windows资源管理器中,所有加密…

作者头像 李华
网站建设 2026/6/24 16:35:27

30、受损系统与丢失数据的恢复指南

受损系统与丢失数据的恢复指南 在日常使用计算机的过程中,系统损坏和数据丢失是常见的问题。为了有效应对这些情况,我们需要了解相关的恢复方法和数据保护策略。下面将详细介绍不同层面的数据保护和恢复措施。 1. BCD 存储命令 在管理系统启动相关设置时,有一些重要的 BC…

作者头像 李华
网站建设 2026/6/26 1:31:41

Excalidraw镜像支持多实例并发,适合大规模应用

Excalidraw镜像支持多实例并发&#xff0c;适合大规模应用 在远程办公成为常态的今天&#xff0c;一个小小的白板&#xff0c;可能正决定着一场产品评审会的效率、一次技术方案讨论的成败。传统的绘图工具虽然精准&#xff0c;但冷冰冰的线条难以激发灵感&#xff1b;而手绘风格…

作者头像 李华
网站建设 2026/6/25 9:46:35

微观交通流仿真软件:VISSIM_(14).基于VISSIM的公交优先系统设计

基于VISSIM的公交优先系统设计 1. 公交优先系统概述 公交优先系统&#xff08;Public Transport Priority System, PTPS&#xff09;是指通过各种措施和技术手段&#xff0c;确保公共交通车辆在交通网络中享有优先权&#xff0c;以提高公交车辆的运行效率和可靠性。在城市交通中…

作者头像 李华
网站建设 2026/6/25 17:14:08

LangFlow实时预览功能揭秘:即时调试AI工作流的强大支持

LangFlow实时预览功能揭秘&#xff1a;即时调试AI工作流的强大支持 在构建大语言模型&#xff08;LLM&#xff09;驱动的应用时&#xff0c;你是否曾为调试一个提示模板而反复运行整个流程&#xff1f;是否因为团队中非技术人员难以理解代码逻辑而沟通受阻&#xff1f;LangChai…

作者头像 李华
网站建设 2026/6/25 9:08:23

16、Windows资源访问与权限配置全解析

Windows资源访问与权限配置全解析 1. SkyDrive服务配置 如果不想再在设备上使用 SkyDrive 服务,可在 SkyDrive 设置对话框中点击“取消链接 SkyDrive”按钮。此操作会停止对文件的检查、处理和同步,但不会删除任何文件。若要重新启用 SkyDrive 同步功能,需重复之前的初始准…

作者头像 李华