[英]Using Docker for development, should I use ADD or VOLUME?
我开始在项目上使用Docker,其中大部分项目都在PHP上运行(一些在Nginx / PHP-FPM上,一些在Apache / PHP上作为模块)。
问题是:我的大脑无法理解何时在Dockerfile上使用ADD和VOLUME指令来获取包含源代码的路径。
这就是我想要的:更改一行代码,访问容器端口上的浏览器,并查看更改。 等等,直到事情按预期运行,然后我将代码“添加”到机器并进行部署。 这就是我认为Docker运行的方式。 我错了吗?
AFAIK,ADD指令将给定路径上的文件复制到映像,而VOLUME指令只是说我将在主机上安装给定路径。
到目前为止,贯穿我脑海的事情:
通过ADD添加源代码文件,然后在命令行上使用“-v”开关将源代码安装在ADD上使用的相同路径上。
使用VOLUME,处理两个不同的Dockerfiles:用于开发容器,用于测试/开发,并根据需要构建每一个(这个东西我觉得适得其反,我的心告诉我这不是它应该如何工作)。
有人可以帮我弄这个吗? 我的大脑无法掌握,我应该(并理解)利用我的Docker知识?
官方PHP图像提供了两种可能的工作流程的示例。
对于生产,您可以使用Dockerfile构建包含代码的容器:
FROM php:5.6-apache
COPY src/ /var/www/html/
而对于开发,您运行一个带有引用本地文件系统的卷的容器:
docker run -it --rm --name my-php-dev -v "$PWD/src":/var/www/html php:5.6-apache
您肯定希望在开发中使用VOLUME
,除非您每次想要查看编辑乐趣时都发现重建图像。 同样,您希望在生产中使用ADD
,否则具有docker类型的不可变环境的整个想法就会消失。
为了避免让两个独立的Dockerfiles处理麻烦,你可以将你的基础环境(即:除了你的应用程序之外的所有东西)放到一个Dockerfile中,然后把它作为Docker Hub上的图像(或者只是使用现有的图像,如果你能找到一个适合你的需求)。 然后在开发中使用类似Docker Compose的东西(使用之前制作的图像作为应用程序的容器,并将代码库作为卷安装),以及从该docker镜像扩展的超薄Dockerfile,并添加代码库以进行生产。
对于正在编辑代码的开发工作流程,您可以使用VOLUME
(或只使用-v
运行容器)。 要将容器构建为可以发布以进行部署的映像,您需要ADD
,但这些是两个不同的用例,因此您可能需要2个不同的Dockerfile,它们相似但略有不同。
这是关键的事情,所以你可以记住这一点:如果你想避免重复的docker build
命令,VOLUME是你的本地开发的朋友,因为你可以更改代码并测试你的更改,而无需等待docker build
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.