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