Dockerfile Add和Copy的区别。

Dockerfile 中,ADDCOPY 都用于将文件或目录从构建上下文(通常是 Dockerfile 所在的目录)复制到 Docker 镜像中,但它们有一些关键区别:


1. COPY 指令

COPY 主要用于复制本地文件或目录到容器的指定路径。

📌 语法

dockerfile 复制代码
COPY <源路径> <目标路径>

📌 特性

仅支持复制本地文件或目录 (不能从远程 URL 复制)。

不会自动解压 .tar 压缩包 (需要手动 RUN tar -xvf)。

适用于简单的文件复制操作

📌 示例

dockerfile 复制代码
COPY index.html /usr/share/nginx/html/
  • 这会将 index.html 文件复制到 /usr/share/nginx/html/ 目录下。
dockerfile 复制代码
COPY src/ /app/
  • 这会将 src/ 目录的所有内容复制到 /app/ 目录下。

2. ADD 指令

ADDCOPY 更强大,除了能复制文件,它还能处理远程 URL 下载自动解压 .tar 压缩包

📌 语法

dockerfile 复制代码
ADD <源路径> <目标路径>

📌 特性

可以复制本地文件和目录 (与 COPY 相同)。

支持远程 URL 下载COPY 不支持)。

自动解压 .tar 文件 (但不会解压 .zip)。

适用于需要自动解压或者拉取远程资源的场景

📌 示例

dockerfile 复制代码
ADD example.tar.gz /app/
  • ADD 自动解压 example.tar.gz/app/
dockerfile 复制代码
ADD https://example.com/sample.txt /app/sample.txt
  • ADD 会从 URL 下载 sample.txt 并存储到 /app/sample.txt

3. ADD vs COPY 选择

特性 ADD COPY
复制本地文件/目录
支持远程 URL 下载
自动解压 .tar 文件
适用于文件复制 更推荐

📌 何时使用 COPY

  • 推荐使用 COPY ,因为它更简单、明确,避免 ADD 可能带来的副作用(如意外解压)。

📌 何时使用 ADD

  • 需要自动解压 .tar.gz 文件到指定目录时。
  • 需要从远程 URL 下载文件 时(尽管更推荐 RUN wgetRUN curl)。

4. 最佳实践

  • 尽量使用 COPY,因为 ADD 的功能更复杂,可能会导致意外行为(如 .tar 自动解压)。
  • 如果需要解压 .tar,可以手动使用 RUN tar -xvf,避免 ADD 带来的不可控行为。
  • 如果需要下载远程文件,更推荐 RUN wgetRUN curl,而不是 ADD,这样可以提高 Docker 层的可复用性。

📌 推荐方式

dockerfile 复制代码
# 推荐方式 1: 复制本地文件
COPY myfile.txt /app/

# 推荐方式 2: 下载远程文件(避免用 ADD)
RUN wget -O /app/sample.txt https://example.com/sample.txt

# 推荐方式 3: 解压 .tar 文件(避免用 ADD)
COPY example.tar.gz /app/
RUN tar -xzf /app/example.tar.gz -C /app/ && rm /app/example.tar.gz

总结

COPY 更推荐 ,因为它只做文件复制,避免 ADD 的额外功能带来意外行为。

ADD 适用于特殊场景 ,如自动解压 .tar.gz 或远程下载(但 RUN wget/curl 更灵活)。

Docker 官方推荐优先使用 COPY,除非 ADD 的特性确实有用。

相关推荐
南风木兮丶2 分钟前
Vue 项目安装 @antfu/eslint-config 保姆级教程
前端·javascript·vue.js
万少15 分钟前
记 HarmonyOS 开发中的一个小事件 怒提华为工单
前端·harmonyos
未来之窗软件服务17 分钟前
万象EXCEL开发(六)excel单元格运算逻辑 ——东方仙盟金丹期
前端·excel·仙盟创梦ide·东方仙盟·万象excel
Mintopia24 分钟前
🚀 Cesium-Kit:10 秒为你的 Cesium 项目添加动态光效标记
前端·javascript·cesium
Mintopia26 分钟前
🌩️ 云边协同架构下的 WebAI 动态资源调度技术
前端·javascript·aigc
Olrookie27 分钟前
若依前后端分离版学习笔记(十六)——scoped、路由跳转
前端·笔记
qaqxiaolei28 分钟前
高效办公利器:前端实现表格导出excel格式 + 自定义水印的完整方案
前端·javascript
叫我詹躲躲30 分钟前
为什么Bun.js能在3秒内启动一个完整的Web应用?
前端·javascript·bun
Olrookie31 分钟前
若依前后端分离版学习笔记(十七)——ruoyi开发规范&流程,请求流程,依赖引入,组件注册&通信
前端·笔记
Keepreal49632 分钟前
谈谈对闭包的理解以及常见用法
前端·javascript