.net core i上 K8S(四).netcore程序的pod管理,重啟策略與健康檢查
阿新 • • 發佈:2018-12-13
進入容器 get ace ner 默認 ast policy dock bsp
上一章我們已經通過yaml文件將.netcore程序跑起來了,但還有一下細節問題可以分享給大家。
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: 1000env: - 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管理,重啟策略與健康檢查分享完了。
.net core i上 K8S(四).netcore程序的pod管理,重啟策略與健康檢查