K8s 的 ResourceList进行加减操作工具类

背景

需要计算STS需要的资源并且扩容NameSpace的resourcequotas

方法

在Kubernetes Go客户端中,你可以使用一些基本的算术运算符来对ResourceList进行加减操作。ResourceList中的值是以v1.ResourceList类型表示的,这个类型实际上是一个map,其中key是v1.ResourceName,value是resource.Quantity。你可以通过操作map中的值来进行加减乘除操作。

代码如下:

go 复制代码
package k8s

import (
	v1 "k8s.io/api/core/v1"
	"k8s.io/apimachinery/pkg/api/resource"
)

// CalResourceList函数用于计算两个ResourceList的资源总量。
// 参数data1和data2分别是两个ResourceList,calFunc是用于计算资源总量的函数。
// 返回值res是一个新的ResourceList,包含了两个ResourceList中各个资源的总量。
func CalResourceList(data1 v1.ResourceList, data2 v1.ResourceList, calFunc func(resource.Quantity, resource.Quantity) resource.Quantity) (res v1.ResourceList) {
	res = v1.ResourceList{}
	res[v1.ResourceCPU] = calFunc(*data1.Cpu(), *data2.Cpu())         // 计算CPU总量
	res[v1.ResourceMemory] = calFunc(*data1.Memory(), *data2.Memory()) // 计算内存总量
	res[v1.ResourceStorage] = calFunc(*data1.Storage(), *data2.Storage()) // 计算存储总量
	return
}

// AddResourceList函数用于将两个ResourceList相加。
// 参数data1和data2分别是待相加的两个ResourceList。
// 返回值是一个新的ResourceList,包含了两个ResourceList中各个资源的总量。
func AddResourceList(data1 v1.ResourceList, data2 v1.ResourceList) v1.ResourceList {
	return CalResourceList(data1, data2, func(q1, q2 resource.Quantity) resource.Quantity {
		q1.Add(q2) // 将q2加到q1上
		return q1
	})
}

// SubResourceList函数用于将两个ResourceList相减。
// 参数data1和data2分别是待相减的两个ResourceList。
// 返回值是一个新的ResourceList,包含了两个ResourceList中各个资源的差值。
func SubResourceList(data1 v1.ResourceList, data2 v1.ResourceList) v1.ResourceList {
	return CalResourceList(data1, data2, func(q1, q2 resource.Quantity) resource.Quantity {
		q1.Sub(q2) // 将q2从q1中减去
		return q1
	})
}

基于上面的方法, 计算STS的配额用量

go 复制代码
func GetStsResourceQuota(sts *appsv1.StatefulSet) (reqRes v1.ResourceList, limitRes v1.ResourceList) {
	// 总得
	reqRes = v1.ResourceList{}
	limitRes = v1.ResourceList{}

	// 单个副本
	sinReq := v1.ResourceList{}
	sinLim := v1.ResourceList{}
	for _, container := range sts.Spec.Template.Spec.Containers {
		requests := container.Resources.Requests
		limits := container.Resources.Limits
		sinReq = k8sutils.AddResourceList(sinReq, requests)
		sinLim = k8sutils.AddResourceList(sinLim, limits)
	}

	// 存储
	for _, vol := range sts.Spec.VolumeClaimTemplates {
		sinReq = k8sutils.AddResourceList(sinReq, vol.Spec.Resources.Requests)
		sinLim = k8sutils.AddResourceList(sinLim, vol.Spec.Resources.Limits)
	}
	// 总的副本
	for i := 0; i < int(*sts.Spec.Replicas); i++ {
		reqRes = k8sutils.AddResourceList(reqRes, sinReq)
		limitRes = k8sutils.AddResourceList(limitRes, sinLim)
	}
	return
}
相关推荐
楼田莉子2 分钟前
高并发内存池项目:内存池性能分析及其优化
开发语言·c++·后端·学习
是翔仔呐8 分钟前
第6章 UART串口通信!掌握单片机与外界的双向数据通道,实现跨设备交互
c语言·开发语言·单片机·嵌入式硬件·gitee
带娃的IT创业者10 分钟前
从本地开发到 PyPI发布:WeClaw 的 Python 包标准化之旅
开发语言·python
qiumingxun10 分钟前
【Go】Go语言基础学习(Go安装配置、基础语法)
服务器·学习·golang
2201_7586426411 分钟前
自定义内存检测工具
开发语言·c++·算法
吠品14 分钟前
QEMU Windows虚拟机NAT网络配置指南:实现IP自动获取与外部访问
开发语言·php
fpcc14 分钟前
C++编程实践—操作系统调优和内核旁支
开发语言·c++
不想看见40420 分钟前
QAbstractItemModel 自定义实现--Qt 模型 / 视图(MVC)
开发语言·qt·mvc
不想看见40422 分钟前
Qt 事件循环与事件过滤器讲解【详细】
开发语言·数据库·qt
FL162386312922 分钟前
基于yolov8+pyqt5实现的水尺图像识别与水深计算系统
开发语言·qt·yolo