網站首頁 編程語言 正文
一.系統環境
服務器版本 | docker軟件版本 | Kubernetes(k8s)集群版本 | CPU架構 |
---|---|---|---|
CentOS Linux release 7.4.1708 (Core) | Docker version 20.10.12 | v1.21.9 | x86_64 |
Kubernetes集群架構:k8scloude1作為master節點,k8scloude2,k8scloude3作為worker節點
服務器 | 操作系統版本 | CPU架構 | 進程 | 功能描述 |
---|---|---|---|---|
k8scloude1/192.168.110.130 | CentOS Linux release 7.4.1708 (Core) | x86_64 | docker,kube-apiserver,etcd,kube-scheduler,kube-controller-manager,kubelet,kube-proxy,coredns,calico | k8s master節點 |
k8scloude2/192.168.110.129 | CentOS Linux release 7.4.1708 (Core) | x86_64 | docker,kubelet,kube-proxy,calico | k8s worker節點 |
k8scloude3/192.168.110.128 | CentOS Linux release 7.4.1708 (Core) | x86_64 | docker,kubelet,kube-proxy,calico | k8s worker節點 |
二.前言
本文介紹pod hook(pod鉤子)和如何優雅的關閉nginx pod。
管理pod的前提是已經有一套可以正常運行的Kubernetes集群,關于Kubernetes(k8s)集群的安裝部署,可以查看博客《Centos7 安裝部署Kubernetes(k8s)集群》https://www.jb51.net/article/266741.htm
三.pod hook(pod鉤子)
為容器的生命周期事件設置處理函數,Kubernetes 支持 postStart 和 preStop 事件。 當一個容器啟動后,Kubernetes 將立即發送 postStart 事件;在容器被終結之前, Kubernetes 將發送一個 preStop 事件。容器可以為每個事件指定一個處理程序。
pod hook:目前pod3容器里運行的是nginx進程,在啟動容器的時候,除了主進程,還想啟動一個進程,怎么辦?這時候就需要使用pod hook(pod 鉤子),pod hook有兩個選項:
- postStart:容器啟動之后執行XXXX,和主進程是同時運行起來的,并沒有先后順序;
- preStop:在容器關閉之前執行XXXX
postStart例子:容器啟動之后執行"/bin/sh","-c","date >> /tmp/bb.txt",打印日期到/tmp/bb.txt文件
[root@k8scloude1 pod]# vim pod3.yaml [root@k8scloude1 pod]# cat pod3.yaml apiVersion: v1 kind: Pod metadata: creationTimestamp: null labels: run: pod3 name: pod3 spec: terminationGracePeriodSeconds: 0 containers: - image: nginx command: ["sh","-c","date > /tmp/aa.txt ; sleep 10000"] imagePullPolicy: IfNotPresent name: n1 resources: {} lifecycle: postStart: exec: command: ["/bin/sh","-c","date >> /tmp/bb.txt"] dnsPolicy: ClusterFirst restartPolicy: Always status: {} [root@k8scloude1 pod]# kubectl apply -f pod3.yaml pod/pod3 created [root@k8scloude1 pod]# kubectl get pods NAME READY STATUS RESTARTS AGE pod3 1/1 Running 0 8s
查看文件可以發現,/tmp/aa.txt /tmp/bb.txt 時間是一致的,就說明兩個命令是同時運行的,證明了postStart:容器啟動之后執行XXXX,和主進程是同時運行起來的,并沒有先后順序。
[root@k8scloude1 pod]# kubectl exec -it pod3 -- bash root@pod3:/# cat /tmp/aa.txt /tmp/bb.txt Thu Jan 13 07:40:24 UTC 2022 Thu Jan 13 07:40:24 UTC 2022 root@pod3:/# exit exit #刪除pod [root@k8scloude1 pod]# kubectl delete -f pod3.yaml pod "pod3" deleted
現在添加preStop處理函數:在容器關閉之前執行"/bin/sh","-c","date >> /tmp/bb.txt ; sleep 100",打印日期到/tmp/bb.txt文件,并休眠100秒。
[root@k8scloude1 pod]# vim pod4.yaml [root@k8scloude1 pod]# cat pod4.yaml apiVersion: v1 kind: Pod metadata: creationTimestamp: null labels: run: pod3 name: pod3 spec: terminationGracePeriodSeconds: 600 containers: - image: nginx command: ["sh","-c","date > /tmp/aa.txt ; sleep 10000"] imagePullPolicy: IfNotPresent name: n1 resources: {} lifecycle: postStart: exec: command: ["/bin/sh","-c","date >> /tmp/bb.txt"] preStop: exec: command: ["/bin/sh","-c","date >> /tmp/bb.txt ; sleep 100"] dnsPolicy: ClusterFirst restartPolicy: Always status: {} [root@k8scloude1 pod]# kubectl apply -f pod4.yaml pod/pod3 created [root@k8scloude1 pod]# kubectl get pod NAME READY STATUS RESTARTS AGE pod3 1/1 Running 0 7s
運行一段時間后,刪除pod,在容器關閉之前執行preStop的命令,preStop執行完成之后,主程序還要運行10000秒,但是寬限期terminationGracePeriodSeconds只有600s,所以600秒之后pod被刪除
[root@k8scloude1 pod]# kubectl delete pod pod3 pod "pod3" deleted ^C #強制刪除pod [root@k8scloude1 pod]# kubectl delete pod pod3 --force warning: Immediate deletion does not wait for confirmation that the running resource has been terminated. The resource may continue to run on the cluster indefinitely. pod "pod3" force deleted
四.如何優雅的關閉nginx pod
說明: 當一個 Pod 被刪除時,執行kubectl get pod?
命令會展示這個 Pod 的狀態為 Terminating(終止)。 這個 Terminating 狀態并不是 Pod 階段之一。 Pod 被賦予一個可以體面終止的期限,默認為 30 秒。 你可以使用 --force 參數來強制終止 Pod。
由于nginx默認是fast shutdown,關閉的時間一般小于30秒,如果想優雅的關閉nginx,可以在關閉容器之前運行nginx -s quit ,達到優雅的關閉nginx的效果
[root@k8scloude1 pod]# vim pod5.yaml #preStop處理函數指定在容器關閉之前執行"/bin/sh","-c","/usr/sbin/nginx -s quit" [root@k8scloude1 pod]# cat pod5.yaml apiVersion: v1 kind: Pod metadata: creationTimestamp: null labels: run: pod5 name: pod5 spec: terminationGracePeriodSeconds: 600 containers: - image: nginx command: ["sh","-c","date > /tmp/aa.txt ; sleep 10000"] imagePullPolicy: IfNotPresent name: n1 resources: {} lifecycle: postStart: exec: command: ["/bin/sh","-c","date >> /tmp/bb.txt"] preStop: exec: command: ["/bin/sh","-c","/usr/sbin/nginx -s quit"] dnsPolicy: ClusterFirst restartPolicy: Always status: {} [root@k8scloude1 pod]# kubectl apply -f pod5.yaml pod/pod5 created [root@k8scloude1 pod]# kubectl get pod NAME READY STATUS RESTARTS AGE pod5 1/1 Running 0 5s [root@k8scloude1 pod]# kubectl delete pod pod5 pod "pod5" deleted ^C [root@k8scloude1 pod]# kubectl delete pod pod5 --force warning: Immediate deletion does not wait for confirmation that the running resource has been terminated. The resource may continue to run on the cluster indefinitely. pod "pod5" force deleted
原文鏈接:https://www.cnblogs.com/renshengdezheli/p/16850563.html
相關推薦
- 2022-10-23 Go語言數據結構之插入排序示例詳解_Golang
- 2022-02-26 輸入ip地址,輸入框超過三位直接跳到下一個
- 2022-07-04 Python中字典的緩存池_python
- 2022-07-04 解決Python保存文件名太長OSError:?[Errno?36]?File?name?too?l
- 2022-09-27 OpenCV中findContours函數參數詳解_C 語言
- 2022-06-28 python神經網絡學習使用Keras進行回歸運算_python
- 2023-05-23 pytorch中backward()方法如何自動求梯度_python
- 2022-10-14 Android適配器和適配器視圖
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支