环境
- kubernetes 1.20.4
- Spring Boot 2.5.0-M3
目标
deploy 在更新过程中,启动 Pod 后,minReadySeconds 可以定义该 Pod 经过多少秒后才被视为可用。
如果新的 Pod 不可用,是不会替换旧的,直到新的可用为止。
示例
Deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: busybox
spec:
minReadySeconds: 30
strategy:
rollingUpdate:
maxUnavailable: 0
maxSurge: 1
selector:
matchLabels:
app: busybox
replicas: 4
template:
metadata:
labels:
app: busybox
spec:
terminationGracePeriodSeconds: 5
containers:
- name: busybox
image: busybox:1.31.0
command: ["/bin/sh", "-c", "sleep 3600"]
然后将版本升级到 1.31.0。kubectl set image deployment/busybox busybox=busybox:1.31.0 --record
查看
busybox-59c95c7d4b-8lk22 0/1 Pending 0 0s
busybox-59c95c7d4b-8lk22 0/1 Pending 0 0s
busybox-59c95c7d4b-8lk22 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-8lk22 1/1 Running 0 2s
busybox-6bd65c67cf-mjn64 1/1 Terminating 0 46s
busybox-59c95c7d4b-shzxn 0/1 Pending 0 0s
busybox-59c95c7d4b-shzxn 0/1 Pending 0 0s
busybox-59c95c7d4b-shzxn 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-shzxn 1/1 Running 0 1s
busybox-6bd65c67cf-mjn64 0/1 Terminating 0 52s
busybox-6bd65c67cf-mjn64 0/1 Terminating 0 53s
busybox-6bd65c67cf-mjn64 0/1 Terminating 0 53s
busybox-6bd65c67cf-nv6hv 1/1 Terminating 0 77s
busybox-59c95c7d4b-cx6zx 0/1 Pending 0 0s
busybox-59c95c7d4b-cx6zx 0/1 Pending 0 0s
busybox-59c95c7d4b-cx6zx 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-cx6zx 1/1 Running 0 2s
busybox-6bd65c67cf-nv6hv 0/1 Terminating 0 83s
busybox-6bd65c67cf-nv6hv 0/1 Terminating 0 90s
busybox-6bd65c67cf-nv6hv 0/1 Terminating 0 90s
busybox-6bd65c67cf-5mrnx 1/1 Terminating 0 109s
busybox-59c95c7d4b-cjvg7 0/1 Pending 0 0s
busybox-59c95c7d4b-cjvg7 0/1 Pending 0 0s
busybox-59c95c7d4b-cjvg7 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-cjvg7 1/1 Running 0 2s
busybox-6bd65c67cf-5mrnx 0/1 Terminating 0 115s
busybox-6bd65c67cf-5mrnx 0/1 Terminating 0 116s
busybox-6bd65c67cf-5mrnx 0/1 Terminating 0 116s
busybox-6bd65c67cf-fz4l2 1/1 Terminating 0 2m21s
busybox-6bd65c67cf-fz4l2 0/1 Terminating 0 2m27s
busybox-6bd65c67cf-fz4l2 0/1 Terminating 0 2m31s
busybox-6bd65c67cf-fz4l2 0/1 Terminating 0 2m31s
因为将 maxUnavailable 为 0,maxSurge 为 1,所以先新增了一个 Pod。
不过在新增成功后,并没有马上停止旧的,而是等了一段时间才停止旧的。
等待的时间必须大于 minReadySeconds 定义的时间。
总结
minReadySeconds 可用定义新建的 Pod 经过多少秒后才被视为可用。