为什么我的docker在执行我的shell脚本后退出?

时间:2016-12-15 08:33:15

标签: shell docker

为什么我的docker在执行shell脚本后退出?感谢。

Docker版本:

docker --version
Docker version 1.12.4, build 1564f02

我的图片:

docker pull lw96/ubuntu-16.04-lnmp1.3

我跑完后:

docker run -it -d --name test -p 8080:80 lw96/ubuntu-16.04-lnmp1.3 sh /root/run.sh

我查了一下:docker ps -a

root@ubuntu:/home/liwei# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS                  NAMES
68c0ce4c59f7        a57b0c1a60cf        "/bin/bash"         2 minutes ago       Up 2 minutes        0.0.0.0:8080->80/tcp   test

这是run.sh:

#! /bin/bash
lnmp restart
echo "lnmp already start"
exit 0

我得到了日志:

root@ubuntu:/home/liwei# docker logs -f test
+-------------------------------------------+
|    Manager for LNMP, Written by Licess    |
+-------------------------------------------+
|              http://lnmp.org              |
+-------------------------------------------+
Stoping LNMP...
Stoping nginx... nginx is not running.
 * MySQL server PID file could not be found!
Gracefully shutting down php-fpm /etc/init.d/php-fpm: 82: kill: No such process

................................... failed. Use force-quit
Starting LNMP...
Starting nginx...  done
Starting MySQL
.. * 
Starting php-fpm  done
lnmp already start!

之后,我的DOCKER CONTAINER退出:

root@ubuntu:/home/liwei# docker ps -a
CONTAINER ID        IMAGE                       COMMAND             CREATED             STATUS                     PORTS               NAMES
cb98d7427802        lw96/ubuntu-16.04-lnmp1.3   "sh /root/run.sh"   8 minutes ago       Exited (0) 7 minutes ago                       test

但是,当我使用:

docker pull lw96/ubuntu-16.04-lnmp1.3

docker run -it -d -p 80:80 --name test  lw96/ubuntu-16.04-lnmp1.3

docker exec -it test /bin/bash

cd ~ && ./run.sh

我的容器效果很好。为什么?????

1 个答案:

答案 0 :(得分:3)

只要主进程正在运行,docker容器就会运行,然后只要入口点/命令进程退出就会结束。在您的情况下,一旦到达exit 0行,您的流程就完成了,并且docker容器应该退出。

如果你想阻止它,你必须保持你的进程运行。在那里你有很多选择,比如在前台运行你的流程,或者只是通过tail -f /some/log/file这样的事情来保持流程的运行,其中日志来自你的后台运行过程。