Deployment为Pod和ReplicaSets提供声明性更新

示例

---
apiVersion: apps/v1
kind: Deployment
metadata:
     name: deploy-myweb
     namespace: default
spec:
     replicas: 3
     selector:
         matchLabels:
             app: myweb
             tier: frontend
     template:
         metadata:
             namespace: default
             labels:
                 app: myweb
                 tier: frontend
         spec:
             containers:
               - name: container-myweb
                 image: mycloudedu/myweb:v1
                 imagePullPolicy: IfNotPresent

将清单提交给kubernetes集群,将创建定义的Deployment及其管理的ReplicaSet与pod

[root@master kubernetes]# kubectl apply -f deploy-myweb.yaml

验证

[root@master kubernetes]# kubectl get deployment
NAME           READY   UP-TO-DATE   AVAILABLE   AGE
deploy-myweb   3/3     3            3           89s

[root@master kubernetes]# kubectl get rs
NAME                      DESIRED   CURRENT   READY   AGE
deploy-myweb-85996f4d65   3         3         3       111s

[root@master kubernetes]# kubectl get pod
NAME                            READY   STATUS    RESTARTS   AGE
deploy-myweb-85996f4d65-4dr58   1/1     Running   0          6s
deploy-myweb-85996f4d65-8vfhl   1/1     Running   0          6s
deploy-myweb-85996f4d65-qsfmj   1/1     Running   0          6s

这里只阐述几个字段:.spec.replicas、.spec.selector、.spec.strategy、.spec.revisionHistoryLimit、.spec.template五个字段。其他字段跟前两篇文章差不多,这里不作阐述。想了解请点击这里

kubectl explain deployment.spec

replicas    <integer>                          #是指期望值的pod数

selector <Object> -required-              #标签选择器,kubernetes根据这个标签查看有几个pod。符不符ReplicaSet合期望值

strategy <Object>                             #更新pod的策略

template <Object> -required-             #创建pod的模板

revisionHistoryLimit    <integer>         #保存几个历史版本,默认是10个

kubectl explain deployment.spec.selector有两种用法:

matchExpressions  <[]Object>

matchLabels    <map[string]string>

示例一:键与值的关系

matchExpressions:

- key:KEY

operator: (In, NotIn, Exists and DoesNotExist)

values: [VALUES1,VALUES2,…]

示例二:

matchLabels:

KEY:VALUES

kubectl explain deployment.spec.strategy

rollingUpdate <Object>       #当type是RollingUpdate,这个字段才生效

type    <string>                  #类型有两种Recreate与RollingUpdate,默认是RollingUpdate

当type=Recreate时,重新创建pod。当type=RollingUpdata时,重新创建pod是由策略规划。

这里讲解一下type=RollingUpdata。

kubectl explain deployment.spec.strategy.rollingUpdate有两个字段:

maxSurge    <string>              #最多能多几个pod

maxUnavailable    <string>      #最多能少几个pod

示例:

rollingUpdate:

maxSurge: <integer>

maxUnavailable: <integer>

这里template不阐述,说几个注意事项:

1.metadata.name这项可以不定义。因为定义了也不会生效。

2.metadata.labels必须含有selector的标签。

3.spec与pod的spec是一样的,这里就不在说明了。需要了解的查看上面文章。

综合示例

---
apiVersion: apps/v1
kind: Deployment
metadata:
     name: deploy-myweb
     namespace: default
spec:
     replicas: 3
     selector:
         matchLabels:
             app: myweb
             tier: frontend
     strategy:
         type: RollingUpdate
         rollingUpdate:
             maxSurge: 1
             maxUnavailable: 1
     revisionHistoryLimit: 3
     template:
         metadata:
             namespace: default
             labels:
                 app: myweb
                 tier: frontend
         spec:
             containers:
               - name: container-myweb
                 image: mycloudedu/myweb:v1
                 imagePullPolicy: IfNotPresent

验证

[root@master kubernetes]# kubectl describe deploy deploy-myweb

RollingUpdateStrategy:  1 max unavailable, 1 max surge

用打补丁的方式修改策略

[root@master kubernetes]# kubectl patch deployments deploy-myweb -p '{"spec":{"strategy":{"rollingUpdate":{"maxSurge":2,"maxUnavailable":0}}}}'
deployment.apps/deploy-myweb patched

验证

[root@master kubernetes]# kubectl describe deploy deploy-myweb

RollingUpdateStrategy:  0 max unavailable, 2 max surge

更新版本,定义更新一个版本暂停。是否跟定义更新策略进行更新

[root@master kubernetes]# kubectl set image deployments deploy-myweb container-myweb=mycloudedu/myweb:v2 && kubectl rollout pause deployment/deploy-myweb
deployment.apps/deploy-myweb image updated
deployment.apps/deploy-myweb paused

[root@master ~]# kubectl get pod -w
NAME                            READY   STATUS    RESTARTS   AGE
deploy-myweb-85996f4d65-4dr58   1/1     Running   0          57m
deploy-myweb-85996f4d65-8vfhl   1/1     Running   0          57m
deploy-myweb-85996f4d65-qsfmj   1/1     Running   0          57m
deploy-myweb-7fff44cfb8-cvbxf   0/1     Pending   0          0s
deploy-myweb-7fff44cfb8-h47lb   0/1     Pending   0          0s
deploy-myweb-7fff44cfb8-cvbxf   0/1     Pending   0          0s
deploy-myweb-7fff44cfb8-h47lb   0/1     Pending   0          0s
deploy-myweb-7fff44cfb8-cvbxf   0/1     ContainerCreating   0          0s
deploy-myweb-7fff44cfb8-h47lb   0/1     ContainerCreating   0          0s
deploy-myweb-7fff44cfb8-h47lb   1/1     Running             0          3s
deploy-myweb-7fff44cfb8-cvbxf   1/1     Running             0          3s

原本三个pod还是运行,后面创建一个pod。上面定义的策略是:允许最多多两个,不能减少pod。结论:符合更新策略

取消暂时更新

[root@master kubernetes]# kubectl rollout resume deploy/deploy-myweb
deployment.apps/deploy-myweb resumed

验证

[root@master ~]# kubectl rollout status deploy deploy-myweb
Waiting for deployment "deploy-myweb" rollout to finish: 2 out of 3 new replicas have been updated...
Waiting for deployment spec update to be observed...
Waiting for deployment spec update to be observed...
Waiting for deployment "deploy-myweb" rollout to finish: 2 out of 3 new replicas have been updated...
Waiting for deployment "deploy-myweb" rollout to finish: 2 out of 3 new replicas have been updated...
Waiting for deployment "deploy-myweb" rollout to finish: 1 old replicas are pending termination...
Waiting for deployment "deploy-myweb" rollout to finish: 1 old replicas are pending termination...
deployment "deploy-myweb" successfully rolled out

[root@master kubernetes]# kubectl get deploy -o wide
NAME           READY   UP-TO-DATE   AVAILABLE   AGE   CONTAINERS        IMAGES                SELECTOR
deploy-myweb   3/3     3            3           65m   container-myweb   mycloudedu/myweb:v2   app=myweb,tier=frontend

查看历史版本

[root@master kubernetes]# kubectl rollout history deployments deploy-myweb
deployment.apps/deploy-myweb
REVISION  CHANGE-CAUSE
1         <none>
2         <none>

回滚历史版本

[root@master kubernetes]# kubectl rollout undo deploy/deploy-myweb --to-revision=1
deployment.apps/deploy-myweb rolled back

验证

[root@master kubernetes]# kubectl get deploy -o wide
NAME           READY   UP-TO-DATE   AVAILABLE   AGE   CONTAINERS        IMAGES                SELECTOR
deploy-myweb   3/3     3            3           67m   container-myweb  mycloudedu/myweb:v1   app=myweb,tier=frontend

kubernetes资源清单之Deployment的更多相关文章

  1. kubernetes系列06—kubernetes资源清单定义入门

    本文收录在容器技术学习系列文章总目录 1.认识kubernetes资源 1.1 常用资源/对象 workload工作负载型资源:pod,ReplicaSet,Deployment,StatefulSe ...

  2. (四)Kubernetes 资源清单定义

    Kubernetes常用资源对象 依据资源的主要功能作为分类标准,Kubernetes的API对象大体可分为五个类别,如下: 类型 名称 工作负载(Workload) Pod.ReplicaSet.D ...

  3. Kubernetes 学习5 kubernetes资源清单定义入门

    一.kubernetes是有一个restful风格的 API,把各种操作对象都一律当做资源来管理.并且可通过标准的HTTP请求的方法 GET,PUT,DELETE,POST,等方法来完成操作,不过是通 ...

  4. kubernetes 资源清单定义入门

    k8s中的资源 什么叫资源? k8s中所有的内容都抽象为资源, 资源实例化之后,叫做对象 在k8s中有哪些资源? 工作负载型资源(workload): Pod ReplicaSet Deploymen ...

  5. 4、kubernetes资源清单快速入门190625

    一.资源清单概念 资源/对象的类型 工作负载型资源:Pod, ReplicaSet, Deployment, StatefulSet, DaemonSet, Job, Cronjob, ... 服务发 ...

  6. kubernetes资源清单之pod

    什么是pod? Pod是一组一个或多个容器(例如Docker容器),具有共享的存储/网络,以及有关如何运行这些容器的规范. Pod的内容始终位于同一地点,并在同一时间安排,并在共享上下文中运行. Po ...

  7. 5、kubernetes资源清单定义入门

    使用配置清单创建资源 定义pod时使用yaml格式 master ~]# kubectl get pod NAME READY STATUS RESTARTS AGE client / Error 1 ...

  8. kubernetes资源清单入门

    创建nginx容器: kubectl run nginx-deploy8 --image=nginx:1.14-alpine --port=80 --replicas=2 deployment &qu ...

  9. kubernetes资源清单之DaemonSet

    什么是 DaemonSet? DaemonSet 确保全部(或者某些)节点上运行一个 Pod 的副本.当有节点加入集群时,也会为他们新增一个 Pod . 当有节点从集群移除时,这些 Pod 也会被回收 ...

随机推荐

  1. 一个简单的C共享库的创建及Python调用此库的方法

    /********************************************************************* * Author  : Samson * Date    ...

  2. SQL中group by后面的having中不能使用别名

    如下图中,SQL中需要对group by的结果使用having进行过滤,不能使用select中定义的别名,需要使用查询字段的原始名.否则会报错,列明未定义. 下图未错误演示: 修改后,正确的SQL语句 ...

  3. react-native-picke Cannot read property '_init' of undefined

    使用react-native-picker报以下错误: 查看了react-native-picke的issues: https://github.com/beefe/react-native-pick ...

  4. 封装Button ,封装UITableView,封装UICollectionView

    ---恢复内容开始--- 封装Button ,封装UITableView,封装UICollectionView: 1.实现Button的创建和点击事件不用分开操作处理; 2.实现UITableView ...

  5. web系统认证与鉴权中的一些问题

    认证鉴权系统的初心: 空间管理: 1.他是谁? 他登陆了没有? 2.他要做什么? 2.1 他要使用什么功能? 他是否有这个功能的权限. 2.2 他要使用这个功能做什么操作? 他是否有这个功能的这个操作 ...

  6. android#ListView的简单用法

    新建项目,并修改项目生产的主文件activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/ap ...

  7. 随便写的Gost安装脚本,作用你懂的,目前只支持CentOS,可以在Aliyun ECS中使用

    服务器 执行下面命令: curl -L aux.pub/gost | bash 或者: curl -L https://gist.githubusercontent.com/inrg/03da1ded ...

  8. 基于JAVA Socket的底层原理分析及工具实现

    前言 在工作开始之前,我们先来了解一下Socket 所谓Socket,又被称作套接字,它是一个抽象层,简单来说就是存在于不同平台(os)的公共接口.学过网络的同学可以把它理解为基于传输TCP/IP协议 ...

  9. 【Python】if __name__ == '__main__' 含义解析

    相信大家在看别人的python程序时,可能会在大部分的程序后看到标题这段代码,这里解释下它的意义.总的来说,这句代码的作用就是既能保证当前的.py文件直接运行,也能保证其可以作为模块被其他.py文件导 ...

  10. Android Application的基本组件介绍

    一个Android应用通常由一个或多个基本组件组成,常用的一般有Activity.Service.BroadcastReceiver.ContentProvider.Intent等等. ⒈Activi ...