-
Notifications
You must be signed in to change notification settings - Fork 8
20180319_docker healthcheck in golang
CI edited this page Jun 25, 2018
·
3 revisions
title: "Go 語言搭配 Docker Healthy Check 檢查" date: 2018-03-19 type: blog author: AppleBoy link: https://blog.wu-boy.com/2018/03/docker-healthcheck-in-golang/ layout: post comments: true
在 Docker 1.12 版本後,提供了 HEALTHCHECK
指令,通過指定的一行命令來判斷容器內的服務是否正常運作。在此之前大部分都是透過判斷程式是否 Crash 來決定容器是否存活,但是這地方有點風險的是,假設服務並非 crash,而是沒辦法退出容器,造成無法接受新的請求,這就確保容器存活。現在呢我們可以透過在 Dockerfile
內指定 HEALTHCHECK
指令來確保服務是否正常。而用 Go 語言開發的 Web 服務該如何來實現呢?
透過簡單的路由 /healthz
直接回傳 200 status code 即可 (使用 Gin 當例子)。
func heartbeatHandler(c *gin.Context) { c.AbortWithStatus(http.StatusOK) }
透過瀏覽器 http://localhost:8080/healthz
可以得到空白網頁,但是打開 console 可以看到正確回傳值。
透過 net/http
套件可以快速寫個驗證接口的函式
func pinger() error { resp, err := http.Get("http://localhost:8080/healthz") if err != nil { return err } defer resp.Body.Close() if resp.StatusCode != 200 { return fmt.Errorf("server returned non-200 status code") } return nil }
在 Dockerfile
內增加底下內容:
HEALTHCHECK --start-period=2s --interval=10s --timeout=5s \ CMD ["/bin/gorush", "--ping"]
- –start-period: 容器啟動後需要等待幾秒,預設為 0 秒
- –interval: 偵測間隔時間,預設為 30 秒
- –timeout: 檢查超時時間
重新編譯容器,並且啟動容器,會看到初始狀態為 (health: starting)
經過 10 秒後,就會執行指定的指令,就可以知道容器健康與否,最後狀態為 (healtyy)
。
最後可以透過 docker inspect
指令來知道容器的狀態列表 (JSON 格式)
$ docker inspect --format '{{json .State.Health}}' gorush | jq
從上圖可以知道每隔 10 秒 Docker 就會自動偵測一次。有了上述這些資料,就可以來寫系統報警通知了。如果對 Go 語言有興趣,可以參考線上課程。
-
Gorush 輕量級手機訊息發送服務 (1)
-
用 Docker 發送 Line 訊息 (5)
-
Drone 搭配 Kubernetes 部署 Go 語言項目 (0)
-
用 Kubernetes 將 Drone CI/CD 架設在 AWS (0)
-
Drone CI Server 搭配 Atlassian Bitbucket Server (前身 Stash) (1)
-
Cronjob 搭配 Drone 服務 (1)
-
2017 COSCUP 研討會: Gitea + Drone 介紹 (4)
-
部署 Go 語言 App 到 Now.sh (0)
-
台灣第一屆 GoPher 大會 (1)
-
為什麼我用 Drone 取代 Jenkins 及 GitLab CI (10)