解决群晖Docker无法停止容器的问题
最近在群晖上折腾一些好玩的Docker镜像,其中有一个容器准备停掉然后修改下配置,但是在Docker管理界面点击停止后,却没有任何反应,即使通过SSH连接到群晖上使用
docker stop xxx
,依然无法停止此容器。不仅如此,后来又发现针对此容器各类docker命令均无效,表现为输入命令后一直hang住,既没有成功也不报失败!
查找原因
通过询问搞运维的朋友,反馈说大概率是这个容器在启动时又在内部启动动了另一个进程,然后退出了初始化进程,导致新启动的进程成了孤儿进程,进而导致docker stop
无法执行成功(docker stop会发送kill -9)。但是通过一通操作,譬如ps -ef | awk '{ if ($4==1){print}}'
、docker top <id>
等等,依然无法确定孤儿线程,无奈只能另寻他法。
于是换个思路,既然容器无法关闭,那能不能直接把Docker应用重启呢?
经过一番搜索,还真在群晖系统中发现了端倪!在/var/packeges/Docker/scripts
路径下,发现了一个脚本:start-stop-status

看了下这个脚本,发现它的作用就是启动和关闭Docker应用,并且在关闭应用本身的时候也关闭容器,简直太贴心了。
解决问题
接下来就很简单了,首先cd到上面的那个目录
- 第一步,现在终端中输入:
./start-stop-status stop |
显示stopped
,但是并没有真正完成,还需要耐心等待,直到命令执行完。

终端中输出下面的内容时不用担心,继续等待:

直到出现以下内容,表示Docker停止完成。

- 第二步,重新启动Docker,在终端中输入:./start-stop-status start
跟第一步一样,耐心等待脚本执行,直到出现下面内容,表示重启完成。
3、经过停止和重启后,原先无法正常关闭的容器,现在就可以正常关闭了。