K8S/ hpa分享

在 Kubernetes 中,HorizontalPodAutoscaler 自动更新工作负载资源 (例如 Deployment 或者 StatefulSet), 目的是自动扩缩工作负载以满足需求。

hpa的使用本身还是很简单的

示例如下:

官网示例

yaml 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  name: php-apache
spec:
  selector:
    matchLabels:
      run: php-apache
  template:
    metadata:
      labels:
        run: php-apache
    spec:
      containers:
      - name: php-apache
        image: registry.k8s.io/hpa-example
        ports:
        - containerPort: 80
        resources:
          limits:
            cpu: 500m
          requests:
            cpu: 200m
---
apiVersion: v1
kind: Service
metadata:
  name: php-apache
  labels:
    run: php-apache
spec:
  ports:
  - port: 80
  selector:
    run: php-apache
bash 复制代码
kubectl apply -f https://k8s.io/examples/application/php-apache.yaml

运行起来后,

bash 复制代码
kubectl autoscale deployment php-apache --cpu-percent=50 --min=1 --max=10

--cpu-percent就是cpu使用率指标,超过就会自动扩容副本,更加详细的说明看官网对这里的算法解释
**官网说明**

增加负载去测试验证:

bash 复制代码
kubectl run -i --tty load-generator --rm --image=busybox:1.28 --restart=Never -- /bin/sh -c "while sleep 0.01; do wget -q -O- http://php-apache; done"

观察:

bash 复制代码
kubectl get hpa php-apache --watch

停止负载后,pod会伸缩回来

相关推荐
邂逅星河浪漫3 小时前
【Docker + DockerCompose】安装步骤+演示
docker·容器·docker-compose
std860218 小时前
容器化入门:一文掌握Docker安装与核心概念
运维·docker·容器
2501_920047038 小时前
k8s-部署单master节点
云原生·容器·kubernetes
可爱的小小小狼10 小时前
k8s的kube-prosy
云原生·容器·kubernetes
腾讯数据架构师10 小时前
k8s 兼容摩尔线程
人工智能·云原生·容器·kubernetes·cube-studio
可爱的小小小狼10 小时前
k8s中的schedule
云原生·容器·kubernetes
桥边驿语人12 小时前
Docker 容器无法访问外网的问题排查与解决指南
运维·docker·容器
阿里云云原生13 小时前
阿里云发布《AI 原生应用架构白皮书》
云原生
阿里云云原生13 小时前
阿里云 AI 中间件重磅发布,打通 AI 应用落地“最后一公里”
云原生·rocketmq
阿里云云原生15 小时前
从“看得见”到“能决策”:Operation Intelligence 重构企业智能运维新范式
云原生