`

[转]使用kubernetes的deployment进行RollingUpdate

阅读更多

转自:https://segmentfault.com/a/1190000008232770

rolling update,可以使得服务近乎无缝地平滑升级,即在不停止对外服务的前提下完成应用的更新。

replication controller与deployment的区别

replication controller

Replication Controller为Kubernetes的一个核心内容,应用托管到Kubernetes之后,需要保证应用能够持续的运行,Replication Controller就是这个保证的key,主要的功能如下:

  • 确保pod数量:它会确保Kubernetes中有指定数量的Pod在运行。如果少于指定数量的pod,Replication Controller会创建新的,反之则会删除掉多余的以保证Pod数量不变。

  • 确保pod健康:当pod不健康,运行出错或者无法提供服务时,Replication Controller也会杀死不健康的pod,重新创建新的。

  • 弹性伸缩 :在业务高峰或者低峰期的时候,可以通过Replication Controller动态的调整pod的数量来提高资源的利用率。同时,配置相应的监控功能(Hroizontal Pod Autoscaler),会定时自动从监控平台获取Replication Controller关联pod的整体资源使用情况,做到自动伸缩。

  • 滚动升级:滚动升级为一种平滑的升级方式,通过逐步替换的策略,保证整体系统的稳定,在初始化升级的时候就可以及时发现和解决问题,避免问题不断扩大。

Deployment

Deployment同样为Kubernetes的一个核心内容,主要职责同样是为了保证pod的数量和健康,90%的功能与Replication Controller完全一样,可以看做新一代的Replication Controller。但是,它又具备了Replication Controller之外的新特性:

  • Replication Controller全部功能:Deployment继承了上面描述的Replication Controller全部功能。

  • 事件和状态查看:可以查看Deployment的升级详细进度和状态。

  • 回滚:当升级pod镜像或者相关参数的时候发现问题,可以使用回滚操作回滚到上一个稳定的版本或者指定的版本。

  • 版本记录: 每一次对Deployment的操作,都能保存下来,给予后续可能的回滚使用。

  • 暂停和启动:对于每一次升级,都能够随时暂停和启动。

  • 多种升级方案:Recreate:删除所有已存在的pod,重新创建新的; RollingUpdate:滚动升级,逐步替换的策略,同时滚动升级时,支持更多的附加参数,例如设置最大不可用pod数量,最小升级间隔时间等等。

deployment的常用命令

查看部署状态

kubectl rollout status deployment/review-demo  --namespace=scm
kubectl describe deployment/review-demo  --namespace=scm

或者这种写法

kubectl rollout status deployments review-demo --namespace=scm
kubectl describe deployments review-demo  --namespace=scm

升级

kubectl set image deployment/review-demo review-demo=library/review-demo:0.0.1 --namespace=scm

或者

kubectl edit deployment/review-demo --namespace=scm

编辑.spec.template.spec.containers[0].image的值

终止升级

kubectl rollout pause deployment/review-demo --namespace=scm

继续升级

kubectl rollout resume deployment/review-demo --namespace=scm

回滚

kubectl rollout undo deployment/review-demo --namespace=scm

查看deployments版本

kubectl rollout history deployments --namespace=scm

回滚到指定版本

kubectl rollout undo deployment/review-demo --to-revision=2 --namespace=scm

升级历史

kubectl describe deployment/review-demo  --namespace=scm
Name:     review-demo
Namespace:    scm
CreationTimestamp:  Tue, 31 Jan 2017 16:42:01 +0800
Labels:     app=review-demo
Selector:   app=review-demo
Replicas:   3 updated | 3 total | 3 available | 0 unavailable
StrategyType:   RollingUpdate
MinReadySeconds:  0
RollingUpdateStrategy:  1 max unavailable, 1 max surge
OldReplicaSets:   <none>
NewReplicaSet:    review-demo-2741031620 (3/3 replicas created)
Events:
  FirstSeen LastSeen  Count From        SubobjectPath Type    Reason      Message
  --------- --------  ----- ----        ------------- --------  ------      -------
  1m    1m    1 {deployment-controller }    Normal    ScalingReplicaSet Scaled up replica set review-demo-2741031620 to 1
  1m    1m    1 {deployment-controller }    Normal    ScalingReplicaSet Scaled down replica set review-demo-1914295649 to 2
  1m    1m    1 {deployment-controller }    Normal    ScalingReplicaSet Scaled up replica set review-demo-2741031620 to 2
  1m    1m    1 {deployment-controller }    Normal    ScalingReplicaSet Scaled down replica set review-demo-1914295649 to 1
  1m    1m    1 {deployment-controller }    Normal    ScalingReplicaSet Scaled up replica set review-demo-2741031620 to 3
  1m    1m    1 {deployment-controller }    Normal    ScalingReplicaSet Scaled down replica set review-demo-1914295649 to 0

deployment文件

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: review-demo
  namespace: scm
  labels:
    app: review-demo
spec:
  replicas: 3
#  minReadySeconds: 60     #滚动升级时60s后认为该pod就绪
  strategy:
    rollingUpdate:  ##由于replicas为3,则整个升级,pod个数在2-4个之间
      maxSurge: 1      #滚动升级时会先启动1个pod
      maxUnavailable: 1 #滚动升级时允许的最大Unavailable的pod个数
  template:
    metadata:
      labels:
        app: review-demo
    spec:
      terminationGracePeriodSeconds: 60 ##k8s将会给应用发送SIGTERM信号,可以用来正确、优雅地关闭应用,默认为30秒
      containers:
      - name: review-demo
        image: library/review-demo:0.0.1-SNAPSHOT
        imagePullPolicy: IfNotPresent
        livenessProbe: #kubernetes认为该pod是存活的,不存活则需要重启
          httpGet:
            path: /health
            port: 8080
            scheme: HTTP
          initialDelaySeconds: 60 ## equals to the maximum startup time of the application + couple of seconds
          timeoutSeconds: 5
          successThreshold: 1
          failureThreshold: 5
        readinessProbe: #kubernetes认为该pod是启动成功的
          httpGet:
            path: /health
            port: 8080
            scheme: HTTP
          initialDelaySeconds: 30 ## equals to minimum startup time of the application
          timeoutSeconds: 5
          successThreshold: 1
          failureThreshold: 5
        resources:
          # keep request = limit to keep this container in guaranteed class
          requests:
            cpu: 50m
            memory: 200Mi
          limits:
            cpu: 500m
            memory: 500Mi
        env:
          - name: PROFILE
            value: "test"
        ports:
          - name: http
            containerPort: 8080

几个重要参数说明

maxSurge与maxUnavailable

maxSurge: 1 表示滚动升级时会先启动1个pod
maxUnavailable: 1 表示滚动升级时允许的最大Unavailable的pod个数
由于replicas为3,则整个升级,pod个数在2-4个之间

terminationGracePeriodSeconds

k8s将会给应用发送SIGTERM信号,可以用来正确、优雅地关闭应用,默认为30秒。

如果需要更优雅地关闭,则可以使用k8s提供的pre-stop lifecycle hook 的配置声明,将会在发送SIGTERM之前执行。

livenessProbe与readinessProbe

livenessProbe是kubernetes认为该pod是存活的,不存在则需要kill掉,然后再新启动一个,以达到replicas指定的个数。

readinessProbe是kubernetes认为该pod是启动成功的,这里根据每个应用的特性,自己去判断,可以执行command,也可以进行httpGet。比如对于使用java web服务的应用来说,并不是简单地说tomcat启动成功就可以对外提供服务的,还需要等待spring容器初始化,数据库连接连接上等等。对于spring boot应用,默认的actuator带有/health接口,可以用来进行启动成功的判断。

其中readinessProbe.initialDelaySeconds可以设置为系统完全启动起来所需的最少时间,livenessProbe.initialDelaySeconds可以设置为系统完全启动起来所需的最大时间+若干秒。

这几个参数配置好了之后,基本就可以实现近乎无缝地平滑升级了。对于使用服务发现的应用来说,readinessProbe可以去执行命令,去查看是否在服务发现里头应该注册成功了,才算成功。

分享到:
评论

相关推荐

    5分钟玩转Kubernetes

    3. **滚动更新(Rolling Update)**:无中断地更新应用版本,减少服务中断风险。 4. **存储编排(Storage Orchestration)**:支持多种存储类型,包括本地存储、网络存储和云存储。 5. **网络策略(Network Policies)**:...

    kubernetes笔记.rar

    - **日志和监控**:使用Kubernetes的logging和metrics API,配合Prometheus和Grafana等工具进行集群监控。 4. **Kubernetes网络模型** - **Network Policy**:控制Pod间通信的策略,实现微隔离。 - **CNI插件**...

    kubernetes常用命令1

    * rolling-update:滚动更新资源对象 三、Pod相关命令 Pod是Kubernetes中的基本执行单元,以下命令适用于Pod: * kubectl get pod:获取Pod的信息 * kubectl describe pod:获取Pod的详细信息 * kubectl update ...

    《Kubernetes 微服务实践》课程PPT.zip

    Kubernetes的部署策略,如滚动更新(Rolling Update)和蓝绿部署(Blue-Green Deployment),使得应用升级更加安全可靠。滚动更新允许逐步替换Pod,而不会中断服务;蓝绿部署则通过并行运行新旧两个版本,先验证新版本...

    23道Kubernetes面试题.pdf

    Kubernetes的滚动更新机制(RollingUpdate)允许用户在更新Pod的镜像版本时,逐步地替换旧的Pod实例,这个过程可以减少更新带来的风险。用户还可以控制滚动更新的速度、行为以及回滚操作,从而灵活地应对各种发布...

    17 _ 经典PaaS的记忆:作业副本与水平扩展1

    例如,如果更新了Deployment的Pod模板(比如,修改了容器的镜像),那么Deployment就会遵循一种叫作“滚动更新”(rolling update)的方式,来升级现有的容器。 ReplicaSet对象的定义是Deployment的一个子集,它的...

    【技术分享】Kubernetes落地实践.pptx

    - **Rolling Update, Recreate**:更新策略,确保服务的连续性。 - **ResourceQuota**:全局资源配额限制。 - **Service Account, Secret, KeyRef**:用于认证和安全通信。 - **Rollout History**:记录部署历史,...

    Kubernetes管理员实训 第3课:K8S日志、监控与应用管理实训1

    RollingUpdate策略允许逐步替换Pod,控制`maxSurge`和`maxUnavailable`参数来调整滚动更新的速度和稳定性。 在回滚Deployment时,如果新版本出现问题,可以使用`kubectl rollout undo`命令恢复到之前的版本。此外,...

    Python库 | eks-rolling-update-1.0.141.tar.gz

    "eks-rolling-update-1.0.141.tar.gz" 是一个针对Python开发的库,主要用于管理和更新Amazon Elastic Kubernetes Service (EKS)集群中的工作负载。EKS是AWS提供的托管Kubernetes服务,允许用户在AWS云环境中部署、...

    Kubernetes知识点归纳1

    - **Rolling Update**: Deployment支持无缝升级Pod,逐步替换旧版本,确保服务的连续性。 8. **Resource Quota**: - 允许设置多粒度的资源配额,限制不同命名空间或用户对资源的消耗。 9. **Security and ...

    kubernetes常用命令表

    # 设置名为 nginx 的 Deployment 自动缩放范围为 1 至 10 个 Pod,并且 CPU 使用率超过 50% 时触发。 kubectl autoscale deployment nginx --min=1 --max=10 --cpu-percent=50 ``` #### 五、kubectl convert `...

    阿里云 专有云企业版 V3.9.0 容器服务Kubernetes版 用户指南 20191017.pdf

    - **滚动更新(Rolling Update)**:在不中断服务的情况下更新应用。 6. **使用流程**: - 创建Kubernetes集群,选择合适的配置(如节点数量、硬件规格等)。 - 部署应用,通过YAML文件定义应用的配置和服务。 ...

    Kubernetes容器云平台介绍.pptx

    - **Recreate/Rolling-UpdatePolicy**:更新 Pod 的策略,如滚动更新或直接替换。 - **Service Account/Secret/KeyRef/ValueFrom**:用于身份验证、安全配置和环境变量注入。 Kubernetes 网络方面,有两种主流的...

    【Cloud Native Lives】Kubernetes管理员实训 第1课:CKA考纲与K8S基础概念解读-v0.21

    `run`用于启动容器,`set`用于设置对象特性,`get`用于查询资源,`explain`用于查看资源定义,`edit`用于编辑资源,`delete`用于删除资源,`rollout`和`rolling-update`用于管理Deployment和ReplicaSet的升级,以及`...

    Kubernetes与OpenStack融合支撑企业级微服务架构.pdf

    - 服务编排:利用Deployment、Helm、Rolling-Update等进行服务编排和版本升级。 - 日志管理与监控:使用EFK(Elasticsearch、Fluentd、Kibana)、Prometheus、Heapster等进行服务日志和性能监控。 - 任务管理:支持...

    kubernetes:我的有关kubernetes的文档

    在Kubernetes中,滚动更新(Rolling Update)是常见的应用更新方式,`kubectl set image`或在Deployment中指定`strategy.type=RollingUpdate`可以实现无中断的更新过程。同时,通过设置`restartPolicy`,我们可以...

    Kubernetes的有状态服务实践.docx

    - **升级策略**:使用滚动更新(RollingUpdate)策略,逐个替换Pod,避免服务中断。 - **监控与日志**:设置监控指标和日志收集,以便及时发现和解决问题。 总之,理解并熟练运用Kubernetes的StatefulSet是确保有...

    17 经典PaaS的记忆:作业副本与水平扩展.pdf

    2. **滚动更新(Rolling Update)**:当Deployment的Pod模板(如容器镜像)被更新时,Deployment会按照一定的策略逐步替换旧的Pod,确保服务的连续性和可用性。这一过程不会导致整个服务中断,降低了维护风险。 3. ...

    K8S权威指南第4版,课程相关代码

    - **RollingUpdate**: 逐步替换旧版本Pod,确保服务可用性。 - **Rollback**: 如果更新出现问题,可以恢复到之前的版本。 6. **自定义资源**: - **CustomResourceDefinition (CRD)**: 允许扩展Kubernetes API,...

    0Downtime-Deployments-Kubernetes:该项目与Kubernetes部署对象有关,以学习如何使用零时区时间在Kubernetes上部署应用程序

    在Kubernetes中,当你更新Deployment的规格(spec)时,系统会按照预定的策略滚动更新(Rolling Update)现有Pods,而不会造成服务中断。 1. **滚动更新**:滚动更新是Kubernetes中最常用的零停机部署方法。在这个...

Global site tag (gtag.js) - Google Analytics