从 Docker 文档,有一个
restart policy
参数可以设置。
如何在容器退出时验证容器确实重新启动。如何手动触发容器退出,观察容器是否重启?
我的环境是Mac和boot2docker
谢谢
运行容器后,您可以检查其策略、重启计数和上次启动时间:
docker inspect -f "{{ .HostConfig.RestartPolicy }}" <container_id>
docker inspect -f "{{ .RestartCount }}" <container_id>
docker inspect -f "{{ .State.StartedAt }}" <container_id>
然后你可以查看容器进程:
docker exec -it <container_id> ps -aux
PID 1 进程 - 是主进程,在它死后整个容器都会死掉。
使用以下方法杀死它:
docker exec -it <container_id> kill -9 <pid>
在此之后确保容器自动重启:
docker inspect -f "{{ .RestartCount }}" <container_id>
你也可以
docker exec -it container_id bash
然后是主进程的kill -9
。我用docker run -d --restart=always -e DISPLAY=$DISPLAY -v /home/gg/moncontainer:/home/gg -v /tmp/.X11-unix:/tmp/.X11-unix k3ck3c/captvty
测试我杀死了主进程(pid 5,Captvty.exe),从容器中注销,2秒后重新启动,再次创建窗口
我刚刚手动创建了一个容器,像这样:
docker run -d --restart=always tacodata/pythondev sleep 10
注意,守护进程启动,但容器在 10 秒后退出。每次我执行 docker ps 时,我都会看到:
core@pa2 ~ $ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
69cbae4b6459 tacodata/pythondev:latest "sleep 10" About a minute ago Up 9 seconds 5000/tcp high_colden
所以,容器是在一分钟前创建的,但是状态只显示了 9 秒。它不断重启。您可以从以下位置获取该信息:
core@pa2 ~ $ docker inspect high_colden
[{
"AppArmorProfile": "",
...
"Path": "sleep",
"ProcessLabel": "",
"ResolvConfPath": "/var/lib/docker/containers/69cbae4b645926b14d86effcfaaa7735119e7f0c8afb0baff5cc1913583bf35a/resolv.conf",
"RestartCount": 16,
"State": {
"Error": "",
"ExitCode": 0,
"FinishedAt": "2015-04-16T16:36:15.325629703Z",
"OOMKilled": false,
"Paused": false,
"Pid": 13453,
"Restarting": false,
"Running": true,
"StartedAt": "2015-04-16T16:36:15.860163812Z"
},
"Volumes": {},
"VolumesRW": {}
}
您还可以重新启动 docker 服务以查看它是否在启动时启动容器。例如,在 Ubuntu 下,
sudo service docker restart
另一种选择:
使用
docker ps
获取要杀死的容器的容器ID。
然后执行
ps -efa | grep <Container ID>
获取进程ID.
然后做
sudo kill -9 <Process ID>
.