k8s deployment 滚动更新

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