正常来说 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; "

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐