亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.430618.com 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

livenessProbe、readinessProbe和startupProbe作用

kubelet使用livenessProbe(存活探針)來判斷何時重啟容器。例如,當程序中產生死鎖的時候,程序還在運行,通過livenessProbe可以檢測到程序已不能正常提供服務。這種情況下重啟容器可以讓程序恢復可用的狀態(雖然程序中存在會導致死鎖的bug)。如果沒有配置livenessProbe,則默認狀態為Success。

kubelet使用readinessProbe(就緒探針)來判斷容器何時準備好了接受流量。當Pod中的所有容器都準備好時,Pod就被認為準備好了。最重要的用途是用來控制哪些pod被用作服務的后端。當一個Pod未準備好時,在負載均衡中會被移除。如果沒有配置readinessProbe,則默認狀態為Success。

Kube.NETes從1.17版本開始新增了startupProbe(啟動探針),kubelet使用startupProbe來判斷容器應用程序何時啟動。如果配置了startupProbe,等啟動成功后才會進行livenessProbe和readinessProbe。這樣可以避免應用程序在啟動過程被livenessProbe和readinessProbe影響。如果沒有配置startupProbe,則默認狀態為Success。

k8s中的四種健康檢查方式

livenessProbe、readinessProbe和startupProbe都可以稱為健康檢查,這幾種健康檢查類型都支持四種檢查方式:exec命令、httpGet、tcpSocket和grpc。其中exec命令行方式通用性最強,適用于大部分場景,tcpSocket方式適用于TCP類型的服務,httpGet方式適用于http類型的服務,grpc方式適用于grpc類型的服務。

  • exec:可以將自定義的健康檢查方法封裝成命令行(CLI)工具使用exec來執行,如果檢測結果是正常,命令行返回0值,否則返回非0值。
  • httpGet:通過容器的IP地址、端口及服務提供的http接口路徑,發起一個HTTP Get請求,如果響應的狀態碼大于等于200且小于400,則認為服務是健康的。
  • tcpSocket:通過容器的IP地址和端口,發起一個tcp請求,能建立連接則認為服務是健康的。
  • grpc:通過容器的IP地址和端口,發起一個grpc請求(前提是服務實現了grpc健康檢查協議),返回服務健康的結果正常則認為服務是健康的。

配置探針的常用可選參數如下:

參數名稱

默認值

最小值

描述

initialDelaySeconds

0秒

0秒

容器啟動后多久開始進行第一次探測。

periodSeconds

10秒

1秒

探測頻度,頻率過高會對pod帶來較大的額外開銷,頻率過低則無法及時反映容器真實情況。

timeoutSeconds

1秒

1秒

探測超時時間。

failureThreshold

3

1

處于成功狀態時,探測連續失敗幾次可被認為失敗。

successThreshold

1

1

處于失敗狀態時,探測連續成功幾次,被認為成功。

配置示例

livenessProbe、readinessProbe和startupProbe的配置方法基本類似,下面就以配置livenessProbe為例。

exec方式

apiVersion: v1
kind: Pod
metadata:
  labels:
    test: liveness
  name: liveness-exec
spec:
  containers:
  - name: liveness
    image: registry.k8s.io/busybox
    args:
    - /bin/sh
    - -c
    - touch /tmp/healthy; sleep 30; rm -f /tmp/healthy; sleep 600
    livenessProbe:
      exec:
        command:
        - cat
        - /tmp/healthy
      initialDelaySeconds: 5
      periodSeconds: 5

httpGet方式

apiVersion: v1
kind: Pod
metadata:
  labels:
    test: liveness
  name: liveness-http
spec:
  containers:
  - name: liveness
    image: registry.k8s.io/liveness
    args:
    - /server
    livenessProbe:
      httpGet:
        path: /healthz
        port: 8080
        httpHeaders:
        - name: Custom-Header
          value: Awesome
      initialDelaySeconds: 3
      periodSeconds: 3

tcpSocket方式

apiVersion: v1
kind: Pod
metadata:
  name: goproxy
  labels:
    App: goproxy
spec:
  containers:
  - name: goproxy
    image: registry.k8s.io/goproxy:0.1
    ports:
    - containerPort: 8080
    readinessProbe:
      tcpSocket:
        port: 8080
      initialDelaySeconds: 5
      periodSeconds: 10
    livenessProbe:
      tcpSocket:
        port: 8080
      initialDelaySeconds: 15
      periodSeconds: 20

grpc方式

apiVersion: v1
kind: Pod
metadata:
  name: etcd-with-grpc
spec:
  containers:
  - name: etcd
    image: registry.k8s.io/etcd:3.5.1-0
    command: [ "/usr/local/bin/etcd", "--data-dir",  "/var/lib/etcd", "--listen-client-urls", "http://0.0.0.0:2379", "--advertise-client-urls", "http://127.0.0.1:2379", "--log-level", "debug"]
    ports:
    - containerPort: 2379
    livenessProbe:
      grpc:
        port: 2379
      initialDelaySeconds: 10

更多關于健康檢查配置的說明可以參考kubernetes官方文檔:
https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/。

分享到:
標簽:Kubernetes
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定