Docker Health Check

Background

通常情況下,我們會(huì)使用一個(gè)容器運(yùn)行一種服務(wù),比如一個(gè)容器運(yùn)行數(shù)據(jù)庫(kù)服務(wù)唠叛,一個(gè)容器作為web服務(wù)器等等, 因此一個(gè)容器被setup起來(lái)并不能代表其中的服務(wù)毫無(wú)問(wèn)題浪箭,因此如何check容器中的服務(wù)器是否正常才是最重要的問(wèn)題控漠。

容器的狀態(tài)

我們都知道矗积,通過(guò)docker ps你可以看到所有正在運(yùn)行的容器全肮,以及容器的部分信息:
[圖片上傳失敗...(image-f10236-1555504132810)]
有兩個(gè)列是需要關(guān)注的:

  • COMMAND:
    通常為了容器中的service正常啟動(dòng),我們會(huì)使用CMD/ENTRYPOINT設(shè)置一段指令棘捣。容器啟動(dòng)之后辜腺,通常會(huì)根據(jù) Dockerfile 中的 CMD 或 ENTRYPOINT 啟動(dòng)一個(gè)進(jìn)程,Command描述的就是這個(gè)進(jìn)程執(zhí)行的指令柱锹。

  • STATUS
    描述的是當(dāng)前容器的狀態(tài),以及容器在多久之前進(jìn)入這樣的狀態(tài)哪自。也可以說(shuō)他描述的是上面COMMAND指令執(zhí)行的情況。

    命令顯示:

    • 有的容器正在運(yùn)行禁熏,狀態(tài)為 UP壤巷。

    • 有的容器已經(jīng)正常停止了,狀態(tài)是 Exited (0)瞧毙‰驶或者說(shuō)COMMAND執(zhí)行的指令正常退出

    • 有的則因發(fā)生故障停止了,退出代碼為非 0宙彪,例如 Exited (137)矩动、Exited (1) 等。

雖然释漆,我們通常會(huì)通過(guò)CMD悲没、ENTRYPOINT設(shè)置COMMAND指令是容器server的啟動(dòng)指令,我們也能通過(guò)STATUS看到啟動(dòng)指令是否執(zhí)行成功男图。但是及時(shí)COMMAND沒(méi)有出錯(cuò)STATUS是up也不能等同于這個(gè)server可以提供服務(wù)

Health Check

What

Docker允許指定一個(gè)命令作為health check命令示姿,Docker可以通過(guò)這個(gè)指令執(zhí)行的成功與否來(lái)判定容器當(dāng)前的狀態(tài)。

Docker 支持的 Health Check 可以是任何一個(gè)單獨(dú)的命令逊笆,Docker 會(huì)在容器中執(zhí)行該命令栈戳,如果返回 0,容器被認(rèn)為是 healthy难裆,如果返回 1子檀,則為 unhealthy。

當(dāng)一個(gè)容器有指定健康檢查 (HEALTHCHECK) 時(shí)乃戈,它除了普通的容器狀態(tài)之外褂痰,還有:

  • starting: Initial status when the container is still starting
  • healthy: 如果health check成功
  • unhealthy: If a single run of the takes longer than the specified timeout then it is considered unhealthy. If a health check fails then the will run retries number of times and will be declared unhealthy if the still fails.

這些狀態(tài)你可以通過(guò)docker ps看到。

how to check health

In Dockerfile
  • 給鏡像設(shè)置HEALTHCHECK
    HEALTHCHECK [option] CMD <command>
    
    • command是HEAlthcheck的指令:如果你的service是restful api偏化,指令可以是curl heartbeat api
    • option:
      • --interval=<interval>: 兩次健康檢查命令執(zhí)行的間隔時(shí)間. default value 是 30 seconds.
      • --timeout=<interval>: 設(shè)置某一個(gè)次health check執(zhí)行的timeout時(shí)間脐恩,一旦超時(shí)代表這一次healthcheck失敗. default value 是 30 seconds.
      • --retries=<number of times>: 設(shè)置health check連續(xù)失敗次數(shù)一旦達(dá)到設(shè)置的值容器狀態(tài)就會(huì)變成unhealthy. default value 是 3.
      • --start-period=<interval>: The initialization time of application startup. Failed health check during the startup is not counted. The default value is 0 second (introduced since version 17.05).

Note
The HEALTHCHECK 只能在Dockerfile中出現(xiàn)一次,如果你設(shè)置了多次侦讨,那么就會(huì)直接使用最后一個(gè)命令

  • 如果本身鏡像中有HEALTHCHECK驶冒,下面的指令可以禁止HEALTHCHECK
HEALTHCHECK NONE

一旦容器被正常啟動(dòng),初始狀態(tài)就是starting. Docker engine會(huì)自動(dòng)的根據(jù)你設(shè)定的--interval, 每個(gè)interval時(shí)間運(yùn)行一次這個(gè)health check command韵卤, 并且根據(jù)每次運(yùn)行的結(jié)果及時(shí)的update你的容器的status

舉個(gè)例子:

FROM elasticsearch:5.5
HEALTHCHECK --interval=5s --timeout=2s --retries=12 \
  CMD curl --silent --fail localhost:9200/_cluster/health || exit 1
In docker compose

docker compose 2.1版本之后才支持health check

healthcheck:
  test: ["CMD", "curl", "-f", "http://localhost"]
  interval: 1m30s
  timeout: 10s
  retries: 3
  start_period: 40s
  • test: 定義了health check的指令骗污,只能是string或者一個(gè)list。如果是list沈条,第一個(gè)參數(shù)只能是NONE, CMD or CMD-SHELL
healthcheck:
  test: curl -f https://localhost || exit 1
  interval: 1m30s
  timeout: 10s
  retries: 3
  start_period: 40s

可以使用如下指令disable掉image的healthcheck

healthcheck:
  disable: true
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末需忿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蜡歹,更是在濱河造成了極大的恐慌屋厘,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件月而,死亡現(xiàn)場(chǎng)離奇詭異汗洒,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)父款,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門溢谤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人憨攒,你說(shuō)我怎么就攤上這事世杀。” “怎么了肝集?”我有些...
    開(kāi)封第一講書人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵瞻坝,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我杏瞻,道長(zhǎng)所刀,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任伐憾,我火速辦了婚禮勉痴,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘树肃。我一直安慰自己蒸矛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布胸嘴。 她就那樣靜靜地躺著雏掠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪劣像。 梳的紋絲不亂的頭發(fā)上乡话,一...
    開(kāi)封第一講書人閱讀 51,488評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音耳奕,去河邊找鬼绑青。 笑死诬像,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的闸婴。 我是一名探鬼主播坏挠,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼邪乍!你這毒婦竟也來(lái)了降狠?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤庇楞,失蹤者是張志新(化名)和其女友劉穎榜配,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體吕晌,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蛋褥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了聂使。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片壁拉。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖柏靶,靈堂內(nèi)的尸體忽然破棺而出弃理,到底是詐尸還是另有隱情,我是刑警寧澤屎蜓,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布痘昌,位于F島的核電站,受9級(jí)特大地震影響炬转,放射性物質(zhì)發(fā)生泄漏辆苔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一扼劈、第九天 我趴在偏房一處隱蔽的房頂上張望驻啤。 院中可真熱鬧,春花似錦荐吵、人聲如沸骑冗。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)贼涩。三九已至,卻和暖如春薯蝎,著一層夾襖步出監(jiān)牢的瞬間遥倦,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工占锯, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留袒哥,地道東北人缩筛。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像统诺,于是被迫代替她去往敵國(guó)和親歪脏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子疑俭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Docker Swarm Mode Docker v1.12 是一個(gè)非常重要的版本钞艇,Docker 重新實(shí)現(xiàn)了集群的...
    陽(yáng)一yayi閱讀 2,278評(píng)論 0 13
  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi閱讀 7,331評(píng)論 0 10
  • 一啄寡、Docker創(chuàng)建鏡像的方式有兩種: 一種通過(guò)commit的方式:把做了一系列操作的容器關(guān)閉,然后利用docke...
    jie0112閱讀 3,831評(píng)論 0 3
  • 今天是我第一次登錄簡(jiǎn)書哩照,也是我第一次在簡(jiǎn)書上寫字挺物,我很開(kāi)心能在一個(gè)角落里發(fā)現(xiàn)了簡(jiǎn)書這個(gè)軟件,它很好飘弧,我能在...
    劯暉閱讀 193評(píng)論 0 0
  • 偶然看過(guò)的一部電影次伶,竟令我感慨萬(wàn)千痴昧,久久難忘。心中感動(dòng)的潮水一次次涌起冠王,迫使我拿起筆赶撰,急切地想分享一下我的感受。 ...
    蕓窗月影閱讀 1,546評(píng)論 15 21