Docker1.12及以上版本,自带了健康检查功能。通常情况下只能使用docker ps 来查看容器是否是up的状态,但是服务是否正常我们不可知,而健康检查功能,可以允许我们在容器中执行一些健康检查的命令,然后将容器的状态在"STATUS"中标识:
1
2
3
<code>[root@docker]</code><code># docker ps</code>
<code>CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES</code>
<code>1bd250e6836a trying</code><code>/nginx_dockerfile</code><code>:v1 </code><code>"nginx"</code> <code>16 seconds ago Up 13 seconds (healthy) 0.0.0.0:80->80</code><code>/tcp</code> <code>nginx-1</code>
实现这一功能只需要在构建镜像的Dockerfile中加入“HEALTHCHECK”字段:
HEALTHCHECK --interval=5s --timeout=3s CMD curl --fail http://localhost:80/ || exit 1
如果http状态码是200,退出代码将为0,容器将被标记为运行状况。 如果服务器响应任何错误,退出代码将为1,容器处于不健康状态。
HEALTHCHECK有3个选项参数:
<code>--interval=DURATION</code> (default 30s)
<code>--timeout=DURATION</code> (default 30s)
<code>--retries=N</code> (default 3)
下面是具有以上健康检查功能的简单Dockerfile:
4
5
6
7
8
9
<code>FROM centos</code>
<code>MAINTAINER trying [email protected]</code>
<code>RUN rpm -ivh http:</code><code>//mirrors</code><code>.aliyun.com</code><code>/epel/epel-release-latest-7</code><code>.noarch.rpm</code>
<code>RUN yum </code><code>install</code> <code>nginx -y</code>
<code>RUN </code><code>sed</code> <code>-i </code><code>'N;6adaemon off;'</code> <code>/etc/nginx/nginx</code><code>.conf</code>
<code>ADD index.html </code><code>/usr/share/nginx/html/index</code><code>.html</code>
<code>HEALTHCHECK --interval=5s --timeout=3s CMD curl --fail http:</code><code>//localhost</code><code>:80/ || </code><code>exit</code> <code>1</code>
<code>EXPOSE 80</code>
<code>CMD [</code><code>"nginx"</code><code>]</code>
也可以直接使用nginx镜像,使用如下Dockerfile:
<code>FROM nginx:latest</code>
<code>CMD </code><code>/usr/sbin/nginx</code> <code>-g </code><code>'daemon off;'</code>
构建镜像并启动:
<code>docker build -t trying</code><code>/nginx_dockerfile</code><code>:v1 ./</code>
<code>docker run -d -p 80:80 --name nginx-1 trying</code><code>/nginx_dockerfile</code><code>:v1 nginx</code>
在启动初始阶段,会显示“health: starting”的状态:
<code>CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES</code>
<code>1bd250e6836a trying</code><code>/nginx_dockerfile</code><code>:v1 </code><code>"nginx"</code> <code>5 seconds ago Up 3 seconds (health: starting) 0.0.0.0:80->80</code><code>/tcp</code> <code>nginx-1</code>
当容器正常时:
当容器故障时,如删除nginx的index.html文件,404错误状态为”unhealthy“:
<code>CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES</code>
<code>1bd250e6836a trying</code><code>/nginx_dockerfile</code><code>:v1 </code><code>"nginx"</code> <code>49 minutes ago Up 49 minutes (unhealthy) 0.0.0.0:80->80</code><code>/tcp</code> <code>nginx-1</code>
任何健康状况变化都会触发Docker事件(heath_status),以便我们可以对更改做出反应,而无需使用轮询Docker引擎。
这个功能帮助开发人员在各种场景中构建更具弹性的软件:例如在负载均衡中,流量不应该被传送到标记为不健康的容器上。
本文转自 酥心糖 51CTO博客,原文链接:http://blog.51cto.com/tryingstuff/1955147