Kubernetes基础: Pod删除的grace-period设置

在Kubernetes中提供了grace-period,在Pod删除时此选项会起作用,会延迟一定时长才进行删除,缺省未设定的情况下会等待30s中之后删除。

为什么要延迟删除

因为在删除之前,很多容器化的应用往往还有一些操作需要处理,而这些都需要一些时间,直接粗暴地关闭往往会带来后遗症。

现象再现

Pod准备

  • YAML文件
[root@host131 Pod]# cat pod.yaml
---
apiVersion: v1
kind: Pod
metadata:
  name: testbox
  namespace: default
spec:
  containers:
  - name: testbox-host
    image: busybox:latest
    command: ["sleep"]
    args: ["1000"]
...
[root@host131 Pod]# 

创建Pod与结果确认日志如下所示:

[root@host131 Pod]# kubectl get pods
No resources found in default namespace.
[root@host131 Pod]# kubectl create -f pod.yaml 
pod/testbox created
[root@host131 Pod]# kubectl get pods -o wide
NAME      READY   STATUS    RESTARTS   AGE   IP             NODE              NOMINATED NODE   READINESS GATES
testbox   1/1     Running   0          8s    10.254.152.5   192.168.163.131   <none>           <none>
[root@host131 Pod]# 

Pod删除 与删除时间确认

对Pod删除动作进行计时,发现为32秒

[root@host131 Pod]# time -p kubectl delete pod testbox
pod "testbox" deleted
real 32.12
user 0.10
sys 0.02
[root@host131 Pod]#

如果非命令行方式,可以考虑使用如下类似命令进行确认

执行命令:i=0; while [ $i -lt 100 ]; do i=expr $i + 1; date; kubectl get pods -o wide; sleep 1; done

指定删除延迟时间: 0s

指定grace-period为0,整体删除时间会明显降低(根据机器实时性能以及镜像的差别,多次执行可能会有一定出入,但是基本肯定小于缺省方式)

[root@host131 Pod]# kubectl create -f pod.yaml 
pod/testbox created
[root@host131 Pod]# kubectl get pods -o wide
NAME      READY   STATUS    RESTARTS   AGE   IP             NODE              NOMINATED NODE   READINESS GATES
testbox   1/1     Running   0          7s    10.254.152.5   192.168.163.131   <none>           <none>
[root@host131 Pod]# 
[root@host131 Pod]# time -p kubectl delete pod testbox --grace-period=0
pod "testbox" deleted
real 8.08
user 0.10
sys 0.03
[root@host131 Pod]#
发布了1084 篇原创文章 · 获赞 1299 · 访问量 402万+

猜你喜欢

转载自blog.csdn.net/liumiaocn/article/details/104213189
今日推荐