正常来说 k8s 的 deployment
在更新时默认就会进行滚动的升级
但是实际操作中会发现,滚动更新过程中应用还是会“挂掉”一会儿,大概会有几秒钟网页访问 502。
究其原因应该是容器启动后,到应用真正工作起来,中间会有一段时间,比如在 runserver
前需要进行一下 migrate
等操作,这段时间应用是无法正常访问的,但 k8s 却认为应用是正常就绪状态。
解决方式是设置一个合理的 minReadySeconds
值,这个值默认是 0
参考如下:
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: webapp
labels:
app: webapp
spec:
replicas: 1
minReadySeconds: 10 # 这里需要估一个比较合理的值,从容器启动到应用正常提供服务
strategy: # k8s 默认的 strategy 就是 RollingUpdate, 这里写明出来可以调节细节参数
type: RollingUpdate
rollingUpdate:
maxSurge: 1 # 更新时允许最大激增的容器数,默认 replicas 的 1/4 向上取整
maxUnavailable: 0 # 更新时允许最大 unavailable 容器数,默认 replicas 的 1/4 向下取整
selector:
matchLabels:
app: webapp
template:
metadata:
name: webapp
labels:
app: webapp
spec:
containers:
- name: heyshop-app-combo-backend
image: django-app-image:latest
imagePullPolicy: Always
command:
- bash
args:
- "-c"
- "python manage.py migrate; gunicorn run.wsgi; "
网友评论