gpt4 book ai didi

docker容器内要启动两个进程时Dockerfile的实现代码

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 35 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章docker容器内要启动两个进程时Dockerfile的实现代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

近期想做一个cron定时任务的docker,在Dockerfile中做如下定义 。

?
1
2
3
4
5
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退出,容器退出,所有的服务就白启动了 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
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脚本如下 。

?
1
2
3
#!/bin/bash
. /f_recv &
. /f_send

以上是docker镜像启动脚本的一点心得.

补充知识:Docker中运行多个进程时的处理 。

通常,Docker容器适合运行单个进程,但是很多时候我们需要在Docker容器中运行多个进程。这时有两种不同方法来运行多进程容器:使用shell脚本或者supervisor,两种方法都很简单,各有优劣,只是有一些值得注意的细节。这里只讲用脚本的处理方法.

写一个脚本multiple_thread.sh,脚本功能运行两个python程序,将运行结果保存到log文件中。脚本内容如下 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#!/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=$?
echo "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=$?
echo "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=$?
ps aux | grep thread2 | grep -q - v grep
PROCESS_2_STATUS=$?
# If the greps above find anything, they exit with 0 status
# If they are not both 0, then something is wrong
if [ $PROCESS_1_STATUS - ne 0 -o $PROCESS_2_STATUS - ne 0 ]; then
echo "One of the processes has already exited."
exit 1
fi

下一步制作Dockerfile

?
1
2
3
4
5
6
7
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的实现代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.

原文链接:https://blog.csdn.net/watcher0111/article/details/79929682 。

最后此篇关于docker容器内要启动两个进程时Dockerfile的实现代码的文章就讲到这里了,如果你想了解更多关于docker容器内要启动两个进程时Dockerfile的实现代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com