k8s核心资源Pod-主容器之钩子函数

一、什么是钩子函数

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

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.19.1 #主机地址
      scheme: HTTP #支持的协议,http或者https
……

三、钩子函数的使用

接下来,以exec方式为例,演示下钩子函数的使用,创建pod-exec.yaml文件

复制代码
apiVersion: v1
kind: Pod
metadata:
  name: pod-hook-exec
  namespace: test
spec:
  containers:
  - name: main-container
    image: nginx:1.18
    ports:
    - name: nginx-port
      containerPort: 80
    lifecycle:
      postStart: 
        exec: #容器启动时执行修改nginx默认网页类容 
          command: ["/bin/sh", "-c", "echo helloworld > /usr/share/nginx/html/index.html"]
      preStop:
        exec:  #容器停止之前关闭nginx服务
          command: ["/usr/sbin/nginx","-s","quit"]

创建pod

复制代码
[root@master ~]# kubectl create -f pod-exec.yaml
pod/pod-hook-exec created
[root@master ~]# kubectl get pod -n test -o wide
NAME                READY   STATUS     RESTARTS   AGE
pod-hook-exec       1/1     Running    0          28s

访问pod

复制代码
[root@master ~]# curl http://10.244.1.14
helloworld
​
# 进入该pod
kubectl exec pod-hook-exec -n test -it -c main-container /bin/sh
​
# 进入目录,/usr/share/nginx/html
cd /usr/share/nginx/html
​
#查看index.html
cat index.html
相关推荐
Jooolin5 小时前
从 DeepSeek、Qwen 到 GPT:一次企业级 AI 知识库项目的模型选型复盘
人工智能·云原生·ai编程
皮皮蟹虾饺10 小时前
DNS协议指南:从报文格式到安全加密与 K8s 实战
安全·容器·kubernetes
阿里云云原生11 小时前
AI Agent 如何“驾驭”云监控?实测自然语言驱动的全链路可观测运维
云原生
千寻girling11 小时前
记录第一次学习 Docker
学习·docker·容器
迷糊小面包12 小时前
Docker Hadopp集群版部署搭建及常规问题解疑
运维·docker·容器
烁34713 小时前
Docker
运维·docker·容器
阿里云云原生14 小时前
拒绝月底“账单惊魂”:AI 网关如何通过“消费者配额”实现大模型调用成本治理?
云原生
网络中的夜鹰14 小时前
轩辕镜像一键安装Docker和Docker Compose脚本
运维·docker·容器
lihongbao8014 小时前
kuboard v3创建用户分配命名空间
kubernetes·kuboard
江湖有缘17 小时前
Docker部署HamsterBase Tasks任务管理工具
运维·docker·容器