美文网首页K8S
k8s deployment 滚动更新

k8s deployment 滚动更新

作者: taojy123 | 来源:发表于2018-08-02 22:12 被阅读0次

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

    相关文章

      网友评论

        本文标题:k8s deployment 滚动更新

        本文链接:https://www.haomeiwen.com/subject/tfcevftx.html