24

我有什么理由需要在我的入口点脚本上 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"]
4

2 回答 2

16

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,因此文件的可执行位受到尊重。

于 2014-12-03T23:55:31.310 回答
13

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

于 2018-08-01T11:26:39.467 回答