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