zoukankan      html  css  js  c++  java
  • Kubernetes Deployment(部署无状态应用)

    Kubernetes Deployment(部署无状态应用)

    Pod与controllers的关系
      • controllers:在集群上管理和运行容器的对象
      • 通过label-selector相关联
      • Pod通过控制器实现应用的运维,如伸缩,升级等

    Deployment
      • 部署无状态应用
      • 管理Pod和ReplicaSet(副本控制、更新回滚)
      • 具有上线部署、副本设定、滚动升级、回滚等功能
      • 提供声明式更新,例如只更新一个新的Image

    应用场景:Web服务

    案例

    1、创建deployment

    vim tomcat-deployment.yaml

    apiVersion: apps/v1beta1
    kind: Deployment
    metadata:
      labels:
        app: tomcat
      name: tomcat
    spec:
      replicas: 3
      selector:
        matchLabels:
          app: tomcat
      template:
        metadata:
          labels:
            app: tomcat
        spec:
          imagePullSecrets:
          - name: registry-pull-secret
          containers:
          - image: tomcat
            imagePullPolicy: Always
            name: tomcat
            ports:
            - containerPort: 8080
    ---
    apiVersion: v1
    kind: Service
    metadata:
      name: tomcat-service
      labels:
        app: tomcat
    spec:
      type: NodePort
      ports:
      - port: 80
        targetPort: 8080
      selector:
        app: tomcat

    2、创建deployment

    kubectl apply -f tomcat-deployment.yaml

    3、创建一个deployment后查看结果:kubectl get pods,deploy,rs

    • 对用户有一个隐藏的控制器 replicaset
    • deploymen是用来管理 replicaset 与 pod

    kubectl get pod,deploy,rs

    NAME READY STATUS RESTARTS AGE
    pod/tomcat-b7cf876c5-6fqq2 1/1 Running 0 117s
    pod/tomcat-b7cf876c5-p94cx 1/1 Running 0 118s
    pod/tomcat-b7cf876c5-znd2r 1/1 Running 0 117s
    
    NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
    deployment.extensions/tomcat 3 3 3 3 118s
    
    NAME DESIRED CURRENT READY AGE
    # 隐藏控制器,控制pod副本数
    
    replicaset.extensions/tomcat-b7cf876c5 3 3 3 118s

    4、查看deployment所有涉及字段

    kubectl edit deployment/tomcat

    ------------------------------------------------
    apiVersion: extensions/v1beta1
    kind: Deployment
    metadata:
      annotations:
        deployment.kubernetes.io/revision: "1"
        kubectl.kubernetes.io/last-applied-configuration: |
      creationTimestamp: 2019-08-27T02:09:45Z
      generation: 1
      labels:
        app: tomcat
      name: tomcat
      namespace: default
      resourceVersion: "141715"
      selfLink: /apis/extensions/v1beta1/namespaces/default/deployments/tomcat
      uid: bd75f48e-c86f-11e9-9db0-000c292e28d6
    spec:
      progressDeadlineSeconds: 600
      # 副本设定
      replicas: 3
      revisionHistoryLimit: 2
      # 标签管理
      selector:
        matchLabels:
          app: tomcat
      # 滚动更新
      strategy:
        rollingUpdate:
          maxSurge: 25%
          maxUnavailable: 25%
        type: RollingUpdate
      template:
        metadata:
          creationTimestamp: null
          labels:
            app: tomcat
        spec:
          # 容器定义
          containers:
          - image: tomcat
            imagePullPolicy: Always
            name: tomcat
            ports:
            - containerPort: 8080
              protocol: TCP
            resources: {}
            terminationMessagePath: /dev/termination-log
            terminationMessagePolicy: File
          dnsPolicy: ClusterFirst
          imagePullSecrets:
          - name: registry-pull-secret
          restartPolicy: Always
          schedulerName: default-scheduler
          securityContext: {}
          terminationGracePeriodSeconds: 30
    status:
      availableReplicas: 3
      conditions:
      - lastTransitionTime: 2019-08-27T02:11:23Z
        lastUpdateTime: 2019-08-27T02:11:23Z
        message: Deployment has minimum availability.
        reason: MinimumReplicasAvailable
        status: "True"
        type: Available
      - lastTransitionTime: 2019-08-27T02:09:45Z
        lastUpdateTime: 2019-08-27T02:11:23Z
        message: ReplicaSet "tomcat-b7cf876c5" has successfully progressed.
        reason: NewReplicaSetAvailable
        status: "True"
        type: Progressing
      observedGeneration: 1
      readyReplicas: 3
      replicas: 3
      updatedReplicas: 3
    ------------------------------------------------
  • 相关阅读:
    王钿《淡逻辑设计的学习》
    格雷码
    perl中 数组 和 列表的区别!
    FPGA建立时间(setup time)&保持时间(hold time)&竞争和冒险&毛刺
    Verilog三段式状态机描述
    [转]Unit Testing 101: Are You Testing Your JavaScript?
    [JavaScript]Jasmine中如何选择只运行部分Cases
    Java编程中推荐的Singleton模式
    [转]如何在Intellij中使用JsTestDriver做Javascript的Unit Testing
    [Groovy]Test with Spock
  • 原文地址:https://www.cnblogs.com/xiangsikai/p/11424015.html
Copyright © 2011-2022 走看看