12-k8s-HPA自动扩缩容

文章目录

    • 一、k8s弹性伸缩类型
    • 二、HPA原理
    • 三、metrics-server插件
    • 四、创建nginx提供负载测试
    • 五、部署HPA

master操作即可

一、k8s弹性伸缩类型

  1. Cluster-Autoscale: 集群容量(node数量)自动伸缩,跟自动化部署相关的,依赖iaas的弹性伸缩,主要用于虚拟机容器集群
  2. Vertical Pod Autoscaler: 工作负载Pod垂直(资源配置)自动伸缩,如自动计算或调整deployment的Pod模板limit/request,依赖业务历史负载指标
  3. Horizontal-Pod-Autoscaler: 工作负载Pod水平自动伸缩,如自动scale deployment的replicas,依赖业务实时负载指标

二、HPA原理

HPA在k8s中也由一个controller控制,controller会间隔循环HPA,检查每个HPA中监控的指标是否触发伸缩条件,默认的间隔时间为15s。一旦触发伸缩条件,controller会向k8s发送请求,修改伸缩对象(statefulSet、replicaController、replicaSet)子对象scale中控制pod数量的字段。k8s响应请求,修改scale结构体,然后会刷新一次伸缩对象的pod数量。伸缩对象被修改后,自然会通过list/watch机制增加或减少pod数量,达到动态伸缩的目的。

三、metrics-server插件

  1. 概念:用来收集K8s集群中的资源使用情况。每15秒进行一次数据采集(可以通过-horizontal-pod-autoscaler-sync-period修改查询metrics的资源使用情况),占用资源少,每个Node占用1 mili core的CPU和2 MB内存,目前只能对CPU和内存进行监控

  2. 下载yaml文件:wget https://github.com/kubernetes-sigs/metrics-server/releases/download/v0.6.1/components.yaml

  3. 修改yaml文件配置:vi components.yaml

    1. 注释- --kubelet-preferred-address-types=InternalIP,ExternalIP,Hostname在底下添加- --kubelet-preferred-address-types=InternalIP,Hostname,InternalDNS,ExternalDNS,ExternalIP    # node address类型的优先权设置- --kubelet-insecure-tls    # 取消安全验证 
    2. 注释image: registry.k8s.io/metrics-server/metrics-server:v0.6.3在底下添加image: registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server:v0.6.1
    
  4. 部署:kubectl apply -f components.yaml

  5. 查看pod:kubectl get pod -n kube-system
    在这里插入图片描述

  6. 查看资源使用情况:

    1)kubectl top node
    在这里插入图片描述

    2)kubectl top pod -n kube-system

    ps:查看全部空间的命令为kubectl top pod --all-namespaces
    在这里插入图片描述

四、创建nginx提供负载测试

  1. 创建yaml:vi /opt/pod-controller.yaml

    apiVersion: apps/v1
    kind: Deployment
    metadata:name: pod-controllerlabels:controller: deploy 
    spec:replicas: 1selector:matchLabels:app: nginx-podtemplate:metadata:labels:app: nginx-podspec:containers:- name: nginximage: nginx:latestports:- name: nginx-portcontainerPort: 80protocol: TCPresources: # 要设置每个容器最低使用的CPU,不然测试不出效果requests:cpu: "0.1"
    
  2. 创建pod:kubectl apply -f /opt/pod-controller.yaml

  3. 暴露端口:kubectl expose deployment pod-controller --name=nginx-service --type=NodePort --port=80 --target-port=80

  4. 查看端口:kubectl get svc
    在这里插入图片描述

  5. 访问:http://192.168.248.11:31409/

五、部署HPA

  1. 新建pod-hpa.yaml:vi /opt/pod-hpa.yaml

    ps:也可以直接设置控制器的资源限制:kubectl autoscale deploy 控制器 --cpu-percent=3 --min=1 --max=10

    apiVersion: autoscaling/v1
    kind: HorizontalPodAutoscaler
    metadata:                                 name: pod-hpa                             # hpa的名称labels:controller: hpa                         # 给hpa打标签
    spec:minReplicas: 1                            # 缩容最小Pod数量maxReplicas: 10                           # 扩容最大Pod数量targetCPUUtilizationPercentage: 3         # 为了便于测试,这里设置CPU使用率警戒线为3%scaleTargetRef:                           # 指定要控制的Deployment的信息apiVersion: apps/v1kind: Deploymentname: pod-controller
    
  2. 创建pod:kubectl apply -f /opt/pod-hpa.yaml

  3. 查看HPA: kubectl get hpa
    在这里插入图片描述

  4. 查看服务pod个数:kubectl get deploy pod-controller -o wide
    在这里插入图片描述

  5. 使用postman测压工具不断访问:http://192.168.248.11:31409/
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/108814.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

户外运动盛行,运动品牌如何利用软文推广脱颖而出?

全民健康意识的提升和城市居民对亲近自然的渴望带来户外运动的盛行,这也使运动品牌的市场保持强劲发展势头,那么在激烈的市场竞争中,运动品牌应该如何脱颖而出呢?下面就让媒介盒子告诉你! 一、 分享户外运动干货 用户…

YAPI介绍及Docker Compose部署指南

我们团队的项目最初前后端是同一个开发人员在做,因此并不存在提供详细接口文档等问题。随着项目的不断迭代,团队规模逐渐扩大,我们决定将前后端分开,专门由专业的前端和后端人员进行开发工作。然而,这样的改变也带来了…

Ubuntu:ESP-IDF 开发环境配置【保姆级】

物联网开发学习笔记——目录索引 参考官网:ESP-IDF 物联网开发框架 | 乐鑫科技 ESP-IDF 是乐鑫官方推出的物联网开发框架,支持 Windows、Linux 和 macOS 操作系统。适用于 ESP32、ESP32-S、ESP32-C 和 ESP32-H 系列 SoC。它基于 C/C 语言提供了一个自给…

力扣每日一题45:跳跃游戏

题目描述&#xff1a; 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说&#xff0c;如果你在 nums[i] 处&#xff0c;你可以跳转到任意 nums[i j] 处: 0 < j < nums[i] i j < n 返…

Python:if判断--综合案例练习:石头剪刀布

1、需求分析 首先注意点&#xff1a;先用文字写整体逻辑思路&#xff0c;把自己看作是游戏规则制定者&#xff0c;想想我要怎么样赢&#xff0c;怎么样输&#xff0c;把自己带入进去思考。----------先从简单的&#xff0c;大体的思路写&#xff0c;之后再细化&#xff0c;哪种…

华为数通方向HCIP-DataCom H12-831题库(单选题:281-300)

第281题 如图所示,某工程师利用4台路由器进行网络互通测试,其中R1、R2、R3部署OSPF (Area0)实现网络互通,R2、R3、R4部署IS-IS(均部署为Level-2路由器)实现网络互通,现在该工程师在R1的OSPF进程中引入直连路由,在R2的IS-IS进程中引入OSPF路由,则以下关于该场景的描述,正…

CUDA学习笔记3——图像卷积实现

分别采用GPU、CPU对图像进行sobel滤波处理 #include <stdio.h> #include "cuda_runtime.h" #include "device_launch_parameters.h" #include<math.h> #include <malloc.h> #include <opencv2/opencv.hpp>#include <stdlib.h…

c#删除数组中符合条件的元素

错误写法 List<int> list new List<int>() { 1, 2, 3, 4 }; for (int i 0; i < sz; i){if (i 1 || i 2)list.RemoveAt(i);}在迭代过程中删除数组元素会有很大的问题&#xff0c;例如删除后位置移动&#xff0c;导致不该被删除的元素被删除。还可能导致数组…

点云从入门到精通技术详解100篇-基于点云数据的奶牛体型评定指标自动测量关键技术研究

目录 前言 国内外研究现状 奶牛体型评定现状 奶牛体型评定指标测量现状 存在问题分

这应该是关于回归模型最全的总结了(附原理+代码)

本文将继续修炼回归模型算法&#xff0c;并总结了一些常用的除线性回归模型之外的模型&#xff0c;其中包括一些单模型及集成学习器。 保序回归、多项式回归、多输出回归、多输出K近邻回归、决策树回归、多输出决策树回归、AdaBoost回归、梯度提升决策树回归、人工神经网络、随…

Windows:VS Code IDE安装ESP-IDF【保姆级】

物联网开发学习笔记——目录索引 Visual Studio Code&#xff08;简称“VS Code”&#xff09;是Microsoft向开发者们提供的一款真正的跨平台编辑器。 参考&#xff1a; VS Code官网&#xff1a;Visual Studio Code - Code Editing. Redefined 乐鑫官网&#xff1a;ESP-IDF…

Spark 的主要组件及任务分工

Spark 是一个开源的分布式计算框架&#xff0c;旨在处理大规模数据集的快速计算和分析。下面是 Spark 的主要组件及其任务分工的详细介绍&#xff1a; Driver&#xff08;驱动器&#xff09;&#xff1a;【任务调度】 负责整个 Spark 应用程序的执行和协调。解析用户程序&#…

Python 爬虫实战之爬淘宝商品并做数据分析

前言 是这样的&#xff0c;之前接了一个金主的单子&#xff0c;他想在淘宝开个小鱼零食的网店&#xff0c;想对目前这个市场上的商品做一些分析&#xff0c;本来手动去做统计和分析也是可以的&#xff0c;这些信息都是对外展示的&#xff0c;只是手动比较麻烦&#xff0c;所以…

华为云云耀云服务器L实例评测|windows系统3389防爆破之安全加固教程

为什么要选择华为云云耀云服务器L实例&#xff1a; 华为云在全国范围内建立了多个数据中心&#xff0c;这些数据中心之间相互冗余&#xff0c;以确保高可靠性和可用性&#xff0c;用户可以选择最适合的区域来部署应用程序&#xff0c;以实现更好的性能和延迟。 相对于传统的物…

【Linux环境搭建】五、Linux(CentOS7)编译源码安装Subversion

Subversion&#xff08;简称为SVN&#xff09;是一种版本控制系统&#xff0c;能够管理和跟踪项目开发中的代码变化。Subversion最初由CollabNet公司开发&#xff0c;现已成为Apache软件基金会的顶级项目之一。 Subversion使用一个中央仓库来存储所有项目文件和历史记录。开发人…

【Java 进阶篇】深入理解 JavaScript DOM Node 对象

在前端开发中&#xff0c;与HTML文档进行交互是一项基本任务。文档对象模型&#xff08;Document Object Model&#xff0c;简称DOM&#xff09;为开发者提供了一种以编程方式访问和操作HTML文档的方式。DOM的核心是节点&#xff08;Node&#xff09;对象&#xff0c;它代表了文…

各种语言【Python,Java,Go,Pascal,C++】不解压直接读取压缩包【rar,zip,7z,gz,tar,z...】中文本行

文章目录 &#xff08;零&#xff09;前言&#xff08;一&#xff09;【ZIP】格式&#xff08;1.1&#xff09;Python ⭐️&#xff08;1.2&#xff09;Java ⭐️&#xff08;1.3&#xff09;Golang ⭐️&#xff08;1.4&#xff09;Pascal&#xff08;1.4.1&#xff09;Lazaru…

MySQL需要了解的常用命令

目录 和mysql相关的Shel命令mysql中常用命令获得mysql元数据命令快捷命令mysqladmin常用命令 1、MySQL 相关的 shell 命令 1)启动MySQL: systemctl start mysqld 该命令用于启动MySQL服务器 systemctl是linux系统中用于管理系统服务的命令start表示启动服务mysqld则是服务…

CentOS(3)——CentOS7开放端口

目录 一、简介 二、使用firewall ①查看防火墙状态 ②查看当前已开放的端口 ③打开端口 ④重启防火墙 ⑤查看该端口是否已经运行 一、简介 在用虚拟机搭建Gitlab的过程中用到了8989端口&#xff0c;因此本篇文章用于记录如何在CenOS7系统中主动打开端口 二、使用firewal…

c++读取inf文件,判断版本是否一致

在驱动安装时&#xff0c;通过inf文件安装&#xff0c;碰到有些驱动包中可能有多个inf文件&#xff0c;不知道选择哪一个来安装。但一个个打开&#xff0c;会发现它们的版本其实好像不一样。因此想到读取每一个inf文件中的版本信息&#xff0c;与自己提前决定好的版本号相比较&…