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

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/28624388/viewspace-2154459/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/28624388/viewspace-2154459/

你可能感兴趣的:(kubernetes实践之四十一:Pod自动扩容与缩容)