Kubernetes中钩子函数详解、实例

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失败的话, 容器会被杀死。

当前名称:Kubernetes中钩子函数详解、实例
标题链接:http://www.shufengxianlan.com/qtweb/news48/194998.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联