好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > docker容器內要啟動兩個進程時Dockerfile的實現代碼

docker容器內要啟動兩個進程時Dockerfile的實現代碼

熱門標簽:高德地圖標注足跡怎么打標 智能電銷機器人真的有用么 激光標記地圖標注 電銷智能機器人試用 百度地圖底圖標注 撫州市城區地圖標注 中國地圖標注上各個省 新鄉牧野400電話申請 企業辦理400電話收費標準

近期想做一個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=$?
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:

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的實現代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

標簽:延安 南通 辛集 海西 臨汾 邯鄲 忻州 西安

巨人網絡通訊聲明:本文標題《docker容器內要啟動兩個進程時Dockerfile的實現代碼》,本文關鍵詞  docker,容器,內,要,啟動,兩個,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《docker容器內要啟動兩個進程時Dockerfile的實現代碼》相關的同類信息!
  • 本頁收集關于docker容器內要啟動兩個進程時Dockerfile的實現代碼的相關信息資訊供網民參考!
  • 推薦文章