【prometheus】入门+实习需求实战
说明:
感冒了,写点总结不浪费时间,声明不会扯出来任何的私有代码,毕竟要保密,只会讲prometheus的官方有的,以及那些开源的代码方法,例如prometheus客户端代方法,代码
工作中遇到了metrics相关任务,之前没有学过,趁着任务需求,就学了一点
prometheus 有四种指标的,但是没有一种指标类型可以是数组类型
而我的需求就是很需要这个数组类型
但是这四种指标类型没有数组类型是很合理的,毕竟数组怎么当指标呢?
不过话说回来,即便当前的任务对我很难(毕竟一无所知对prometheus),但是该完成任务还要完成任务,学就完事了
任务:
给指标添加——事项id,为了dis
简单分析一下不难发现,我们目前的指标有
个人效能——就是事项,例如bug数量,需求数量,任务数量等
代码贡献——例如代码增加/减少行数,文件修改数目,commit个数
项目报表——项目纬度的功能点,bug,task,requirement 个数等
那么以个人效能来说,单位是人,这个人有什么指标呢?就是例如有一个bug总数,这个指标对应的事项id是什么?
忘了说了事项——就是需求(requirement),任务(task),缺陷(bug)
所以这个bug总数指标对应的事项id不可能是一个,而是很多个,因为bug总数,代表的是所有bug,每个bug都是一个事项,都有一个事项id,所以,这个bug总数是几,他对应的事项id就有几个,就是一个id数组
首先先吐槽一下,这个任务真的挺鸡肋的,为了dis,就是比较
但是又不得不说,他有难度,是个男点,毕竟四个指标类型都没有数组
解决方案:
方案一:直接写一个prometheus对象,collect出来指标——id数组,返回,结果返回方法没有这种指标类型
//注册一个指标对象
registry := prometheus.NewRegistry()
registry.MustRegister(对象(例如a))
func NewMetricWithTimestamp(t time.Time, m Metric) Metric
prometheus.NewMetricWithTimestamp(
t time.Time,
MustNewConstMetric(desc *Desc, valueType ValueType, value float64, labelValues ...string) Metric,
)
// 对就是 MustNewConstMetric 方法里的第三个参数只能接受float64类型的
// 另外就是去找了其他类型的,都没有找到数组类型的
a.Register.Add(http.MethodGet, "/url", func(w http.ResponseWriter, r *http.Request) {
promhttp.HandlerFor(registry, promhttp.HandlerOpts{}).ServeHTTP(w, r)
})
//当调用了 /url 接口,就会走这个http请求,转发到promhttp去调用collect,但是我并没有看出来是如何返回指标的,应该是NewMetricWithTimestamp 这个函数有什么操作
//但是源码只有一行:Collect(chan<- Metric),也不知道嗯干嘛的,但总之是返回了指标数据
所以方案一不行了…
方案二:
还在构建思索中
目前大体思路是这样:
能否从概念入手,指标名作为key,本来的value是float64类型的一个值,但在这中间还有一个label呢!,记录的是这个人的信息,例如人名,id,项目名,项目id,组织id。
而我在label中加一个id数组,这样就不必是指标类型了
把label中的id数组,想像成value即可,毕竟这整体还是一个指标,是一个完整的
接着在另一个项目就可以去拿到这指标,处理一下,做一下关联,存储到clickhouse,给项目a用
哦对了,讲一下背景:
整体原本的思路和逻辑是这样的,项目a,计算采集指标放在etcd,放的是每天的指标,同时有暴露接口能给项目b调用
项目a通过查询clickhouse拿到当前的指标
我曾经疑我们的mysql有几个?有一个,那怎么主从同步,怎么解决高并发,数据库崩了等等问题,然后看到了rds,原来用的是阿里云的rds云数据库服务啊,专业的事交给了专业的人去做了,clickhouse有四个
后续有进展持续更新
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!