kubernetes中如何实现Pod自动扩容与缩容

小编给大家分享一下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文件创建

  1. apiVersion: autoscaling/v1

  2. kind: HorizontalPodAutoscaler

  3. metadata:

  4.   name: php-apache

  5. spec:

  6.   scaleTargetRef:

  7.     apiVersion: apps/v1beta1

  8.     kind: Deployment

  9.     name: php-apache

  10.   minReplicas: 1

  11.   maxReplicas: 10

  12.   targetCPUUtilizationPercentage: 50

看完了这篇文章,相信你对“kubernetes中如何实现Pod自动扩容与缩容”有了一定的了解,如果想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!