容器生命周期

绝大多数高级程序编程语言的框架(例如,Angular、Spring Framework、Vue 等)在组件的生命周期中提供 hook(钩子函数),Kubernetes 中,也为容器提供了对应的生命周期钩子函数,使得容器可以获知其所在运行环境对其进行管理的生命周期事件,以便容器可以响应该事件,并执行对应的代码。
容器钩子
Kubernetes中为容器提供了两个 hook(钩子函数):
PostStart
此钩子函数在容器创建后将立刻执行。但是,并不能保证该钩子函数在容器的 ENTRYPOINT 之前执行。该钩子函数没有输入参数。
PreStop
此钩子函数在容器被 terminate(终止)之前执行,例如:
通过接口调用删除容器所在 Pod
某些管理事件的发生:健康检查失败、资源紧缺等
如果容器已经被关闭或者进入了 completed 状态,preStop 钩子函数的调用将失败。该函数的执行是同步的即,kubernetes 将在该函数完成执行之后才删除容器。该钩子函数没有输入参数。
容器生命周期事件处理
定义postStart和preStop处理程序
创建一个yaml文件

vi nginx-demo.yaml
apiVersion: v1
kind: Pod
metadata:
  name: nginx-demo
spec:
  containers:
  - name: nginx-demo
    image: nginx:1.10
    lifecycle:
      postStart:
        exec:
          command: ["/bin/sh", "-c", "echo Hello from the postStart handler > /usr/share/message"]
      preStop:
        exec:
          command: ["/bin/sh","-c","nginx -s quit; while killall -0 nginx; do sleep 1; done"]

执行应用:

kubectl apply -f nginx-demo.yaml

进入应用:

kubectl exec -it nginx-demo -- /bin/bash
cat /usr/share/message 
Hello from the postStart handler

你可能感兴趣的:(kubernetes)