天天看點

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