在 Kubernetes Pod 中运行的容器是不需要手动交互的独立计算单元。有时您可能需要将文件复制到 Pod 的文件系统或从 Pod 的文件系统复制文件,这可能是因为您正在调试问题并希望存档存储在容器中的日志、配置文件或缓存。

以下是如何使用 Kubectl 的内置传输功能或手动替代方法在您的机器和 Pod 中的容器之间移动文件。

复印到您的机器或从您的机器复印

kubectl cp命令是复制到容器文件系统或从容器文件系统复制的最简单方法。它的工作原理与docker cp您可能已经在本地容器开发中熟悉的类似。

kubectl cp需要源和目标参数。源或目标之一必须是 Pod 引用。这被格式化为 Pod 名称,后跟一个冒号和容器内文件系统路径。

kubectl cp example-pod:/tmp/example-dir ./example-dir

此示例将/tmp/example-dirfrom的内容复制example-podexample-dir本地文件系统上。反转参数会将您的机器复制example-dir回 Pod。

命令参数

由于单个 Pod 可以容纳多个容器,因此在使用cp. Kubernetes 将默认复制到或从 Pod 中的第一个容器实例。您可以通过添加-c标志来定位特定容器:

kubectl cp example-pod:/tmp/example-dir ./example-dir -c second-container

像所有其他的kubectl命令,cp有违通过定义群连接你的KUBECONFIG环境变量。这默认为~/.kube/conf.

引用命名空间 Pod 时有两个选项。您可以--namespace example-namespace在文件系统参考中添加标准标志或使用完整的 Pod 路径:

kubectl cp example-namespace/example-pod:/tmp/example-dir ./example-dir

默认情况下保留文件属性。将--no-preserve标志添加到您的cp命令以从留在目的地的复制文件中去除所有权和权限数据。与常规 Unix 不同cp,Kubectl 的实现始终是递归的,因此引用目录也将包含其内容。

当 Kubectl Cp 不起作用时

kubectl cp有一个很大的警告:在内部,它是一个简单的tar. 该命令将压缩源路径,将存档复制到目标,然后提取其内容。您的容器映像必须tar在其路径中包含二进制文件才能使其正常工作。

这意味着kubectl cp当您遵循 Docker 最佳实践来保持镜像较小时,这可能并不总是一种选择。尽管流行的最小基础(例如alpinedo include)tar,它可能不会出现在每个图像中,并且如果您从头开始组装它们,则不会出现。

使用tar也限制了kubectl cp可以复制的内容。您无法解析符号链接或使用诸如/tmp/*.log. 当需要此功能时,您将不得不使用不同的方法。

一种选择是将kubectl execcat命令和 shell 重定向结合起来,将文件的内容从集群中流式传输到本地文件中:

kubectl exec \
--namespace 示例-namespace \
example-pod -c 第二个容器 \
-- cat /tmp/example-file > 本地文件

kubectl exec命令在 Pod 中启动一个 shell 会话。之后的所有内容都在--容器内运行。调用cat文件的输出将发送到您的终端,在那里它可以重定向到本地文件。

当您复制少量相对较小的文件时,此技术适用。如果您需要检索一个大目录,它很快就会变得乏味。不幸的是,如果不向容器中添加额外的软件,就没有更好的选择。

如果你感觉大胆,你可以在你的容器安装SSH和使用scp,以从您的主机访问它的文件系统。这将为您提供完整的复制体验,但代价是运行额外的守护程序并产生潜在的安全问题。它应该只在受到适当保护的集群上考虑。

添加tar到您的容器映像是一个更安全的选择。这使您可以在需要额外功能时使用kubectl cp和解锁更高级的手动复制kubectl exec。如果遇到cp语法限制,请tar直接调用viakubectl exec向命令添加额外的标志:

kubectl exec \
--namespace 示例-namespace \
example-pod -c 第二个容器 \
-- tar -cf /tmp/example-dir | tar xf - -C ./extracted-dir

tar -cF在您的容器内运行,并将结果通过管道传输到tar xf本地机器上的提取命令。的-指示tar来提取通过标准输入流馈送到它的数据。-C用于指定目标目录。

概括

kubectl cp命令允许您在 Kubernetes Pod 和您的机器之间复制文件。它适用于任一方向,但不能用于将文件从 Pod 移动到 Pod。如果您需要这样做,最好使用两阶段程序,首先从 Pod A 复制到您的机器,然后再复制到 Pod B。

由于cp依赖于tar后台,您需要确保您的容器映像包含它。你会看到一个No such file or directory tar错误,如果你尝试运行cp对抗吊舱没有tar。在这种情况下,无论是添加tar到容器或使用的组合kubectl execcat,如果你只需要找回一些文件。

 

如何在 Kubernetes Pod 和您的机器之间复制文件的更多相关文章

  1. Linux机器之间复制文件和目录方式&Linux的scp命令详解

    本文转载于:http://www.cnblogs.com/hitwtx/archive/2011/11/16/2251254.html 整理总结如下: 不同的Linux之间copy文件常用有3种方法: ...

  2. Linux下不同机器之间的文件拷贝

    通过 scp 命令实现不同机器之间的文件拷贝. (1)本机考到目标机器:scp 本机文件 目的地: 如:scp /home/odp-web.war   root@192.168.6.137:/usr/ ...

  3. 如何在docker和宿主机之间复制文件

    如何在docker和宿主机之间复制文件   最近在用Docker布署hadoop,要将文件上传到HDFS首先文件得在Docker容器中吧,网上提供的方法差不多有三种 1.用-v挂载主机数据卷到容器内  ...

  4. Linux下不同机器之间拷贝文件

    在Linux系统下,不同机器上实现文件拷贝 一.将本地文件拷贝到远程机器: scp /home/administrator/news.txt root@192.168.6.129:/etc/squid ...

  5. Linux系统下不同机器之间拷贝文件的方法

    在Linux系统下,不同机器上实现文件拷贝 一.将本地文件拷贝到远程机器: scp /home/administrator/news.txt root@192.168.6.129:/etc/squid ...

  6. 不同Linux机器之间拷贝文件

    不同的Linux之间copy文件常用有3种方法: 第一种就是ftp,也就是其中一台Linux安装ftp Server,这样可以另外一台使用ftp的client程序来进行文件的copy. 第二种方法就是 ...

  7. 如何在 Linux 上复制文件/文件夹到远程系统?

    从一个服务器复制文件到另一个服务器,或者从本地到远程复制是 Linux 管理员的日常任务之一. 我觉得不会有人不同意,因为无论在哪里这都是你的日常操作之一.有很多办法都能处理这个任务,我们试着加以概括 ...

  8. 如何在Kubernetes里创建一个Nginx service

    Jerry之前的文章如何在Kubernetes里创建一个Nginx应用,已经使用kubectl命令行创建了Pod,但是在kubernetes中,Pod的IP地址会随着Pod的重启而变化,因此用Pod的 ...

  9. 实例演示:如何在Kubernetes上大规模运行CI/CD

    本周四晚上8:30,第二期k3s在线培训如约开播!本期课程将介绍k3s的核心架构,如高可用架构以及containerd.一起来进阶探索k3s吧! 报名及观看链接:http://z-mz.cn/PmwZ ...

  10. Kubernetes入门(四)——如何在Kubernetes中部署一个可对外服务的Tensorflow机器学习模型

    机器学习模型常用Docker部署,而如何对Docker部署的模型进行管理呢?工业界的解决方案是使用Kubernetes来管理.编排容器.Kubernetes的理论知识不是本文讨论的重点,这里不再赘述, ...

随机推荐

  1. .NET高级调试 - 3.8线程操作

    简介 高级调试过程中,与线程与线程栈是打交道特别多的.因此如何查看线程与线程栈就显得至关重要了 查看线程 !Threads 使用 !t/!Threads 命令获取所有托管线程 含义 ThreadCou ...

  2. 分享几个实用且高效的EF Core扩展类库,提高开发效率!

    前言 今天大姚给大家分享3款开源且实用的EF Core扩展类库,希望能帮助你在使用 EF Core 进行数据库开发变得更加高效和灵活,提高开发效率. EF Core介绍 Entity Framewor ...

  3. 二、java之面向对象

    面向对象 面向对象编程(Object-Oriented Programming,OOP) 面向对象编程的本质就是:以类的方式组织代码,以对象的组织(封装)数据 三大特性: ◆封装 ◆◆封装的概念 程序 ...

  4. KubeSphere 开源社区 2022 年度回顾与致谢

    2022 年,国内的云原生技术生态日趋完善,细分技术项目也不断涌现,形成了完整的支撑应用云原生化的全生命周期技术体系.基础设施即代码.微服务.Serverless 等技术,促使基础设施资源向更加灵活弹 ...

  5. WinSCP 脚本实现将 jar 包一键上传 Ubuntu 并 docker 部署

    准备 首先,在 Ubuntu 写一个.sh 脚本用于自动更新 jar 包的 docker 容器和镜像,然后在 Windows 写一个.bat 脚本用于上传 jar 包并运行.sh 脚本. deploy ...

  6. javascript语法--for in、for of和forEach

    首先看简单for循环效果,功能最基本,但可以实现所有循环功能 for (let i = 0; i < list.length; i++) { } 接下来看for in.for of和forEac ...

  7. 工作中的技术总结_Thymeleaf插件_关于th:if 、th:with、th:replace和th:fragment的一些事 _20210825

    工作中的技术总结_Thymeleaf _20210825 1.值取为空的情况:不能使用 th:if 进行条件渲染(因为是伪条件渲染,不管怎样元素都是先渲染到DOM再决定是否显示:个人这么认为不一定准确 ...

  8. 对于特定的游戏问题使用启发式算法可以取得比AI算法更好的表现

    相关: Using A.I. to DOMINATE NERDS in TETRIS 有些问题的求解可以通过建模将其转换为强化学习问题,然后再使用强化学习算法对其进行求解,但是很多问题如果不建模为强化 ...

  9. 使用 C# 入门深度学习:线性代数

    教程名称:使用 C# 入门深度学习 作者:痴者工良 地址: https://torch.whuanle.cn 线性代数 目录 线性代数 推荐书籍 基础知识 标量.向量.矩阵 Pytorch 的一些数学 ...

  10. apache2和nginx卸载总是不干净不完全导致无法重装,重装成功也无法启动

    大着胆子把nginx卸载了用的命令是  sudo apt remove nginx 结果最后不知道怎么折腾的就算重新装也装不上了,然后就转头折腾apache2,也卸载了  sudo apt remov ...