kubernetes资源对象之deployment

kubernetes资源对象之deployment

deployment简述

Deployment 的是升级版的 ReplicationController,提供更强大的功能。k8s中常用的资源之一,部署是无状态的,为一般性项目应用的主体。典型用例:

  • 定义 Deployment 来创建 Pod 和 ReplicaSet
  • 滚动升级和回滚应用
  • 扩容和缩容
  • 暂停和继续 Deployment

deployment参加字段解析

apiVersion: v1       #必填,版本号,例如v1
kind: Depolyment     #必填
metadata:       #必填,元数据
  name: string       #必填,Pod名称
  namespace: string    #必填,Pod所属的命名空间
  labels:      #自定义标签
    - name: string     #自定义标签名字<key: value>
  annotations:       #自定义注释列表
    - name: string
spec:         #必填,部署的详细定义
  replicas: number #必填,副本数量
  revisionHistoryLimit: number # 保留历史版本
  strategy: # 策略
    type: RollingUpdate # 滚动更新策略
    rollingUpdate: # 滚动更新
      maxSurge: 30% # 最大额外可以存在的副本数,可以为百分比,也可以为整数
      maxUnavailable: 30% # 示在更新过程中能够进入不可用状态的 Pod 的最大值,可以为百分比,也可以为整数
  selector: 
    matchLabels:
      name: string #必填,通过此标签匹配对应pod<key: value>
  template: #必填,应用容器模版定义
    metadata: 
      labels: 
        name: string #必填,遇上面matchLabels的标签相同
    spec: 
      containers:      #必填,定义容器列表
      - name: string     #必填,容器名称
        image: string    #必填,容器的镜像名称
        imagePullPolicy: [Always | Never | IfNotPresent] #获取镜像的策略 Alawys表示下载镜像 IfnotPresent表示优先使用本地镜像,否则下载镜像,Nerver表示仅使用本地镜像
        affinity: # 亲和性调试
        nodeAffinity: # 节点亲和力
          requiredDuringSchedulingIgnoredDuringExecution: # pod 必须部署到满足条件的节点上
            nodeSelectorTerms: # 节点满足任何一个条件就可以
            - matchExpressions: # 有多个选项,则只有同时满足这些逻辑选项的节点才能运行 pod
              - key: beta.kubernetes.io/arch
                operator: In
                values:
                - amd64
        command: [string]    #容器的启动命令列表,如不指定,使用打包时使用的启动命令
        args: [string]     #容器的启动命令参数列表
        workingDir: string     #选填,容器的工作目录
        env:       #容器运行前需设置的环境变量列表
        - name: string     #环境变量名称
          value: string    #环境变量的值
        ports:       #需要暴露的端口库号列表
        - name: string     #选填,端口号名称
          containerPort: int   #容器需要监听的端口号
          hostPort: int    #选填,容器所在主机需要监听的端口号,默认与Container相同
          protocol: string     #选填,端口协议,支持TCP和UDP,默认TCP
        resources:       #资源限制和请求的设置
          limits:      #资源限制的设置
            cpu: string    #Cpu的限制,单位为core数,将用于docker run --cpu-shares参数
            memory: string     #内存限制,单位可以为Mib/Gib,将用于docker run --memory参数
          requests:      #资源请求的设置
            cpu: string    #Cpu请求,容器启动的初始可用数量
            memory: string     #内存清楚,容器启动的初始可用数量
        volumeMounts:    #挂载到容器内部的存储卷配置
        - name: string     #引用pod定义的共享存储卷的名称,需用volumes[]部分定义的的卷名
          mountPath: string    #存储卷在容器内mount的绝对路径,应少于512字符
          readOnly: boolean    #是否为只读模式
        livenessProbe:     #对Pod内个容器健康检查的设置,当探测无响应几次后将自动重启该容器,检查方法有exec、httpGet和tcpSocket,对一个容器只需设置其中一种方法即可
          exec:      #对Pod容器内检查方式设置为exec方式
            command: [string]  #exec方式需要制定的命令或脚本
          httpGet:       #对Pod内个容器健康检查方法设置为HttpGet,需要制定Path、port
            path: string
            port: number
            host: string
            scheme: string
            HttpHeaders:
            - name: string
              value: string
          tcpSocket:     #对Pod内个容器健康检查方式设置为tcpSocket方式
            port: number
          initialDelaySeconds: 0  #容器启动完成后首次探测的时间,单位为秒
          timeoutSeconds: 0   #对容器健康检查探测等待响应的超时时间,单位秒,默认1秒
          periodSeconds: 0    #对容器监控检查的定期探测时间设置,单位秒,默认10秒一次
          successThreshold: 0
          failureThreshold: 0
          securityContext:
            privileged:false
        #Pod的重启策略,Always表示一旦不管以何种方式终止运行,kubelet都将重启,OnFailure表示只有Pod以非0退出码退出才重启,Nerver表示不再重启该Pod
        restartPolicy: [Always | Never | OnFailure]
        nodeSelector: obeject  #设置NodeSelector表示将该Pod调度到包含这个label的node上,以key:value的格式指定
        imagePullSecrets:    #Pull镜像时使用的secret名称,以key:secretkey格式指定
        - name: string
        hostNetwork:false      #是否使用主机网络模式,默认为false,如果设置为true,表示使用宿主机网络
        volumes:       #在该pod上定义共享存储卷列表
        - name: string     #共享存储卷名称 (volumes类型有很多种)
          emptyDir: {}     #类型为emtyDir的存储卷,与Pod同生命周期的一个临时目录。为空值
          hostPath: string     #类型为hostPath的存储卷,表示挂载Pod所在宿主机的目录
            path: string     #Pod所在宿主机的目录,将被用于同期中mount的目录
        - name: string     #共享存储卷名称
          secret:      #类型为secret的存储卷,挂载集群与定义的secre对象到容器内部
            scretname: string  
            items:     
            - key: string     #选择secrets定义的某个key
              path: string    #文件内容路径
        - name: string     #共享存储卷名称
          configMap:     #类型为configMap的存储卷,挂载预定义的configMap对象到容器内部
            name: string
            items:
            - key: string     #选择configmap定义的某个key
              path: string     #文件内容路径
        - name: string     #共享存储卷名称
          persistentVolumeClaim:
            claimName: string     #类型为PVC的持久化存储卷

deployment的属性:

  1. apiVersion
  2. kind
  3. metadata
  4. spec
  5. status

4.spec字段

  1. minReadySeconds
  2. paused
  3. progressDeadlineSeconds
  4. replicas
  5. revisionHistoryLimit
  6. selector
  7. strategy
  8. template
8.template.spec字段
  1. activeDeadlineSeconds
  2. affinity
  3. automountServiceAccountToken
  4. containers
  5. dnsConfig
  6. dnsPolicy
  7. enableServiceLinks
  8. ephemeralContainers
  9. hostAliases
  10. hostIPC
  11. hostNetwork
  12. hostPID
  13. hostname
  14. imagePullSecrets
  15. initContainers
  16. nodeName
  17. nodeSelector
  18. overhead
  19. preemptionPolicy
  20. priority
  21. priorityClassName
  22. readinessGates
  23. restartPolicy
  24. runtimeClassName
  25. schedulerName
  26. securityContext
  27. serviceAccount
  28. serviceAccountName
  29. setHostnameAsFQDN
  30. shareProcessNamespace
  31. subdomain
  32. terminationGracePeriodSeconds
  33. tolerations
  34. topologySpreadConstraints
  35. volumes
4.containers字段
  1. args
  2. command
  3. env
  4. envFrom
  5. image
  6. imagePullPolicy
  7. lifecycle
  8. livenessProbe
  9. name
  10. ports
  11. readinessProbe
  12. resources
  13. securityContext
  14. startupProbe
  15. stdin
  16. stdinOnce
  17. terminationMessagePath
  18. terminationMessagePolicy
  19. tty
  20. volumeDevices
  21. volumeMounts
  22. workingDir

pod常用字段

  • name
  • image
  • command
  • args
  • workingDir
  • ports
  • env
  • resources
  • volumeMounts
  • livenessProbe
  • readinessProbe
  • livecycle
  • terminationMessagePath
  • imagePullPolicy
  • securityContext
  • stdin
  • stdinOnce
  • tty
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值