问题 Docker文件:入口点脚本上的Chmod


有没有理由我需要在我的入口点脚本上使用chmod + x?它似乎没有出现Redis在他们的dockerfile中这样做(https://github.com/docker-library/redis/blob/109323988b7663bceaf4a01c3353f8934dfc002e/2.8/Dockerfile)他们的入口点脚本。

Dockerfile:

# Generic Docker Image for Running Node app from Git Repository
FROM    node:0.10.33-slim
ENV NODE_ENV production

# Add script to pull Node app from Git and run the app
COPY docker-node-entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh
ENTRYPOINT ["/entrypoint.sh"]

EXPOSE  8080
CMD ["--help"]

6117
2017-12-03 21:26


起源



答案:


redis不需要这样做,因为他们的脚本已经有exec标志:

~/redis/2.8$ ls -l docker-entrypoint.sh 
-rwxrwxr-x 1 igor igor 109 Dec  3 23:52 docker-entrypoint.sh

如果您将为docker-node-entrypoint.sh脚本执行此操作,则在Dockerfile中也不需要chmod。

这是可能的,因为默认情况下git core.fileMode选项为true,因此文件的可执行位被尊重。


11
2017-12-03 23:55





Docker将使用其源的权限将文件复制到容器中。如果在推送到代码仓库或构建主机的链中某处删除Linux可执行文件位,则需要重新添加这些执行权限。我已经看到Windows用户最常报告的这个问题,他们正在将代码下载到不支持Linux权限位的文件系统。希望我们能得到一个 COPY --chmod 解决方案很快将消除对额外层的需求


1
2017-08-01 11:26