我尝试使用入口点和cmd设置Docker。
FROM debian:stretch
RUN apt-get update && \
apt install gnupg ca-certificates -y
RUN echo "deb http://repo.aptly.info/ squeeze main" > /etc/apt/sources.list.d/aptly.list
RUN apt-key adv --keyserver keys.gnupg.net --recv-keys 9E3E53F19C7DE460
RUN apt update && apt install aptly -y
ADD aptly.conf /etc/aptly.conf
ADD start.sh .
VOLUME ["/aptly"]
ENTRYPOINT ["/start.sh"]
CMD ["aptly", "api", "serve"]
但是入口点脚本没有停止...... cmd命令未启动
这是我的剧本:
#!/bin/bash
set -e
init_aptly() {
#import pgp key
#create nginx root folder in /aptly
su -c "mkdir -p /aptly/.aptly/public"
echo "12"
#initialize repository
#aptly create repo doze-server - distribution="stable"
}
#check for first run
if [ ! -e /aptly/.aptly/public ]; then
init_aptly
echo "13"
fi
echo "14"
脚本总是回显14,我只想要一个,然后从dockerfile执行cmd命令
答案 0 :(得分:11)
当您同时使用入口点和命令时,命令部分将作为参数附加到entrypoint可执行文件。因此在你的情况下:
ENTRYPOINT ["/start.sh"]
CMD ["aptly", "api", "serve"]
相当于跑步:
ENTRYPOINT["/start.sh", "aptly", "api", "serve"]
答案 1 :(得分:1)
在不知道入口点的作用的情况下无法说清楚,但实质上这就是你将入口点和cmd结合在一起所做的事情:
/start.sh aptly api serve
如果您只是在启动服务器之后,您可以执行以下操作(可能需要aptly
可执行文件的有效路径):
ENTRYPOINT ["aptly"]
CMD ["api", "serve"]
除非您只是运行可执行文件,否则不需要输入点脚本。
答案 2 :(得分:0)
一个重要的注意事项,因为没有其他人提到它:为了同时使用 ENTRYPOINT
和 CMD
,您需要在数组格式中指定两者。做这样的事情行不通:
ENTRYPOINT ./my_script.sh
CMD echo "hello world"
在上面的代码中,会调用 ./my_script.sh
,但不会传入 CMD
。