IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> HPA集群控制器 -> 正文阅读

[PHP知识库]HPA集群控制器

Horizontal Pod Autoscaling,简称HPA,是Kubernetes中实现POD水平自动伸缩的功能,HPA可以可以基于CPU利用率或其他应用程序提供的度量指标自动缩放POD的数量

Pod水平自动伸缩特性由Kubernetes API资源和控制器实现,资源决定了控制器的行为。控制器会周期性的获取平均率,并与目标值相比较后来调整副本数量

限制

-不适合用于无法伸缩的对象,比如:DaemonSets

资源控制器创建

[root@master ~]# vim myhpa.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myweb       #集群名称
spec:
  selector:
    matchLabels:
      app: apache      #后端标签app:apache
  replicas: 1           #只有1个POD
  template:
    metadata:
      labels:
        app: apache     #标签
    spec:
      containers:
      - name: apache
        image: 192.168.1.100:5000/myos:httpd
        ports:
        - containerPort: 80       
        resources:                #计算此计算器所需的资源
          requests:               #描述所需的最小计算资源量
            cpu: 200m              #计量单位,可以看作100milli
      restartPolicy: Always

---
apiVersion: v1
kind: Service
metadata:
  name: web-service
spec:
  ports:
  
  - protocol: TCP
    port: 80
    targetPort: 80
  selector:
    app: apache
  type: ClusterIP

---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: my-app
  annotations:
    kubernetes.io/ingress.class: "nginx"
spec:
  backend:
    serviceName: web-service
    servicePort: 80

---
apiVersion: autoscaling/v1
kind: HorizontalPodAutoscaler        #HPA资源内型
metadata:
  name: myweb                         #HPA名称
spec:                
  minReplicas: 1                      #最小保留POD数量
  maxReplicas: 3                       #最大保留POD数量
  scaleTargetRef:
    apiVersion: apps/v1
    kind: Deployment
    name: myweb                        #监视deployment名称
  targetCPUUtilizationPercentage: 50    #CPU度量值
[root@master ~]# kubectl apply -f hpa-example.yaml
[root@master ~]# kubectl get hpa
NAME    REFERENCE          TARGETS   MINPODS   MAXPODS   REPLICAS   AGE
myweb   Deployment/myweb   0%/50%    1         3         1          15m

当容器的cpu占用超过 50% 的时候,自动扩展一个POD,依次扩展,一直到最大值

如果cpu访问不足 50% 的时候,每 300s 缩减一个 POD 节点,直到最小值时停止

访问测试可以使用镜像内提供的 info.php增加系统负载,从而查看状态信息

访问地址? http://ip.xx.xx.xx/info.php?id=1000000

[root@master ~]# kubectl get service
NAME          TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
kubernetes    ClusterIP   10.254.0.1       <none>        443/TCP        5d19h
myapache      ClusterIP   10.254.105.21    <none>        80/TCP         4d1h
myheadless    ClusterIP   None             <none>        80/TCP         3d23h
mynodeport    NodePort    10.254.207.195   <none>        80:31341/TCP   3d23h
web-service   ClusterIP   10.254.196.125   <none>        80/TCP         7m23s
[root@master ~]# kubectl get pod
NAME                     READY   STATUS    RESTARTS   AGE
myweb-7f89fc7b66-99xfx   1/1     Running   0          115s
myweb-7f89fc7b66-lvrhs   1/1     Running   0          7m29s
[root@master ~]# kubectl get hpa
NAME    REFERENCE          TARGETS   MINPODS   MAXPODS   REPLICAS   AGE
myweb   Deployment/myweb   70%/50%   1         3         2          7m34s
[root@master ~]# 
[root@master ~]# kubectl get hpa  -w #时实观看

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-09-08 10:26:21  更:2021-09-08 10:28:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:27:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码