构建Dockerfile - 在中间容器之间保留文件

时间:2017-11-08 19:52:29

标签: node.js docker dockerfile pm2

我正在使用keymetrics官方图片docker hub link here

构建一个非常基本的容器

然而,这不是node.js或pm2问题,这是一个很大的Docker问题,尤其是docker build

Dockerfile(npm install)中的一个步骤将节点包拉入node_modules文件夹 - IT WORKS。创建文件夹并下载文件并显示在构建输出中(如下所示)。

问题是在RUN命令完成后,中间容器被删除,我丢失了node_modules文件夹。

我的dockerfile有一些ls -l命令来澄清文件的内容。

工作目录(/app)中保留的唯一文件是我使用COPY命令从主机复制的文件

这是我的 Dockerfile:

FROM keymetrics/pm2:latest

# Bundle APP files
COPY src src/
COPY package.json .
COPY pm2.json .

# Install app dependencies
ENV NPM_CONFIG_LOGLEVEL info
RUN pwd && ls -l /app && npm install && ls -l

# Show current folder structure in logs
RUN ls -l

CMD [ "pm2-docker", "start", "pm2.json" ]

构建命令: docker build -t localapps/pm2_test_app:0.0.4 .

构建输出

Sending build context to Docker daemon  13.31kB
Step 1/8 : FROM keymetrics/pm2:latest
 ---> 6aa333f957ec
Step 2/8 : COPY src src/
 ---> Using cache
 ---> 6b73b4463af5
Step 3/8 : COPY package.json .
 ---> Using cache
 ---> d27a2e75fdde
Step 4/8 : COPY pm2.json .
 ---> Using cache
 ---> 9864d9dd73a9
Step 5/8 : ENV NPM_CONFIG_LOGLEVEL info
 ---> Using cache
 ---> 9f711fe6bada
Step 6/8 : RUN pwd && ls -l /app && npm install && ls -l
 ---> Running in 668eb2e2c1e8
/app
total 12
-rw-r--r--    1 root     root           323 Nov  8 17:33 package.json
-rw-r--r--    1 root     root           123 Nov  8 16:59 pm2.json
drwxr-xr-x    2 root     root          4096 Nov  8 18:10 src
npm info it worked if it ends with ok
npm info using npm@5.5.1
npm info using node@v9.0.0
... <omitting useless npm logs> ...

added 8 packages in 2.001s
npm info ok
total 20
drwxr-xr-x   10 root     root          4096 Nov  8 19:49 node_modules
-rw-r--r--    1 root     root          1833 Nov  8 19:49 package-lock.json
-rw-r--r--    1 root     root           323 Nov  8 17:33 package.json
-rw-r--r--    1 root     root           123 Nov  8 16:59 pm2.json
drwxr-xr-x    2 root     root          4096 Nov  8 18:10 src
 ---> 0d749171a431
Removing intermediate container 668eb2e2c1e8
Step 7/8 : RUN ls -l
 ---> Running in fc2132121c96
total 12
-rw-r--r--    1 root     root           323 Nov  8 17:33 package.json
-rw-r--r--    1 root     root           123 Nov  8 16:59 pm2.json
drwxr-xr-x    2 root     root          4096 Nov  8 18:10 src
 ---> c689180648c9
Removing intermediate container fc2132121c96
Step 8/8 : CMD pm2-docker start pm2.json
 ---> Running in e70b2b89b3c8
 ---> 299c26f883e8
Removing intermediate container e70b2b89b3c8
Successfully built 299c26f883e8
Successfully tagged localapps/pm2_test_app:0.0.4

^^注意node_modules目录是否存在,并且在第6步完成后可以继续使用?!

从构建输出中证明npm install运行并将包下拉到适当的目录....

但是在第7步它消失了?!此外,在最终的图像上,它已经消失了。应用程序不起作用,因为node_modules中的依赖关系在最终图像中被破坏了。

为什么呢?如果没有node_modules目录,应用程序将无法运行,它们是依赖项。

我能使这个工作的唯一方法是在构建之外运行npm_install,然后使用COPY复制文件夹,这绝对不是一个有效的解决方案......但它是一个成熟的解决方法。

我理解它使用了有意义的中间容器,但是如何在RUN命令中创建的文件保留到最后?

编辑: 进一步调查显示源映像dockerfile found here在其dockerfile中声明了VOLUME - 这是我的问题来自哪里?他们的例子显示,只需执行npm install即可开箱即用,但它不会消除安装下载的文件。

2 个答案:

答案 0 :(得分:3)

keymetrics / pm2图片在Dockerfile中包含以下行:

VOLUME ["/app"]

这会破坏任何后续步骤和子图像修改/app目录。来自docker's documentation

  

更改Dockerfile中的卷:如果任何构建步骤在声明后更改了卷中的数据,那么这些更改将被丢弃。

您需要在不同的目录中运行构建,制作不同的基本图像,或者说服上游作者删除该行。

我之前blogged about the issues with volumes defined in Dockerfiles,这是其中一个问题。在Dockerfile中使用这一行真的没有优势。

答案 1 :(得分:0)

pm2的泊坞窗图片fixed中的问题是new tags