成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Docker容器原生健康檢查機(jī)制詳解

云計(jì)算 云原生
本文介紹Docker中兩種原生的健康檢查方式,使用起來非常方便。目前主流的容器編排框架也都自帶了健康健康檢查功能,這種情況下不需要使用Docker原生的健康檢查方式。

為什么需要健康檢查機(jī)制?

健康檢查機(jī)制是用來檢查服務(wù)的可用性,當(dāng)服務(wù)不可用時(shí)及時(shí)重啟以恢復(fù)可用性。之前的文章《Kubernetes中配置livenessProbe、readinessProbe和startupProbe》講解了Kubernetes中的各種健康檢查類型和配置方法,本篇文章講解一下docker容器的健康檢查機(jī)制。

看過上文提到的那篇文章的同學(xué)型相信肯定能理解為什么需要對(duì)服務(wù)本身做健康檢查。就以docker為例再解釋一下,Docker Daemon用來運(yùn)行和管理容器,本身會(huì)監(jiān)控容器中PID為1的進(jìn)程,其實(shí)在實(shí)際場景中僅監(jiān)控PID為1的進(jìn)程是不夠的。例如當(dāng)容器中的服產(chǎn)生死鎖的情況,這時(shí)候服務(wù)雖然不能處理用戶請(qǐng)求,但是PID為1的進(jìn)程依然是運(yùn)行狀態(tài)。

Docker健康檢查機(jī)制

Docker健康檢查有兩種方式:

  • 在Dockerfile中使用HEALTHCHECK命令配置健康檢查策略;
  • 在啟動(dòng)容器時(shí)(docker run 命令)配置健康檢查策略。

在Dockerfile中使用HEALTHCHECK命令配置健康檢查策略

在Dockerfile中使用HEALTHCHECK聲明健康檢查策略,容器啟動(dòng)后就會(huì)自動(dòng)進(jìn)行健康檢查。HEALTHCHECK支持下列選項(xiàng):

  • --interval=<間隔時(shí)間>:兩次健康檢查的間隔時(shí)間,默認(rèn)30 秒;
  • --timeout=<超時(shí)時(shí)間>:健康檢查命令運(yùn)行超時(shí)時(shí)間,如果超過這個(gè)時(shí)間,本次健康檢查被視為失敗,默認(rèn) 30 秒;
  • --retries=<重試次數(shù)>:當(dāng)連續(xù)重試指定次數(shù)后,則將容器狀態(tài)置為 unhealthy,默認(rèn) 3 次。
  • --start-period=<間隔>: 應(yīng)用啟動(dòng)時(shí)間,不計(jì)啟動(dòng)過程中的健康檢查失效情況,默認(rèn) 0 秒。

使用示例如下:

from elasticsearch:latest
HEALTHCHECK --interval=5s --timeout=2s --retries=3 \
CMD curl --silent --fail localhost:9200/_cluster/health || exit 1

在Dockerfile中HEALTHCHECK最好只寫一個(gè),如果寫了多個(gè),只有最后一個(gè)會(huì)有效。

CMD命令返回值有三種,如下

  • 0,成功;
  • 1,失敗;
  • 2,保留值,不要使用。

執(zhí)行docker run后容器初始狀態(tài)為starting,等待配置的interval時(shí)間后,開始執(zhí)行健康檢查。如果單次檢查返回值不是0或者檢查時(shí)間超過了timeout,本次檢查被認(rèn)為失敗。如果健康檢查連續(xù)失敗次數(shù)超過了retries,狀態(tài)就會(huì)變?yōu)閡nhealthy,健康檢查結(jié)果一旦成功,容器就會(huì)被置為healthy狀態(tài)。

在啟動(dòng)容器時(shí)(docker run 命令)配置健康檢查策略

示例如下:

$ docker run --rm -d \
     --name=es \
     --health-cmd="curl --silent --fail localhost:9200/_cluster/health || exit 1" \
     --health-interval=5s \
     --health-timeout=2s \
     --health-retries=3 \
     elasticsearch:latest

參數(shù)代表的意思和第一種方式中的相同,健康檢查命令的輸出存儲(chǔ)在健康狀態(tài)里,可以用docker inspect命令查看。

小結(jié)

本文介紹了Docker中兩種原生的健康檢查方式,使用起來非常方便。目前主流的容器編排框架也都自帶了健康健康檢查功能,這種情況下不需要使用Docker原生的健康檢查方式。

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2017-08-25 10:20:46

Docker容器機(jī)制

2023-03-02 07:20:10

GRPC服務(wù)健康檢查協(xié)議

2022-09-07 09:19:49

Docker健康檢查

2024-02-27 17:30:11

2020-12-07 06:29:13

SpringBoot

2023-03-03 08:19:35

KubernetesgRPC

2023-03-01 08:33:37

gRPC健康檢查代碼

2024-10-31 15:16:35

2021-07-15 10:25:15

集群節(jié)點(diǎn)檢查

2022-08-23 10:04:23

Dockerhealth健康檢查

2022-02-28 07:40:23

Nacos注冊(cè)中心客戶端

2023-10-14 15:36:14

PodKubernetes

2023-01-30 07:51:38

云原生Kubernetesk8s

2021-01-15 05:38:28

ASPHttp端口

2021-04-18 10:34:28

Spring Clou郵件釘釘

2021-09-18 16:10:48

Spring BootJava微服務(wù)

2021-07-05 06:51:41

Nacos微服務(wù)源碼

2021-09-21 16:31:56

Windows 11微軟PC健康檢查工具

2024-02-19 08:01:59

服務(wù)微服務(wù)授權(quán)

2022-12-27 07:42:12

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 无码一区二区三区视频 | 国产999精品久久久久久绿帽 | 国产农村妇女毛片精品久久麻豆 | 国产一区二区三区四区hd | 少妇性l交大片免费一 | 亚洲成av人片在线观看无码 | 亚洲视频第一页 | 一区二区三区在线免费看 | 毛片久久久 | 日韩在线播放一区 | 成人在线免费 | 一级做a爰片性色毛片16 | 久久精品在线 | 精品国产一区二区三区久久久久久 | 久久看看 | 美国一级片在线观看 | 在线观看视频一区二区三区 | 国产精品国产成人国产三级 | 日韩午夜精品 | 久久久久国产 | 精品免费av | 国产精品国产三级国产aⅴ中文 | 色综久久| 黄色片在线网站 | 久久精品99久久 | 国产精品亚洲综合 | 国产精品免费大片 | 欧美精品乱码久久久久久按摩 | 日韩欧美二区 | www.中文字幕.com | 97精品一区二区 | 91精品国产一区二区三区 | 91在线观看免费视频 | 国产美女在线免费观看 | 久久免费视频观看 | 精品9999| 国产精品久久久久久久7电影 | 国产黄色在线观看 | 免费在线观看一区二区 | 一本大道久久a久久精二百 欧洲一区二区三区 | 亚洲va中文字幕 |