五 pod钩子 pod:pod hook和优雅的关闭nginx pod

目录

  • 一.系统环境
  • 二.前言
  • 三.pod hook(pod钩子)
  • 四.如何优雅的关闭nginx pod
一.系统环境服务器版本docker软件版本Kubernetes(k8s)集群版本CPU架构CentOS Linux release 7.4.1708 (Core)Docker version 20.10.12v1.21.9x86_64Kubernetes集群架构:k8scloude1作为master节点,k8scloude2,k8scloude3作为worker节点
服务器操作系统版本CPU架构进程功能描述k8scloude1/192.168.110.130CentOS Linux release 7.4.1708 (Core)x86_64docker,kube-apiserver,etcd,kube-scheduler,kube-controller-manager,kubelet,kube-proxy,coredns,calicok8s master节点k8scloude2/192.168.110.129CentOS Linux release 7.4.1708 (Core)x86_64docker,kubelet,kube-proxy,calicok8s worker节点k8scloude3/192.168.110.128CentOS Linux release 7.4.1708 (Core)x86_64docker,kubelet,kube-proxy,calicok8s worker节点二.前言本文介绍pod hook(pod钩子)和如何优雅的关闭nginx pod 。
管理pod的前提是已经有一套可以正常运行的Kubernetes集群,关于Kubernetes(k8s)集群的安装部署,可以查看博客《Centos7 安装部署Kubernetes(k8s)集群》https://www.cnblogs.com/renshengdezheli/p/16686769.html
三.pod hook(pod钩子)【五 pod钩子 pod:pod hook和优雅的关闭nginx 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.yamlapiVersion: v1kind: Podmetadata:creationTimestamp: nulllabels:run: pod3name: pod3spec:terminationGracePeriodSeconds: 0containers:- image: nginxcommand: ["sh","-c","date > /tmp/aa.txt ; sleep 10000"]imagePullPolicy: IfNotPresentname: n1resources: {}lifecycle:postStart:exec:command: ["/bin/sh","-c","date >> /tmp/bb.txt"]dnsPolicy: ClusterFirstrestartPolicy: Alwaysstatus: {}[root@k8scloude1 pod]# kubectl apply -f pod3.yamlpod/pod3 created[root@k8scloude1 pod]# kubectl get podsNAMEREADYSTATUSRESTARTSAGEpod31/1Running08s查看文件可以发现,/tmp/aa.txt /tmp/bb.txt 时间是一致的,就说明两个命令是同时运行的,证明了postStart:容器启动之后执行XXXX,和主进程是同时运行起来的,并没有先后顺序 。
[root@k8scloude1 pod]# kubectl exec -it pod3 -- bashroot@pod3:/# cat /tmp/aa.txt /tmp/bb.txtThu Jan 13 07:40:24 UTC 2022Thu Jan 13 07:40:24 UTC 2022root@pod3:/# exitexit#删除pod[root@k8scloude1 pod]# kubectl delete -f pod3.yamlpod "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.yamlapiVersion: v1kind: Podmetadata:creationTimestamp: nulllabels:run: pod3name: pod3spec:terminationGracePeriodSeconds: 600containers:- image: nginxcommand: ["sh","-c","date > /tmp/aa.txt ; sleep 10000"]imagePullPolicy: IfNotPresentname: n1resources: {}lifecycle:postStart:exec:command: ["/bin/sh","-c","date >> /tmp/bb.txt"]preStop:exec:command: ["/bin/sh","-c","date >> /tmp/bb.txt ; sleep 100"]dnsPolicy: ClusterFirstrestartPolicy: Alwaysstatus: {}[root@k8scloude1 pod]# kubectl apply -f pod4.yamlpod/pod3 created[root@k8scloude1 pod]# kubectl get podNAMEREADYSTATUSRESTARTSAGEpod31/1Running07s

经验总结扩展阅读