K8S中POD的生命周期之钩子函数

钩子函数

  • Kubernetes 中的容器生命周期钩子(lifecycle hooks)些钩子允许开发者在容器的生命周期中的特定时刻执行自定义操作。kubernetes在主容器的启动之后和停止之前提供了两个钩子函数:

    • Post Start Hook

      • 这个钩子在容器创建并成功运行之后立即执行。它可以用来执行容器启动后需要立即进行的任务,比如发送信号给其他服务,或者执行某些初始化逻辑。

      • 如果 Post Start 钩子失败,即执行的命令返回非零退出码,Kubernetes 会认为容器启动失败,并根据容器的重启策略决定是否重启容器。

    • Pre Stop Hook

      • 这个钩子在容器即将终止之前执行。它通常用于执行清理工作,如保存状态、优雅地关闭服务、释放资源等。

      • Pre Stop 钩子提供了一种优雅关闭容器的方式。如果容器在 Pre Stop 钩子执行期间没有停止,Kubernetes 将等待一段时间(默认为 30 秒)之后,发送 SIGKILL 信号强制终止容器。

Kubernetes 中容器生命周期钩子处理器支持的三种动作类型:ExecTCPSocketHTTPGet

  • Exec 命令

    • 这个动作类型允许在容器内执行一个命令行命令。

    • 如果命令执行成功(退出状态码为0),钩子继续执行;如果失败(非零退出状态码),则容器将被重启。

bash 复制代码
lifecycle:
  postStart:
    exec:
      command: ["cat", "/tmp/healthy"]

TCPSocket

  • 这个动作类型尝试在容器内访问指定的 TCP 端口。

  • 如果能够建立连接,则钩子动作成功;否则,容器将被重启。

bash 复制代码
lifecycle:
  postStart:
    tcpSocket:
      port: 8080

HTTPGet

  • 这个动作类型在容器内向指定的 URL 发起 HTTP GET 请求。

  • 如果请求成功(HTTP 状态码为 200-399),钩子动作成功;如果失败,则容器将被重启。

bash 复制代码
lifecycle:
  postStart:
    httpGet:
      path: /healthz  # URI地址
      port: 80        # 端口号
      host: 192.168.110.100  # 主机地址
      scheme: HTTP    # 支持的协议,可以是 HTTP 或 HTTPS
钩子函数使用实例(Exec为例)
bash 复制代码
[root@K8s-master-01 ~]# vim pod-hook-exec.yaml
---
apiVersion: v1
kind: Pod
metadata:
  name: pod-hook-exec
  namespace: test
spec:
  containers:
  - name: main-container
    image: nginx:1.17.1
    ports:
    - name: nginx-port
      containerPort: 80
    lifecycle:
      postStart:
        exec:
          command: ["/bin/bash", "-c", "echo 'postStart...' > /usr/share/nginx/html/index.html"]
      preStop:
        exec:
          command: ["/usr/sbin/nginx", "-s", "quit"]

-- 容器 (`main-container`):
  - 使用 `nginx:1.17.1` 镜像。
  - 暴露端口 80,命名为 `nginx-port`。
-- 生命周期钩子 (`lifecycle`):
  - 这个字段包含两个钩子:`postStart` 和 `preStop`。
-- Post Start 钩子:
  - 这个钩子在容器创建并启动之后立即执行。
  - 通过 `exec` 动作执行命令:使用 `/bin/bash -c` 执行一个 shell 命令,该命令输出字符串 `'postStart...'` 到 Nginx 的网页根目录下的 `    	  index.html` 文件。这将修改 Nginx 服务器的默认首页内容。
-- Pre Stop 钩子:
  - 这个钩子在容器被停止之前执行。
  - 同样使用 `exec` 动作执行命令:发送 `nginx -s quit` 命令给 Nginx 服务器以优雅地关闭服务。这允许 Nginx 完成当前的请求并关闭监听的套接字,     而不是被强制终止。

测试:

bash 复制代码
[root@k8s-master ~]# kubectl create ns test
namespace/test created
[root@k8s-master ~]# kubectl apply -f pod-hook-exec.yaml 
pod/pod-hook-exec created

[root@k8s-master ~]# kubectl get pods  -n test
NAME            READY   STATUS              RESTARTS   AGE
pod-hook-exec   0/1     ContainerCreating   0          16s
[root@k8s-master ~]# kubectl get pods  -n test -w
NAME            READY   STATUS              RESTARTS   AGE
pod-hook-exec   0/1     ContainerCreating   0          20s
pod-hook-exec   1/1     Running             0          30s
^C[root@k8s-master ~]# kubectl get pods  -n test -o wide
NAME            READY   STATUS    RESTARTS   AGE   IP               NODE        NOMINATED NODE   READINESS GATES
pod-hook-exec   1/1     Running   0          40s   10.244.169.129   k8s-node2   <none>           <none>
[root@k8s-master ~]# curl 10.244.169.129:80
postStart...
相关推荐
9命怪猫7 小时前
[K8S小白问题集] - Calico好在哪里?
网络·云原生·容器·kubernetes
齐潇宇7 小时前
k8s-Helm管理器
linux·运维·云原生·容器·kubernetes
容器魔方7 小时前
让Skill从执行中生长:Cloud Agent Harness的三段式Skill自进化机制
云原生·开源·资讯
叶~小兮7 小时前
K8S进阶核心综合学习笔记(持久化存储+特殊容器+调度管理)
笔记·学习·kubernetes
Zhu7588 小时前
[软件部署]在k8s环境部署alist
云原生·容器·kubernetes
2401_840192279 小时前
k8s的crd、operator、cr分别是什么?
运维·分布式·kubernetes·prometheus
Cat_Rocky10 小时前
K8S-Helm简单学习分享
学习·容器·kubernetes
ziqi52211 小时前
Docker compose 和共享数据
运维·docker·容器
安当加密12 小时前
AES-256直接加密就够了?微服务架构下的敏感数据加密:信封加密、格式保留加密和字段级加密全解析
微服务·云原生·架构