近期想做一个cron定时任务的docker,在Dockerfile中做如下定义
FROM library/alpine:latest RUN apk --update add rsync openssh bash VOLUME ["/data"] ADD start.sh / CMD ["/bin/bash","/start.sh"]
在start.sh中用crontab 加载定时任务run.cron,然后启动crond:
/usr/bin/crontab /run.cron
/usr/sbin/crond
docker build Dockerfile后,采用docker run –name xxx -d 运行容器,发现start.sh执行后容器就退出了,根本无法启动定时任务,网上各种办法有说用nohup,有死循环,还有说用信号,发现都不靠谱。
分析了一下docker的机制,一个docker容器同时只能管理一个进程,这个进程退出后,容器也就退出了。这并不意味着一个容器里只能同时运行一个进程(那样太浪费了),只是最后一个运行的进程不能退出。
这个案例在容器启动运行start.sh,crond的缺省设置是后台运行,这样导致start.sh运行结束,容器跟着start.sh退出而退出。
因此,在start.sh中,crond 应强制采用前台运行:crond -f。
这样start.sh就不会退出, docker run -d 运行时就可以保持容器后台运行。
start.sh总结总结:
(1)容器中运行多个守护进程时,前面的进程要用后台方式运行(或添加 &),否则后面的服务无法启动
(2)容器中最后一个守护进程一定要用前台方式运行,否则start.sh退出,容器退出,所有的服务就白启动了
FROM ubuntu:latest RUN mkdir -p "/usr/src/pdas" mkdir -p "/usr/src/pdas/reload" COPY bin.tar /usr/src/pdas COPY config.tar /usr/src/pdas COPY lib.tar /usr/src/pdas WORKDIR /usr/src/pdas RUN tar -xvf lib.tar && tar -xvf bin.tar && tar -xvf config.tar ENV LD_LIBRARY_PATH /usr/src/pdas/lib/libxml/lib:/usr/src/pdas/lib/curl/lib:$LD_LIBRARY_PATH WORKDIR /usr/src/pdas/bin RUN chmod +x start.sh && chmod +x f_recv && chmod +x f_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 # Start the first process nohup python -u /tmp/thread1.py > /tmp/thread1.log 2>&1 & ps aux |grep thread1 |grep -q -v grep PROCESS_1_STATUS=$"thread1 status..." echo $PROCESS_1_STATUS if [ $PROCESS_1_STATUS -ne 0 ]; then echo "Failed to start my_first_process: $PROCESS_2_STATUS" exit $PROCESS_1_STATUS fi sleep 5 # Start the second process nohup python -u /tmp/thread2.py > /tmp/thread2.log 2>&1 & ps aux |grep thread2 |grep -q -v grep PROCESS_2_STATUS=$"thread2 status..." echo $PROCESS_2_STATUS if [ $PROCESS_2_STATUS -ne 0 ]; then echo "Failed to start my_second_process: $PROCESS_2_STATUS" exit $PROCESS_2_STATUS fi # 每隔60秒检查进程是否运行 while sleep 60; do ps aux |grep thread1 |grep -q -v grep PROCESS_1_STATUS=$"One of the processes has already exited." exit 1 fi
下一步制作Dockerfile:
FROM centos:latest COPY thread1.py /tmp/thread1.py COPY thread2.py /tmp/thread2.py COPY multiple_thread.sh /tmp/multiple_thread.sh CMD bash /tmp/multiple_thread.sh
以上这篇docker容器内要启动两个进程时Dockerfile的实现代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
更新日志
- 王艺翔.2024-至暖(EP)【乐人】【FLAC分轨】
- 樊桐舟《流年微词HQCD》WAV+CUE
- Rachmaninoff-SymphonicDances-BerlinerPhilharmoniker,KirillPetrenko(2024)[24-96]
- 岡部啓一《NieRGestaltReplicantOrchestralArrangementAlbum》24-96\FLAC
- 群星《心光》[FLAC/分轨][307.76MB]
- 许茹芸《讨好》[WAV+CUE][1G]
- 唐磊《丁香花》[WAV+CUE]
- 刘德华.2001-天开了【BMG】【WAV+CUE】
- 群星.2013-顾嘉辉大师经典演唱会3CD【爱我音乐】【WAV+CUE】
- 费翔.2000-费常翔念2CD【环球】【WAV+CUE】
- Rachmaninoff-SuitesNos.12,TheSleepingBeauty-MikuOmine,TakakoTakahashi(2024)[24-
- 童丽《影视金曲(1:1黄金母盘版)》[WAV]
- 柏菲·胭花四乐《胭花四乐》限量开盘母带ORMCD[低速原抓WAV+CUE]
- 群星《监听耳机天碟》2018[WAV分轨][1G]
- 群星《娱协奖原创金曲合辑》滚石[WAV+CUE][1.1G]