Kubernetes中钩子函数详解、实例

云计算 云原生
kubernetes在主容器的启动之后和停止之前提供了两个钩子函数,post start:容器创建之后执行,如果失败了会重启容器,pre stop :容器终止之前执行,执行完成之后容器将成功终止,在其完成之前会阻塞删除容器的操作。

1、概述

钩子函数能够感知自身生命周期中的事件,并在相应的时刻到来时运行用户指定的程序代码。

kubernetes在主容器的启动之后和停止之前提供了两个钩子函数:

  • post start:容器创建之后执行,如果失败了会重启容器。
  • pre stop :容器终止之前执行,执行完成之后容器将成功终止,在其完成之前会阻塞删除容器的操作。

钩子处理器支持使用下面三种方式定义动作:

  • Exec命令:在容器内执行一次命令。
……
  lifecycle:
    postStart: 
      exec:
        command:
        - cat
        - /tmp/healthy
……
  • TCPSocket:在当前容器尝试访问指定的socket。
……      
  lifecycle:
    postStart:
      tcpSocket:
        port: 8080
……

  • HTTPGet:在当前容器中向某url发起http请求
……
  lifecycle:
    postStart:
      httpGet:
        path: / #URI地址
        port: 80 #端口号
        host: 192.168.5.3 #主机地址
        scheme: HTTP #支持的协议,http或者https
……

2、以exec方式为例,演示钩子函数的使用

创建pod-hook-exec.yaml文件,内容如下:

apiVersion: v1
kind: Pod
metadata:
  name: pod-hook-exec
  namespace: dev
spec:
  containers:
  - name: main-container
    image: nginx
    ports:
    - name: nginx-port
      containerPort: 80
    lifecycle:
      postStart: 
        exec: # 在容器启动的时候执行一个命令,修改掉nginx的默认首页内容
          command: ["/bin/sh", "-c", "echo postStart... > /usr/share/nginx/html/index.html"]
      preStop:
        exec: # 在容器停止之前停止nginx服务
          command: ["/usr/sbin/nginx","-s","quit"]

# 创建pod
[root@k8s-master01 ~]# kubectl create -f pod-hook-exec.yaml
pod/pod-hook-exec created

# 查看pod
[root@k8s-master01 ~]# kubectl get pods  pod-hook-exec -n dev -o wide
NAME           READY   STATUS     RESTARTS   AGE    IP               NODE    
pod-hook-exec  1/1     Running    0          29s    172.17.169.187   k8s-node2 

# 访问pod
[root@k8s-master01 ~]# curl 172.17.169.187
postStart...

效果:

3、总结

  • PostStart hook是在容器创建(created)之后立马被调用,并且PostStart跟容器的ENTRYPOINT是异步执行的,无法保证它们之间的顺序。
  • PreStop hook是容器处于Terminated状态时立马被调用(也就是说要是Job任务的话,执行完之后其状态为completed,所以不会触发PreStop的钩子),同时PreStop是同步阻塞的,PreStop执行完才会执行删除Pod的操作。
  • PostStart会阻塞容器成为Running状。
  • PreStop会阻塞容器的删除,但是过了terminationGracePeriodSeconds时间后,容器会被强制删除。
  • 如果PreStop或者PostStart失败的话, 容器会被杀死。
责任编辑:姜华 来源: 今日头条
相关推荐

2021-05-24 11:55:55

网络安全Windows钩子函数

2011-05-20 17:59:06

回调函数

2020-12-01 12:44:44

PythonHook钩子函数

2023-09-14 12:25:58

2023-06-14 08:49:22

PodKubernetes

2009-12-09 11:40:02

Linux防火墙

2023-12-25 15:40:55

React开发

2010-06-18 10:33:03

Linux Acces

2009-09-04 18:09:12

C# Main函数

2009-09-01 15:47:20

C#取整函数

2023-04-28 08:35:22

Vue 3Vue 2

2022-07-24 09:46:48

优雅停机代码

2010-09-08 14:03:41

SQL函数CONVERT

2017-01-13 15:45:05

Linuxfork函数详解

2010-09-09 11:12:49

SQL函数DATALENGTH

2010-09-06 14:58:42

SQL函数

2022-11-21 09:01:00

Swift并发结构

2021-11-30 08:19:43

Vue3 插件Vue应用

2009-07-09 15:05:45

Servlet实例

2010-09-10 13:24:45

SQL求和函数
点赞
收藏

51CTO技术栈公众号