我正在寻找一种同时实现这些目标的方法:
node_modules
保留在容器内(不要"污染"主机上的工作目录)Dockerfile
我不确定这些目标是否被考虑"最佳实践"。例如,在容器中保留node_modules
的内容为disadvantages。
目前我的撰写文件是这样的:
services:
# ...
node:
image: "node:9"
user: "node"
working_dir: /home/node/app
environment:
# - NODE_ENV=production
- NPM_CONFIG_PREFIX=/home/node/.npm-global
- PATH=$PATH:/home/node/.npm-global/bin
volumes:
- ./proj/:/home/node/app
- /home/node/app/node_modules # mark1
ports:
- "3001:3001"
command: >
bash -c "echo hello
&& ls -lh /home/node/app/
&& npm install
&& npm i -g babel-cli
&& npm i -g flow-bin
&& npm start"
depends_on:
- redis
但是有
"Error: EACCES: permission denied, access
'/home/node/app/node_modules'".
如果我注释掉#mark1
行,则容器会运行,但node_modules
会写入主机(因为./proj
为mounted)
我已经阅读了关于这个主题的这两篇文章:
但都达不到我的目标。
我添加了一行ls -lh /home/node/app/
,发现node_modules
归root
所有。这可能是问题所在。
答案 0 :(得分:1)
我最终使用Dockerfile
。这是最低限度的。 (我保留一些注释掉的行,任何人都可能觉得它们很有用。)
我们需要更改容器内node_modules
的所有者。 似乎(更新:抱歉。我忘了用node:9
图片不需要这个。所以这仅适用于node:9-alpine
。docker system prune
删除构建的容器。两个图片都需要这个。这是{{ 3}})
FROM node:9-alpine
#ENV NPM_CONFIG_PREFIX=/home/node/.npm-global
#ENV PATH=$PATH:/home/node/.npm-global/bin
RUN mkdir -p /home/node/app/node_modules
RUN chown -R node:node /home/node/app
#USER node
#WORKDIR /home/node/app
#RUN npm install --silent --progress=false ; \
# npm i -g babel-cli --silent --progress=false ;\
# npm i -g flow-bin --silent --progress=false
docker-compose.yml
最终结果如下:
services:
# ...
node:
# image: "node:9-alpine"
build: ./proj
user: "node"
working_dir: /home/node/app
environment:
# - NODE_ENV=production
- NPM_CONFIG_PREFIX=/home/node/.npm-global
- PATH=$PATH:/home/node/.npm-global/bin
volumes:
- ./proj/:/home/node/app
- /home/node/app/node_modules/
ports:
- "3006:3001"
command: >
/bin/sh -c "echo hello
&& ls -lh /home/node/app/
&& npm install
&& npm i -g babel-cli
&& npm i -g flow-bin
&& npm start"
depends_on:
- redis