docker容器内要启动两个进程时Dockerfile的实现代码
近期想做一个cron定时任务的docker,在Dockerfile中做如下定义
FROMlibrary/alpine:latest RUNapk--updateaddrsyncopensshbash VOLUME["/data"] ADDstart.sh/ CMD["/bin/bash","/start.sh"]
在start.sh中用crontab加载定时任务run.cron,然后启动crond:
/usr/bin/crontab/run.cron
/usr/sbin/crond
dockerbuildDockerfile后,采用dockerrun–namexxx-d运行容器,发现start.sh执行后容器就退出了,根本无法启动定时任务,网上各种办法有说用nohup,有死循环,还有说用信号,发现都不靠谱。
分析了一下docker的机制,一个docker容器同时只能管理一个进程,这个进程退出后,容器也就退出了。这并不意味着一个容器里只能同时运行一个进程(那样太浪费了),只是最后一个运行的进程不能退出。
这个案例在容器启动运行start.sh,crond的缺省设置是后台运行,这样导致start.sh运行结束,容器跟着start.sh退出而退出。
因此,在start.sh中,crond应强制采用前台运行:crond-f。
这样start.sh就不会退出,dockerrun-d运行时就可以保持容器后台运行。
start.sh总结总结:
(1)容器中运行多个守护进程时,前面的进程要用后台方式运行(或添加&),否则后面的服务无法启动
(2)容器中最后一个守护进程一定要用前台方式运行,否则start.sh退出,容器退出,所有的服务就白启动了
FROMubuntu:latest RUNmkdir-p"/usr/src/pdas"\ mkdir-p"/usr/src/pdas/reload" COPYbin.tar/usr/src/pdas COPYconfig.tar/usr/src/pdas COPYlib.tar/usr/src/pdas WORKDIR/usr/src/pdas RUNtar-xvflib.tar&&\ tar-xvfbin.tar&&\ tar-xvfconfig.tar ENVLD_LIBRARY_PATH/usr/src/pdas/lib/libxml/lib:/usr/src/pdas/lib/curl/lib:$LD_LIBRARY_PATH WORKDIR/usr/src/pdas/bin RUNchmod+xstart.sh&&\ chmod+xf_recv&&\ chmod+xf_send VOLUME/behb/diqu VOLUME/var/log/pdas ENTRYPOINT./start.sh
其中./start.sh脚本如下
#!/bin/bash ./f_recv& ./f_send
以上是docker镜像启动脚本的一点心得。
补充知识:Docker中运行多个进程时的处理
通常,Docker容器适合运行单个进程,但是很多时候我们需要在Docker容器中运行多个进程。这时有两种不同方法来运行多进程容器:使用shell脚本或者supervisor,两种方法都很简单,各有优劣,只是有一些值得注意的细节。这里只讲用脚本的处理方法。
写一个脚本multiple_thread.sh,脚本功能运行两个python程序,将运行结果保存到log文件中。脚本内容如下
#!/bin/bash #Startthefirstprocess nohuppython-u/tmp/thread1.py>/tmp/thread1.log2>&1& psaux|grepthread1|grep-q-vgrep PROCESS_1_STATUS=$? echo"thread1status..." echo$PROCESS_1_STATUS if[$PROCESS_1_STATUS-ne0];then echo"Failedtostartmy_first_process:$PROCESS_2_STATUS" exit$PROCESS_1_STATUS fi sleep5 #Startthesecondprocess nohuppython-u/tmp/thread2.py>/tmp/thread2.log2>&1& psaux|grepthread2|grep-q-vgrep PROCESS_2_STATUS=$? echo"thread2status..." echo$PROCESS_2_STATUS if[$PROCESS_2_STATUS-ne0];then echo"Failedtostartmy_second_process:$PROCESS_2_STATUS" exit$PROCESS_2_STATUS fi #每隔60秒检查进程是否运行 whilesleep60;do psaux|grepthread1|grep-q-vgrep PROCESS_1_STATUS=$? psaux|grepthread2|grep-q-vgrep PROCESS_2_STATUS=$? #Ifthegrepsabovefindanything,theyexitwith0status #Iftheyarenotboth0,thensomethingiswrong if[$PROCESS_1_STATUS-ne0-o$PROCESS_2_STATUS-ne0];then echo"Oneoftheprocesseshasalreadyexited." exit1 fi
下一步制作Dockerfile:
FROMcentos:latest COPYthread1.py/tmp/thread1.py COPYthread2.py/tmp/thread2.py COPYmultiple_thread.sh/tmp/multiple_thread.sh CMDbash/tmp/multiple_thread.sh
以上这篇docker容器内要启动两个进程时Dockerfile的实现代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。