0

0

Dockerfile中COPY指令避免覆盖镜像内重要文件

舞姬之光

舞姬之光

发布时间:2026-03-19 09:21:11

|

113人浏览过

|

来源于php中文网

原创

COPY默认直接覆盖目标文件,防止误覆盖需依靠路径设计、分层意识和构建上下文控制;应避免覆盖系统目录,优先使用应用专属路径、多阶段构建、.dockerignore及RUN指令进行可控操作。

dockerfile中copy指令避免覆盖镜像内重要文件

COPY 指令本身不会主动“避免覆盖”,它默认行为就是**直接覆盖目标路径的文件**。真正要防止误覆盖镜像内重要文件,关键在于**路径设计、分层意识和构建上下文控制**,而不是依赖 COPY 的某个开关。

明确 COPY 的目标路径,避开系统关键目录

Docker 镜像的基础层(如 Debian/Alpine 的 rootfs)包含 /bin、/usr、/etc 等系统目录。如果你在 Dockerfile 中写:

COPY ./config /etc/

就会把本地 config 目录下所有内容直接覆盖进镜像的 /etc/ —— 可能删掉 /etc/passwd、/etc/hosts 等关键文件,导致容器启动失败。

✅ 正确做法:

MedPeer自然科学基金
MedPeer自然科学基金

科研申报与成果分析的智能数据引擎

下载
  • 只 COPY 到应用专属目录,例如 /app/srv/myapp/opt/app
  • 若必须修改配置,用 COPY ./myapp.conf /etc/myapp.conf(精确到文件),而非整个目录
  • 避免通配符无差别覆盖:COPY ./conf/* /etc/ 同样危险

利用多阶段构建,隔离构建产物与运行环境

很多“覆盖风险”其实源于把构建工具链、测试文件、源码等一股脑 COPY 进最终镜像。多阶段构建能天然规避这类问题:

  • 第一阶段用 golang:1.22 构建二进制,只保留 编译好的可执行文件
  • 第二阶段用 alpine:latest,仅 COPY 上一阶段的二进制到 /usr/local/bin/
  • 最终镜像里没有 src、go mod、node_modules,自然不存在误覆盖系统文件的可能

善用 .dockerignore,从源头排除干扰文件

即使你写了 COPY . /app,只要项目根目录有 .dockerignore,就能阻止不该进镜像的文件被 COPY:

  • 在 .dockerignore 中加入 /etc/bin/usr(虽然通常不会存在,但体现意识)
  • 更实用的是排除:.gitnode_modules__pycache__*.logsecrets.env
  • ⚠️ 注意:.dockerignore 不影响已显式指定的 COPY 源路径(如 COPY nginx.conf /etc/nginx.conf),它只过滤 COPY .COPY src/ 这类基于构建上下文的复制

用 RUN + cp 做可控的覆盖(仅限必要场景)

极少数情况确实需要替换系统配置(如定制 /etc/resolv.conf 或 /etc/apk/repositories),这时不建议用 COPY,而改用 RUN:

  • RUN echo "nameserver 8.8.8.8" > /etc/resolv.conf —— 清晰、可读、可审计
  • RUN cp /tmp/custom-repos /etc/apk/repositories —— 先 COPY 临时文件,再由 RUN 显式覆盖,逻辑分离
  • 好处:Dockerfile 更易理解,且该层变更明确,便于调试和回滚

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

212

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

247

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

357

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

214

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

410

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

530

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

201

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

1599

2025.06.17

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号