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会伸缩回来

相关推荐
白夜易寒9 小时前
Docker学习之私有仓库(day10)
学习·docker·容器
GrapefruitCat12 小时前
Envoy 学习笔记(一)
云原生
tingting011913 小时前
k8s 1.30 安装ingress-nginx
nginx·容器·kubernetes
Mia@14 小时前
网络通信&微服务
微服务·云原生·架构
陈陈CHENCHEN15 小时前
【Kubernetes】CentOS 7 安装 Kubernetes 1.30.1
kubernetes
2201_7611990415 小时前
k8s2部署
云原生·容器·kubernetes
阿里云云原生16 小时前
Nacos 发布 MCP Registry,实现存量应用接口“0改动”升级到 MCP 协议
云原生
阿里云云原生16 小时前
Higress 开源 Remote MCP Server 托管方案,并将上线 MCP 市场
云原生
云上艺旅17 小时前
K8S学习之基础六十四:helm常用命令
学习·云原生·容器·kubernetes