• kubernetes给容器生命周期设置操作事件


    Kubernetes支持预启动和预结束事件。 Kubernetes在容器启动的时候发送预启动事件,在容器结束的时候发送预结束事件。

    定义预启动和预结束事件操作

    下面是Pod的配置文件:

    # cat lifecycle-events.yaml
    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: ["/usr/sbin/nginx","-s","quit"]
    

    在这个配置文件里,你可以看到postStart命令在容器目录/usr/share下写了一个message文件, preStop命令停止容器。这在容器被因错误而结束时很有帮助。

    # 创建Pod
    kubectl create -f lifecycle-events.yaml
    
    # 验证Pod里的容器是否运行
    kubectl get pod lifecycle-demo
    
    # 连接到Pod里容器的shell
    kubectl exec -it lifecycle-demo -- /bin/bash
    
    # 在shell里,验证postStart是否创建了message文件
    root@lifecycle-demo:/# cat /usr/share/message
    
    # 输出显示了文件确实被创建了
    Hello from the postStart handler
    

    说明

    Kubernetes在容器创建之后就会马上发送postStart事件,但是并没法保证一定会这么做,它会在容器入口被调用之前调用postStart操作,因为postStart的操作跟容器的操作是异步的,而且Kubernetes控制台会锁住容器直至postStart完成,因此容器只有在 postStart操作完成之后才会被设置成为RUNNING状态。

    Kubernetes在容器结束之前发送preStop事件,并会在preStop操作完成之前一直锁住容器状态,除非Pod的终止时间过期了。

  • 相关阅读:
    英语语法入门十五(名词所有格)
    在线调试Arduino
    CANopen和Canfestival
    嵌入式系统中的printf
    云原生爱好者周刊:Lens 5.0 发布,更炫、更快、更强!
    基于 KubeSphere 的 Nebula Graph 多云架构管理实践
    KubeSphere Meetup 北京站火热报名中 | 搭载 CIC 2021 云计算峰会
    KubeSphere Helm 应用仓库源码分析
    开启 Calico eBPF 数据平面实践
    KubeSphere 在直播应用中的实践
  • 原文地址:https://www.cnblogs.com/sanduzxcvbnm/p/14777402.html
Copyright © 2020-2023  润新知