Kubernetes中鉤子函數(shù)詳解、實(shí)例
作者:全棧行動(dòng)派
kubernetes在主容器的啟動(dòng)之后和停止之前提供了兩個(gè)鉤子函數(shù),post start:容器創(chuàng)建之后執(zhí)行,如果失敗了會(huì)重啟容器,pre stop :容器終止之前執(zhí)行,執(zhí)行完成之后容器將成功終止,在其完成之前會(huì)阻塞刪除容器的操作。
1、概述
鉤子函數(shù)能夠感知自身生命周期中的事件,并在相應(yīng)的時(shí)刻到來時(shí)運(yùn)行用戶指定的程序代碼。
kubernetes在主容器的啟動(dòng)之后和停止之前提供了兩個(gè)鉤子函數(shù):
- post start:容器創(chuàng)建之后執(zhí)行,如果失敗了會(huì)重啟容器。
- pre stop :容器終止之前執(zhí)行,執(zhí)行完成之后容器將成功終止,在其完成之前會(huì)阻塞刪除容器的操作。
鉤子處理器支持使用下面三種方式定義動(dòng)作:
- Exec命令:在容器內(nèi)執(zhí)行一次命令。
……
lifecycle:
postStart:
exec:
command:
- cat
- /tmp/healthy
……
- TCPSocket:在當(dāng)前容器嘗試訪問指定的socket。
……
lifecycle:
postStart:
tcpSocket:
port: 8080
……
- HTTPGet:在當(dāng)前容器中向某url發(fā)起http請(qǐng)求
……
lifecycle:
postStart:
httpGet:
path: / #URI地址
port: 80 #端口號(hào)
host: 192.168.5.3 #主機(jī)地址
scheme: HTTP #支持的協(xié)議,http或者h(yuǎn)ttps
……
2、以exec方式為例,演示鉤子函數(shù)的使用
創(chuàng)建pod-hook-exec.yaml文件,內(nèi)容如下:
apiVersion: v1
kind: Pod
metadata:
name: pod-hook-exec
namespace: dev
spec:
containers:
- name: main-container
image: nginx
ports:
- name: nginx-port
containerPort: 80
lifecycle:
postStart:
exec: # 在容器啟動(dòng)的時(shí)候執(zhí)行一個(gè)命令,修改掉nginx的默認(rèn)首頁內(nèi)容
command: ["/bin/sh", "-c", "echo postStart... > /usr/share/nginx/html/index.html"]
preStop:
exec: # 在容器停止之前停止nginx服務(wù)
command: ["/usr/sbin/nginx","-s","quit"]
# 創(chuàng)建pod
[root@k8s-master01 ~]# kubectl create -f pod-hook-exec.yaml
pod/pod-hook-exec created
# 查看pod
[root@k8s-master01 ~]# kubectl get pods pod-hook-exec -n dev -o wide
NAME READY STATUS RESTARTS AGE IP NODE
pod-hook-exec 1/1 Running 0 29s 172.17.169.187 k8s-node2
# 訪問pod
[root@k8s-master01 ~]# curl 172.17.169.187
postStart...
效果:
3、總結(jié)
- PostStart hook是在容器創(chuàng)建(created)之后立馬被調(diào)用,并且PostStart跟容器的ENTRYPOINT是異步執(zhí)行的,無法保證它們之間的順序。
- PreStop hook是容器處于Terminated狀態(tài)時(shí)立馬被調(diào)用(也就是說要是Job任務(wù)的話,執(zhí)行完之后其狀態(tài)為completed,所以不會(huì)觸發(fā)PreStop的鉤子),同時(shí)PreStop是同步阻塞的,PreStop執(zhí)行完才會(huì)執(zhí)行刪除Pod的操作。
- PostStart會(huì)阻塞容器成為Running狀。
- PreStop會(huì)阻塞容器的刪除,但是過了terminationGracePeriodSeconds時(shí)間后,容器會(huì)被強(qiáng)制刪除。
- 如果PreStop或者PostStart失敗的話, 容器會(huì)被殺死。
責(zé)任編輯:姜華
來源:
今日頭條