Linux:kubernetes(k8s)prestop事件的使用(10)
他的作用是在结束pod容器之后进行的操作
apiVersion: v1 # api文档版本 kind: Pod # 资源对象类型 metadata: # pod相关的元数据,用于描述pod的数据 name: nginx-po # pod名称 labels: # pod的标签 type: app #这个是随便写的 自定义的标签 version: 1.0.0 #这个是随便写的 namespace: 'default' #命名空间的配置 spec: #期望pod按照这里面的描述进行创建 containers: #对于pod容器的描述 - name: nginx #容器的名称 image: nginx:1.7.9 # 指定容器的镜像 imagePullPolicy: IfNotPresent #镜像拉取策略 lifecycle: # 生命周期配置 postStart: exec: command: - sh - -c - "echo 'pre stop' > /usr/share/nginx/html/prestop.html" preStop: exec: command: - sh - -c - "sleep 50 ; echo 'sleep finished...' >> /usr/share/nginx/html/prestop.html" command: # 指定容器启动时执行的命令 - nginx - -g - 'daemon off;' workingDir: /usr/local/nginx/html # 定义容器启动后的工作目录 ports: - name: http # 端口名称 containerPort: 80 # 描述容器内容要暴露的端口 protocol: TCP # 端口是用什么协议通信 env: # 环境变量 - name: JVM_OPTS # 环境变量的名称 value: '-Xms128m -Xmx128m' # 环境变量的值 resources: requests: # 最少需要多少资源 cpu: 100m #限制cpu最少使用 1000m=1核心 100m就是0.1个核心 memory: 128Mi #限制内存最少使用129兆 limits: #最多可以用多少 cpu: 200m # 限制最多可以使用多少 memory: 256Mi restartPolicy: OnFailure #重启策略,只有失败的情况才会重启
将这yaml文件运行起来
开始的时候写入一段 pre stop 结束的时候先休眠50秒 再写入一个 sleep ……
可以看到已经写入了,
查看效果
现在我们左边右边都开一个终端,右边持续监听从而持续查看他的一个状态
kubectl get po -w
当我们删除pod的时候默认他是缓30秒后才删除的,这是归功于terminationGracePeriodSeconds: 30
我没写所以他默认是30秒,如果想改成别的时间,可以直接把他加上并且改后面的数值
可以看到就是30秒(多个1秒2秒问题也不大)
现在我把 terminationGracePeriodSeconds: 30加上 时间改成40秒,让后再去生成一个容器
发现就是40秒左右了
文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。