ITPub博客

kubernetes实践之四十一:Pod自动扩容与缩容

原创 作者:百联达 时间:2018-05-14 15:58:54 0 删除 编辑
一:简介
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

请登录后发表评论 登录
全部评论

注册时间:2013-02-05

  • 博文量
    267
  • 访问量
    874287