【k8s】deploy-maxSurge
环境
- kubernetes 1.20.4
- Spring Boot 2.5.0-M3
目标
deploy 在更新过程中,Pod 数量可以超过定义的数量,超过的最大的值就叫 maxSurge。
该值可以是一个百分比,也可以是一个具体的数字,默认情况下,该值为 25%。
示例
Deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: busybox
spec:
strategy:
rollingUpdate:
maxSurge: 0
selector:
matchLabels:
app: busybox
replicas: 4
template:
metadata:
labels:
app: busybox
spec:
terminationGracePeriodSeconds: 5
containers:
- name: busybox
image: busybox:1.30.0
command: ["/bin/sh", "-c", "sleep 3600"]
然后将版本升级到 1.31.0。
kubectl set image deployment/busybox busybox=busybox:1.31.0 --record
查看
busybox-76bcb59645-n9w5f 1/1 Terminating 0 48s
busybox-59c95c7d4b-wr6bd 0/1 Pending 0 0s
busybox-59c95c7d4b-wr6bd 0/1 Pending 0 0s
busybox-59c95c7d4b-wr6bd 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-wr6bd 1/1 Running 0 2s
busybox-76bcb59645-gjg7m 1/1 Terminating 0 50s
busybox-59c95c7d4b-fmzvx 0/1 Pending 0 0s
busybox-59c95c7d4b-fmzvx 0/1 Pending 0 0s
busybox-59c95c7d4b-fmzvx 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-fmzvx 1/1 Running 0 2s
busybox-76bcb59645-pjfv7 1/1 Terminating 0 52s
busybox-59c95c7d4b-9pv8l 0/1 Pending 0 0s
busybox-59c95c7d4b-9pv8l 0/1 Pending 0 0s
busybox-59c95c7d4b-9pv8l 0/1 ContainerCreating 0 0s
busybox-59c95c7d4b-9pv8l 1/1 Running 0 1s
busybox-76bcb59645-qg4ws 1/1 Terminating 0 53s
busybox-59c95c7d4b-nx6hr 0/1 Pending 0 0s
busybox-59c95c7d4b-nx6hr 0/1 Pending 0 0s
busybox-59c95c7d4b-nx6hr 0/1 ContainerCreating 0 0s
busybox-76bcb59645-n9w5f 0/1 Terminating 0 54s
busybox-76bcb59645-gjg7m 0/1 Terminating 0 56s
busybox-76bcb59645-n9w5f 0/1 Terminating 0 57s
busybox-76bcb59645-n9w5f 0/1 Terminating 0 57s
busybox-76bcb59645-pjfv7 0/1 Terminating 0 58s
busybox-76bcb59645-gjg7m 0/1 Terminating 0 67s
busybox-76bcb59645-gjg7m 0/1 Terminating 0 67s
busybox-76bcb59645-pjfv7 0/1 Terminating 0 67s
busybox-76bcb59645-pjfv7 0/1 Terminating 0 67s
busybox-59c95c7d4b-nx6hr 1/1 Running 0 15s
busybox-76bcb59645-qg4ws 0/1 Terminating 0 68s
busybox-76bcb59645-qg4ws 0/1 Terminating 0 78s
busybox-76bcb59645-qg4ws 0/1 Terminating 0 78s
因为将 maxSurge,最大超出数量设置成了 0,所以无论如何都不会超过定义的数量。
都是先减少再新增,也就是说,更新过程中,只会出现缺少服务数量的情况,不会多。
总结
maxSurge 定义了更新过程中,超出定义的数量,可以是一个数值,也可以是百分比。
附录
分类:
Kubernetes
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2020-04-02 Redis:ERR max number of clients reached