• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    docker容器内要启动两个进程时Dockerfile的实现代码

    近期想做一个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部署Consul配置过程解析
    下一篇:Docker 使用 Supervisor 来管理进程操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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