Docker容器意外(非正常)关闭后无法正常启动
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Docker容器意外(非正常)关闭后无法正常启动相关的知识,希望对你有一定的参考价值。
参考技术A 最近发现一个Docker的容器意外关闭了,启动的时候提示:莫名其妙,查看日志未发现异常,网上一阵乱搜总结处理如下:
再次启动,成功!
docker
一 启动进入容器指定bash 退出后容器关闭
[[email protected] ~]# docker run -it centos bash [[email protected] /]#
二 docker attach进入容器后退出 如果容器没有指定bash环境会停留在空白页面 退出后容器也会正常退出(进入容器后其他人进入容器可以看到你输入的信息)
[[email protected] ~]# docker run -it -d --name mynginx nginx /bin/bash c23ba383b76baa6c3e1a9450e23e6e4f46724a4e2b8e8c2b8c002e54ba2e5f32 [[email protected]-node3 ~]# docker attach mynginx [email protected]:/# ls bin dev home lib64 mnt proc run srv tmp var boot etc lib media opt root sbin sys usr [email protected]:/# exit exit [[email protected]-node3 ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
三 docker exec 进入容器 会启用一个bash环境
[[email protected] ~]# docker run -it -d --name mycentos centos /bin/bash 68e1f711a4990f66ad3456b453591c3fa9a7d22d4fed3e50bda1cf27a36cc60a [[email protected]-node3 ~]# docker exec -it mycentos bash [[email protected] /]# ps -ef PID TTY TIME CMD 1 ? 00:00:00 bash 13 ? 00:00:00 bash 25 ? 00:00:00 ps [[email protected] /]# exit exit [[email protected]-node3 ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 68e1f711a499 centos "/bin/bash" About a minute ago Up About a minute mycentos c23ba383b76b nginx "/bin/bash" 5 minutes ago Up 2 minutes 80/tcp mynginx
[[email protected] ~]# docker exec -it mycentos ls
anaconda-post.log dev home lib64 mnt proc run srv tmp var
bin etc lib media opt root sbin sys usr
四 nsenter
yum -y install util-linux #安装nsenter命令
[[email protected] ~]# docker inspect -f "{{ .State.Pid }}" mycentos
30428 #查看容器pid
nsenter -t 30428 -m -u -i -n -p -t:指定PID –u:参数是进入到uts namespace中 –i:参数是进入到System V IPC namaspace中 –n:参数是进入到network namespace中 –p:参数是进入到pid namespace中
脚本方式进入(可直接传参docker name 或者ID)
[[email protected] ~]# cat docker_in.sh #!/bin/bash #Use nsenter to access docker docker_in(){ NAME_ID=$1 PID=$(docker inspect -f "{{ .State.Pid }}" $NAME_ID) nsenter -t $PID -m -u -i -n -p } docker_in $1
以上是关于Docker容器意外(非正常)关闭后无法正常启动的主要内容,如果未能解决你的问题,请参考以下文章
php mcrypt 在 docker 容器上启用后无法正常工作