天天看点

Docker 健康检查功能

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-&gt;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-&gt;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-&gt;80</code><code>/tcp</code>   <code>nginx-1</code>

任何健康状况变化都会触发Docker事件(heath_status),以便我们可以对更改做出反应,而无需使用轮询Docker引擎。

这个功能帮助开发人员在各种场景中构建更具弹性的软件:例如在负载均衡中,流量不应该被传送到标记为不健康的容器上。

 本文转自 酥心糖 51CTO博客,原文链接:http://blog.51cto.com/tryingstuff/1955147