如何自定义hpa metric server

本文详细介绍了如何基于custom-metrics-apiserver项目创建自己的metric server,包括实现关键接口、部署、创建Service和APIService、系统权限配置,并通过创建HPA验证其成功。同时,文章还探讨了Kubernetes Custom Metrics的机制以及apiserver的角色。
摘要由CSDN通过智能技术生成

本章重点: 如何基于 custom-metrics-apiserver 项目,打造自己的 metric server

1. custom-metrics-apiserver简介

项目地址: https://github.com/kubernetes-sigs/custom-metrics-apiserver/tree/master

自定义metric server,具体来说需要做以下几个事情:

(1)实现 custom-metrics-apiserver 的 三个接口,如下:

type CustomMetricsProvider interface {
    // 定义metric。 例如 pod_cpu_used_1m
    ListAllMetrics() []CustomMetricInfo
  
  // 如何根据 metric的信息,得到具体的值
    GetMetricByName(name types.NamespacedName, info CustomMetricInfo) (*custom_metrics.MetricValue, error)
    
    // 如何根据 metric selector的信息,得到具体的值
    GetMetricBySelector(namespace string, selector labels.Selector, info CustomMetricInfo) (*custom_metrics.MetricValueList, error)
}

GetMetricBySelectorm, GetMetricByName 在reststorage.go被使用。

https://github.com/kubernetes-sigs/custom-metrics-apiserver/blob/master/pkg/registry/custom_metrics/reststorage.go

restful接口在installer.go中被定义。

https://github.com/kubernetes-sigs/custom-metrics-apiserver/blob/master/pkg/apiserver/installer/installer.go

总的来说,可以认为

(1)基于custom-metrics-apiserver这个项目,你只要实现上述三个接口就行。其他的事情这个包在你new provider的时候都自动实现了。

(2)ListAllMetrics 注册了所有的Metric,让api-server 知道有哪些自定义metric。

(3)GetMetricByName, GetMetr

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值