在分布式系统中,容器经常需要利用健康检查机制来检查服务的增加制可用性,防止其他服务调用时出现异常。个健自 1.12 版本之后,康检Docker 引入了原生的网站模板查机健康检查实现。
如何给Docke配置原生健康检查能力,容器在写dockerfile的增加制时候,通过HEALTHCHECK指令就可以了

dockerfile如下:
FROM nginx:1.13 ADD test.sh /opt/test.sh HEALTHCHECK --interval=10s --timeout=3s --retries=3 CMD /bin/bash /opt/test.sh脚本如下:
vi /opt/test.sh #!/bin/bash cat /var/run/nginx.pid if [ $?个健 == 0 ];then echo 0 exit 0 else echo 1 exit 1 fi指令分析:
HEALTHCHECK --interval=10s --timeout=3s --retries=3 CMD /bin/bash /opt/test.sh
--interval 代表间隔,免费源码下载每隔10秒执行一次脚本
--timeout 脚本执行超时时间
--retries 脚本失败次数,康检3次失败,查机即30秒之后,容器标记容器为unhealthy
增加制服务正常启动案例:
增加制[root@k8s-node-1 opt]# docker run -d 10.0.0.11:5000/nginx:1.13.1 be97b9980431d326d9b745ec3f605c227caa085d50529926d27562ae1e339e39 [root@k8s-node-1 opt]# docker ps -a -l CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES be97b9980431 10.0.0.11:5000/nginx:1.13.1 "nginx -g daemon off" 4 seconds ago Up 3 seconds (health: starting) 80/tcp pensive_chandrasekhar [root@k8s-node-1 opt]# docker ps -a -l CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES be97b9980431 10.0.0.11:5000/nginx:1.13.1 "nginx -g daemon off" 11 seconds ago Up 10 seconds (healthy) 80/tcp pensive_chandrasekhar服务不正常启动案例:
增加制[root@k8s-node-1 opt]# docker run -d 10.0.0.11:5000/nginx:1.13.1 tail -f /etc/hosts b3b0b5a280930e40753da6174f22fd014510715c8757ad43928c2833a40a516d [root@k8s-node-1 opt]# docker ps -a -l CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES b3b0b5a28093 10.0.0.11:5000/nginx:1.13.1 "tail -f /etc/hosts" 38 seconds ago Up 38 seconds (unhealthy) 80/tcp furious_poincare容器死掉自动重启案例:
增加制[root@k8s-node-1 opt]# docker run --restart=always -d 10.0.0.11:5000/nginx:1.13.1 sleep 40 fd1017e1ce4f063e4110689ae476f2307ab0d6ce23286f64b102a949b58f657a [root@k8s-node-1 ~]# docker ps -a -l CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES fd1017e1ce4f 10.0.0.11:5000/nginx:1.13.1 "sleep 40" 33 seconds ago Up 32 seconds (unhealthy) 80/tcp tiny_mccarthy [root@k8s-node-1 ~]# docker ps -a -l CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES fd1017e1ce4f 10.0.0.11:5000/nginx:1.13.1 "sleep 40" 56 seconds ago Up 14 seconds (health: starting) 80/tcp tiny_mccarthy(责任编辑:数据库)