From ba2dc02c77dc93a26d1202fff114ff3d3aa9286f Mon Sep 17 00:00:00 2001 From: Jinhua Tan <312841925@qq.com> Date: Thu, 6 Jun 2019 13:28:10 +0800 Subject: [PATCH] Translate docs/tasks/configure-pod-container/attach-handler-lifecycle-event in Chinese (#14605) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Add zh/docs/tasks/configure-pod-container/attach-handler-lifecycle-event.md Add zh/examples/pods/lifecycle-events.yaml Translate zh/includes/task-tutorial-prereqs.md to chinese * Apply suggestions from code review Thanks for tengqm's review Co-Authored-By: Qiming * Apply suggestions from code review Thanks for tengqm's help again Co-Authored-By: Qiming * Modify the order of text in markdown format * Unified translation into 处理函数 --- .../attach-handler-lifecycle-event.md | 174 ++++++++++++++++++ .../zh/examples/pods/lifecycle-events.yaml | 16 ++ content/zh/includes/task-tutorial-prereqs.md | 5 + 3 files changed, 195 insertions(+) create mode 100644 content/zh/docs/tasks/configure-pod-container/attach-handler-lifecycle-event.md create mode 100644 content/zh/examples/pods/lifecycle-events.yaml diff --git a/content/zh/docs/tasks/configure-pod-container/attach-handler-lifecycle-event.md b/content/zh/docs/tasks/configure-pod-container/attach-handler-lifecycle-event.md new file mode 100644 index 0000000000..746c123a3d --- /dev/null +++ b/content/zh/docs/tasks/configure-pod-container/attach-handler-lifecycle-event.md @@ -0,0 +1,174 @@ +--- +title: 为容器的生命周期事件设置处理函数 +content_template: templates/task +weight: 140 +--- + + +{{% capture overview %}} + + +这个页面将演示如何为容器的生命周期事件挂接处理函数。Kubernetes 支持 postStart 和 preStop 事件。 +当一个容器启动后,Kubernetes 将立即发送 postStart 事件;在容器被终结之前, +Kubernetes 将发送一个 preStop 事件。 + +{{% /capture %}} + + +{{% capture prerequisites %}} + +{{< include "task-tutorial-prereqs.md" >}} {{< version-check >}} + +{{% /capture %}} + + +{{% capture steps %}} + + +## 定义 postStart 和 preStop 处理函数 + + +在本练习中,你将创建一个包含一个容器的 Pod,该容器为 postStart 和 preStop 事件提供对应的处理函数。 + + +下面是对应 Pod 的配置文件 + +{{< codenew file="pods/lifecycle-events.yaml" >}} + + +在上述配置文件中,你可以看到 postStart 命令在容器的 `/usr/share` 目录下写入文件 `message`。 +命令 preStop 负责优雅地终止 nginx 服务。当因为失效而导致容器终止时,这一处理方式很有用。``` + + +创建 Pod: + + kubectl apply -f https://k8s.io/examples/pods/lifecycle-events.yaml + + +验证 Pod 中的容器已经运行: + + kubectl get pod lifecycle-demo + + +使用 shell 连接到你的 Pod 里的容器: + + kubectl exec -it lifecycle-demo -- /bin/bash + + +在 shell 中,验证 `postStart` 处理函数创建了 `message` 文件: + + root@lifecycle-demo:/# cat /usr/share/message + + +命令行输出的是 `postStart` 处理函数所写入的文本 + + Hello from the postStart handler + +{{% /capture %}} + + + +{{% capture discussion %}} + + +## 讨论 + + +Kubernetes 在容器创建后立即发送 postStart 事件。然而,postStart 处理函数的调用不保证早于容器的入口点(entrypoint) +的执行。postStart 处理函数与容器的代码是异步执行的,但 Kubernetes +的容器管理逻辑会一直阻塞等待 postStart 处理函数执行完毕。只有 postStart 处理函数执行完毕,容器的状态才会变成 +RUNNING。 + + +Kubernetes 在容器结束前立即发送 preStop 事件。除非 Pod 宽限期限超时,Kubernetes 的容器管理逻辑 +会一直阻塞等待 preStop 处理函数执行完毕。更多的相关细节,可以参阅 +[Pods 的结束](/docs/user-guide/pods/#termination-of-pods)。 + + +{{< note >}} +Kubernetes 只有在 Pod *结束(Terminated)* 的时候才会发送 preStop 事件,这意味着在 Pod *完成(Completed)* 时 +preStop 的事件处理逻辑不会被触发。这个限制在 +[issue #55087](https://github.com/kubernetes/kubernetes/issues/55807) 中被追踪。 +{{< /note >}} + +{{% /capture %}} + + +{{% capture whatsnext %}} + + +* 进一步了解[容器生命周期回调](/docs/concepts/containers/container-lifecycle-hooks/)。 +* 进一步了解[Pod 的生命周期](/docs/concepts/workloads/pods/pod-lifecycle/)。 + + + +### 参考 + +* [Lifecycle](/docs/reference/generated/kubernetes-api/{{< param "version" >}}/#lifecycle-v1-core) +* [Container](/docs/reference/generated/kubernetes-api/{{< param "version" >}}/#container-v1-core) +* 参阅 [PodSpec](/docs/reference/generated/kubernetes-api/{{< param "version" >}}/#podspec-v1-core) 中关于`terminationGracePeriodSeconds` 的部分 + +{{% /capture %}} + + diff --git a/content/zh/examples/pods/lifecycle-events.yaml b/content/zh/examples/pods/lifecycle-events.yaml new file mode 100644 index 0000000000..4b79d7289c --- /dev/null +++ b/content/zh/examples/pods/lifecycle-events.yaml @@ -0,0 +1,16 @@ +apiVersion: v1 +kind: Pod +metadata: + name: lifecycle-demo +spec: + containers: + - name: lifecycle-demo-container + image: nginx + 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"] + diff --git a/content/zh/includes/task-tutorial-prereqs.md b/content/zh/includes/task-tutorial-prereqs.md index 6f1407fe45..a9de9e7844 100644 --- a/content/zh/includes/task-tutorial-prereqs.md +++ b/content/zh/includes/task-tutorial-prereqs.md @@ -1,8 +1,13 @@ +你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 +如果你还没有集群,你可以通过 [Minikube](/docs/getting-started-guides/minikube) 构建一 +个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建: + * [Katacoda](https://www.katacoda.com/courses/kubernetes/playground) * [Play with Kubernetes](http://labs.play-with-k8s.com/)