FROM ubuntu:14.04
COPY ./file.sh /
RUN chmod 755 /file.sh
# Note the json syntax on this next line is strict, double quotes, and any syntax
# error will result in a shell being used to run the line.
ENTRYPOINT [ "/file.sh" ]
docker run -d --rm $IMG_NAME "bash:command1&&command2&&command3"
字符串
在dockerfile中
ENTRYPOINT ["/entrypoint.sh"]
型
在entrypoint.sh
#!/bin/sh
entrypoint_params=$1
printf "==>[entrypoint.sh] %s\n" "entry_point_param is $entrypoint_params"
PARAM1=$(echo $entrypoint_params | cut -d':' -f1) # output is 1 must be 'bash' it will be tested
PARAM2=$(echo $entrypoint_params | cut -d':' -f2) # the real command separated by &&
printf "==>[entrypoint.sh] %s\n" "PARAM1=$PARAM1"
printf "==>[entrypoint.sh] %s\n" "PARAM2=$PARAM2"
if [ "$PARAM1" = "bash" ];
then
printf "==>[entrypoint.sh] %s\n" "about to running $PARAM2 command"
echo $PARAM2 | tr '&&' '\n' | while read cmd; do
$cmd
done
fi
8条答案
按热度按时间rkttyhzu1#
使用
file.sh
中的此脚本字符串
这个
Dockerfile
型
您应该能够:
型
35g0bw712#
使用相同的
file.sh
字符串
使用现有的Dockerfile构建镜像:
型
使用参数
abc
或xyz
或其他参数运行图像。型
clj7thdc3#
这里有几个相互作用的东西:
docker run your_image arg1 arg2
将用arg1 arg2
替换CMD
的值。这是对CMD的完全替换,而不是向其追加更多值。这就是为什么你经常看到docker run some_image /bin/bash
在容器中运行bash shell。1.当你同时定义了一个ENTRYPOINT和一个CMD值时,docker通过连接这两个值并运行连接的命令来启动容器。因此,如果您将入口点定义为
file.sh
,那么现在可以运行带有附加参数的容器,这些参数将作为参数传递给file.sh
。&&
)、变量替换等方面很有用。但是,shell会妨碍信号处理(如果您曾经看到过停止容器的10秒延迟,这通常是原因)以及将入口点和命令连接在一起。如果将入口点定义为字符串,它将运行/bin/sh -c "file.sh"
,这本身就很好。但是如果你也有一个定义为字符串的命令,你会看到像/bin/sh -c "file.sh" /bin/sh -c "arg1 arg2"
这样的命令在你的容器中被启动,这就不太好了。有关这两个选项如何相互作用的更多信息,请参见此处的表格-c
选项只接受一个参数。之后的所有内容都将以$1
、$2
等形式传递给该参数,但不会传递到嵌入式shell脚本中,除非显式传递参数。也就是说,/bin/sh -c "file.sh $1 $2" "arg1" "arg2"
可以工作,但/bin/sh -c "file.sh" "arg1" "arg2"
不行,因为file.sh
将被调用,没有参数。把所有这些放在一起,共同的设计是:
字符串
然后运行以下命令:
型
关于这一点有更多的细节:
7fhtutme4#
在Docker中,传递这类信息的正确方式是通过环境变量。
因此,使用相同的Dockerfile,将脚本更改为
字符串
构建完成后,使用以下docker命令:
型
wmomyfyw5#
我所拥有的是一个实际运行的脚本文件。此脚本文件可能相对复杂。我们称之为“run_container”。此脚本从命令行获取参数:
字符串
一个简单的run_container可能是:
型
我想做的是,在“dockering”之后,我希望能够使用docker命令行上的参数启动这个容器,如下所示:
型
并使用p1 p2 p3作为参数运行run_container脚本。
这是我的解决方案:
驳接文件:
型
uurv41yg6#
如果你想在编译时运行它:
字符串
如果你想在运行时运行它:
型
然后在主机 shell 中
型
mctunoxg7#
我想使用字符串版本的ENTRYPOINT,这样我就可以使用交互式shell了。
字符串
然后运行命令(注意
--
):型
其工作方式是
ENTRYPOINT
的字符串版本运行一个shell,该shell使用指定为-c
标志值的命令。在--
之后传递给shell的参数将作为"$@"
所在命令的参数提供。请参见此处的表格:https://tldp.org/LDP/abs/html/options.html(感谢@jkh和@BMitch的回答帮助我理解了正在发生的事情。
ocebsuys8#
另一个选择
让这一切成真
字符串
在dockerfile中
型
在entrypoint.sh
型