Kubernetes如何控制复制?

Kubernetes如何控制复制?,kubernetes,configuration,replication,kubernetes-pod,Kubernetes,Configuration,Replication,Kubernetes Pod,我很好奇Kubernetes是如何控制复制的。例如,我的配置yaml文件指定我需要三个pod,每个pod都有一个Nginx服务器(从这里--) 库伯内特斯如何知道何时关闭吊舱,何时启动更多吊舱?例如,对于高流量负载,我想启动另一个pod,但我不确定如何在YAML文件中配置它,因此我想知道Kubernetes是否有一些幕后魔法可以为您实现这一点。Kubernetes在这里没有魔法-从您的配置来看,它根本不知道也不改变副本的数量。 您正在寻找的概念称为自动缩放器。它使用集群中的指标(也需要启用/安装

我很好奇Kubernetes是如何控制复制的。例如,我的配置yaml文件指定我需要三个pod,每个pod都有一个Nginx服务器(从这里--)


库伯内特斯如何知道何时关闭吊舱,何时启动更多吊舱?例如,对于高流量负载,我想启动另一个pod,但我不确定如何在YAML文件中配置它,因此我想知道Kubernetes是否有一些幕后魔法可以为您实现这一点。

Kubernetes在这里没有魔法-从您的配置来看,它根本不知道也不改变副本的数量。 您正在寻找的概念称为自动缩放器。它使用集群中的指标(也需要启用/安装),然后可以决定是否必须放大或缩小POD,并且实际上会更改部署或复制控制器中副本的数量。(请使用部署控制器,而不是复制控制器,后者不支持应用程序的滚动更新。)
您可以在此处阅读有关autoscaler的更多信息:

您可以将HorizontalPodAutoscaler与部署一起使用,如下所示。这将根据目标CPU利用率以声明方式自动缩放pod

apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: $DEPLOY_NAME
spec:
  replicas: 2
  template:
    metadata:
      labels:
        app: $DEPLOY_NAME
    spec:
      containers:
      - name: $DEPLOY_NAME
        image: $DEPLOY_IMAGE
        imagePullPolicy: Always
        resources:
          requests:
            cpu: "0.2"
            memory: 256Mi            
          limits:
            cpu: "1"
            memory: 1024Mi
---
apiVersion: v1
kind: Service
metadata:
  name: $DEPLOY_NAME
spec:
  selector:
    app: $DEPLOY_NAME
  ports:
      - port: 8080
  type: ClusterIP
---
apiVersion: autoscaling/v1
kind: HorizontalPodAutoscaler
metadata:
  name: $DEPLOY_NAME
  namespace: $K8S_NAMESPACE
spec:
  scaleTargetRef:
    apiVersion: apps/v1beta1
    kind: Deployment
    name: $DEPLOY_NAME
  minReplicas: 2
  maxReplicas: 6
  targetCPUUtilizationPercentage: 60
apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: $DEPLOY_NAME
spec:
  replicas: 2
  template:
    metadata:
      labels:
        app: $DEPLOY_NAME
    spec:
      containers:
      - name: $DEPLOY_NAME
        image: $DEPLOY_IMAGE
        imagePullPolicy: Always
        resources:
          requests:
            cpu: "0.2"
            memory: 256Mi            
          limits:
            cpu: "1"
            memory: 1024Mi
---
apiVersion: v1
kind: Service
metadata:
  name: $DEPLOY_NAME
spec:
  selector:
    app: $DEPLOY_NAME
  ports:
      - port: 8080
  type: ClusterIP
---
apiVersion: autoscaling/v1
kind: HorizontalPodAutoscaler
metadata:
  name: $DEPLOY_NAME
  namespace: $K8S_NAMESPACE
spec:
  scaleTargetRef:
    apiVersion: apps/v1beta1
    kind: Deployment
    name: $DEPLOY_NAME
  minReplicas: 2
  maxReplicas: 6
  targetCPUUtilizationPercentage: 60