本页面展示了如何将容器生命周期事件绑定到处理程序上。Kubernetes 支持 postStart 和 preStop 事件。Kubernetes 在启动容器之后会立即发送 postStart 事件 ,在容器终止之前会立即发送 preStop 事件。
您必须拥有一个 Kubernetes 集群,并且必须使用 kubectl 命令行工具与你的集群进行通信。如果您还没有一个集群,您可以通过 Minikube 创建一个集群,或者使用这些 Kubernetes playground :
To check the version, enter kubectl version
.
在本练习中,您将创建一个具有一个容器的 Pod。该容器包含用于处理 postStart 和 preStop 事件的程序。
这是 Pod 的配置文件:
pods/lifecycle-events.yaml
|
---|
|
在配置文件中,您可以看到 postStart 命令写入 message
文件到容器的的 /usr/share
目录。preStop 命令优雅地关闭了 nginx 。如果容器因故障而终止,这就会非常有用。
创建 Pod:
kubectl create -f https://k8s.io/examples/pods/lifecycle-events.yaml
验证 Pod 里的容器处于运行状态:
kubectl get pod lifecycle-demo
获取一个访问 Pod 中运行容器的 shell:
kubectl exec -it lifecycle-demo -- /bin/bash
在 shell 中,验证 postStart
处理程序是否创建了 message
文件:
root@lifecycle-demo:/# cat /usr/share/message
输出显示 postStart 处理程序写入的文本:
Hello from the postStart handler
Kubernetes 在创建容器后立即发送 postStart 事件。但是,不能保证 postStart 处理程序 在容器的 entrypoint 调用之前被调用。相对于容器的代码,postStart 处理程序以异步方式运行,但 Kubernetes 对容器的管理 会阻塞直到 postStart 处理程序完成。容器的状态直到 postStart 处理程序完成后才会设置为 RUNNING 。
Kubernetes 在容器终止之前立即发送 preStop 事件。 Kubernetes 对容器的管理一直阻塞直到 preStop 处理程序完成, 除非 Pod 的宽限期过期。有关详细信息,请参阅 Pods 的终止 。
Note:Kubernetes 仅在 Pod 是 terminated 时发送 preStop 事件。这意味着当 Pod 是 completed 状态时,preStop 钩子程序不会被触发。 这个限制被记录在 issue #55087 中。
此页是否对您有帮助?
Thanks for the feedback. If you have a specific, answerable question about how to use Kubernetes, ask it on Stack Overflow. Open an issue in the GitHub repo if you want to report a problem or suggest an improvement.