1. 程式人生 > >.net core i上 K8S(四).netcore程式的pod管理,重啟策略與健康檢查

.net core i上 K8S(四).netcore程式的pod管理,重啟策略與健康檢查

.net core i上 K8S(四).netcore程式的pod管理,重啟策略與健康檢查

 

目錄

回到頂部

1.pod管理

1.1建立pod

kubectl create -f netcore-pod.yaml

我們建立一個netcore-pod.yaml檔案,內容如下:

 

apiVersion: v1
kind: Pod          #指明型別
metadata: 
  name: netcore-pod
  labels:
    app: netcorepod
spec:
  containers:
  - name: netcorepod
    image: chenyishi/webdocker_s_provider
    ports:
    - containerPort: 1000
    env:
    - name: serverport
      value: "1000"

 

1.2檢視pod是否建立成功

1.3檢視pod描述

1.4替換pod

先修改netcore-pod.yaml,name改成netcorepod1

再執行替換命令

kubectl replace -f netcore-pod.yaml --force

我們可以看到,是先刪除舊的,再替換的。

1.5刪除pod

 kubectl delete -f netcore-pod.yaml

回到頂部

2.重啟策略

k8s有三種重啟策略Always(總是重啟,預設),OnFailue(錯誤時重啟),Never(從不),下面我們來修改netcore-pod.yaml配置

 

apiVersion: v1
kind: Pod
metadata: 
  name: netcore-pod
  labels:
    app: netcorepod
spec:
  containers:
  - name: netcorepod
    image: chenyishi/webdocker_s_provider
    ports:
    - containerPort: 1000
    env:
    - name: serverport
      value: "1000"
  restartPolicy: OnFailure      #策略

 

然後create

kubectl create -f netcore-pod.yaml  

我們手動製造一個異常,去Node節點查詢並kill掉程序dotnet

kill -9 82043

然後回到master節點,檢視pod資訊

我們可以看到重啟次數已經從0變成1了,說明我門的重啟策略發揮作用了,大家可以多kill幾次,這個數字會遞增。另外兩種策略大家也可以試一下

回到頂部

3.健康檢查

k8s為我們提供了對pod的健康檢查,我們可以檢視一下支援哪些

這裡我們使用httpGet測試一下,修改配置如下

我們使用一個存在的介面/api/values/1測試,建立pod,並檢視資訊

策略已生效,我們重新修改一下,改成一個不存在的介面

然後replace掉舊的

然後檢視資訊

我們發現已經出發了健康檢查策略,在不停重啟,restart count再增加,Events事件資訊也在增加。

回到頂部

4.進入容器

kubectl exec pod/netcore-pod -it bash

 

至此,我們.netcore程式的pod管理,重啟策略與健康檢查分享完了。