我正在使用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
即可开箱即用,但它不会消除安装下载的文件。
答案 0 :(得分:3)
keymetrics / pm2图片在Dockerfile中包含以下行:
VOLUME ["/app"]
这会破坏任何后续步骤和子图像修改/app
目录。来自docker's documentation:
更改Dockerfile中的卷:如果任何构建步骤在声明后更改了卷中的数据,那么这些更改将被丢弃。
您需要在不同的目录中运行构建,制作不同的基本图像,或者说服上游作者删除该行。
我之前blogged about the issues with volumes defined in Dockerfiles,这是其中一个问题。在Dockerfile中使用这一行真的没有优势。
答案 1 :(得分:0)