为什么docker exec在退出时杀死nohup进程?

时间:2015-11-16 09:29:55

标签: bash docker nohup

我已经运行了docker ubuntu容器,里面只有一个bash脚本。我想用Docker exec在那个容器中启动我的应用程序:

docker exec -it 0b3fc9dd35f2 ./main.sh

在主脚本内部我想用nohup运行另一个应用程序,因为这是一个运行时间很长的应用程序:

#!/bin/bash
nohup ./java.sh &
#with this strange sleep the script is working
#sleep 1
echo `date` finish main >> /status.log

java.sh脚本如下(为简单起见,它是一个虚拟脚本):

#!/bin/bash
sleep 10
echo `date` finish java >> /status.log

问题是在docker exec返回后java.sh被立即杀死。问题是为什么?

我发现的唯一解决方案是在nohup启动后在第一个脚本中添加一些虚拟sleep 1。比第二个进程运行正常。你知道为什么会这样吗?

[编辑]

第二种解决方案是在睡眠前向echo脚本添加一些trapjava.sh命令。比它工作正常。不幸的是我不能使用这种解决方法而不是这个脚本我有java进程。

3 个答案:

答案 0 :(得分:5)

这不是答案,但我仍然没有必要的评论声誉。

我不知道为什么nohup不起作用。但是我使用你的想法做了一个有效的解决方法:

docker exec -ti running_container bash -c 'nohup ./main.sh &> output & sleep 1'

答案 1 :(得分:2)

好的,让我们加入以上两个答案:D

首先 rcmgleite 说得恰到好处:使用

  

-d

运行流程的选项'分离'背景。

第二个(最重要的!)如果您运行分离式流程,不需要nohup

<强> deploy_app.sh

#!/bin/bash
cd /opt/git/app
git pull
python3 setup.py install
python3 -u webui.py >> nohup.out

在容器内执行此操作

docker exec -itd container_name bash -c "/opt/scripts/deploy_app.sh"

检查

$ docker attach container_name
$ ps aux
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.0  11768  1940 pts/0    Ss   Aug31   0:00 /bin/bash
root       887  0.4  0.0  11632  1396 pts/1    Ss+  02:47   0:00 /bin/bash /opt/scripts/deploy_app
root       932 31.6  0.4 235288 32332 pts/1    Sl+  02:47   0:00 python3 -u webui.py

答案 2 :(得分:1)

我知道这是一个迟到的回复,但出于文档原因,我会在此处添加回复。

在bash上使用nohup并在docker容器上使用'exec'运行时,你应该使用

$ docker exec -d 0b3fc9dd35f2 /bin/bash -c "./main.sh"

-d选项意味着:

  

-d, - detach分离模式:运行命令   背景

有关docker exec的更多信息,请参阅: https://docs.docker.com/engine/reference/commandline/exec/

这应该可以解决问题。