小编给大家分享一下kubernetes中如何实现Pod自动扩容与缩容,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
一:简介
Kubernetes通过HPA控制器,用于实现基本CPU使用率进行自动Pod扩容和缩容的功能。HAP控制器基于Master的Kube-controller-manager服务启动参数–horizontal-pod-autoscaler-sync-period定义的时长(默认值为30s),周期性地检测目标Pod的CPU使用率,并在满足条件时对ReplicationController或Deployment中的Pod副本数量进行调整,以符合用户定义的平均Pod CPU使用率。Pod CPU使用率来源于Heapster组件,所有需要预先安装好Heapster.
二:HPA的创建
创建HPA时可以使用kubectl autoscale命令进行快速创建或者使用Yaml配置文件进行创建,在创建HPA之前,需要已经存在一个Deployment/RC对象,并且该Deployment/RC中的Pod必须定义resources.requests.cpu的资源请求值,如果不设置该值,则Heapster将无法采集到Pod的CPU使用情况,会导致HPA无法正常工作。
举例:
1.kubectl autoscale deployment php-apache –min=1 –max=10 –cpu-percent=50
2.通过yaml文件创建
-
apiVersion: autoscaling/v1
-
kind: HorizontalPodAutoscaler
-
metadata:
-
name: php-apache
-
spec:
-
scaleTargetRef:
-
apiVersion: apps/v1beta1
-
kind: Deployment
-
name: php-apache
-
minReplicas: 1
-
maxReplicas: 10
-
targetCPUUtilizationPercentage: 50
看完了这篇文章,相信你对“kubernetes中如何实现Pod自动扩容与缩容”有了一定的了解,如果想了解更多相关知识,欢迎关注云行业资讯频道,感谢各位的阅读!