从Docker document,可以设置restart policy
参数。
如何在容器退出时验证容器是否确实重新启动。如何手动触发容器的退出,并观察容器是否重启?
我的环境是Mac和boot2docker。
由于
答案 0 :(得分:10)
运行容器后,您可以检查其策略,重新启动coun和上次启动时间:
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>
答案 1 :(得分:3)
您还可以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秒后重新启动,窗口再次创建
答案 2 :(得分:1)
我刚刚手动创建了一个容器,如下所示:
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": {}
}
答案 3 :(得分:0)
您还可以重新启动docker service以查看它是否在启动时启动容器。例如,在Ubuntu下,
sudo service docker restart