【prometheus】入门+实习需求实战

news/2024/5/19 1:58:24 标签: prometheus

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有四个

后续有进展持续更新


http://www.niftyadmin.cn/n/5249297.html

相关文章

387.字符串中的第一个唯一字符 —> `size()`

解答&#xff1a; int firstUniqChar(string s) {int size s.size();// char count[26] { 0 };// error.1int count[26] { 0 };// for (int i 0; i < s.size() - 1; i) // error.2for (int i 0; i < size; i){count[s[i] - a] 1;}for (int i 0; i < size; i){…

vue使用甘特图dhtmlxgantt + gantt.addTaskLayer

效果图&#xff1a; 甘特图 官网地址 gantt安装与使用 vue版---部分功能收费 安装gantt 或 引入文件 npm install dhtmlx-gantt -save或import gantt from "/public/static/dhtmlxgantt/dhtmlxgantt.js"; import "/public/static/dhtmlxgantt/locale/local…

结构化布线系统

满足下列需求&#xff1a; 1.标准化&#xff1a;国际、国家标准。 2.实用性&#xff1a;针对实际应用的需要和特点来建设系统。 3.先进性&#xff1a;采用国际最新技术。5-10年内技术不落后。 4.开放性&#xff1a;整个系统的开放性。 5.结构化、层次化&#xff1a;易于管理和维…

iPaaS架构深入探讨

在数字化时代全面来临之际&#xff0c;企业正面临着前所未有的挑战与机遇。技术的迅猛发展与数字化转型正在彻底颠覆各行各业的格局&#xff0c;不断推动着企业迈向新的前程。然而&#xff0c;这一数字化时代亦衍生出一系列复杂而深奥的难题&#xff1a;各异系统之间数据孤岛、…

以下是一些自然语言处理(NLP)技术的例子:

以下是一些自然语言处理&#xff08;NLP&#xff09;技术的例子&#xff1a; 语音识别&#xff1a;将说话者的语音转换为文本形式&#xff0c;从而使机器能够理解和分析语音内容。 文本分类&#xff1a;将大量的文本分成不同的类别&#xff0c;例如新闻、评论、博客等。 情感…

交换排序(冒泡排序)(快速排序(1))

目录 1.交换排序 &#xff08;1&#xff09;冒泡排序 &#xff08;2&#xff09;快速排序 1.交换排序 基本思想&#xff1a;所谓交换&#xff0c;就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置&#xff0c;交换排序的特点是&#xff1a;将键值较大的…

MT5的6种挂单方式解析:如何根据交易策略选择合适的挂单

在金融市场中&#xff0c;交易策略的选择对于投资者的成功至关重要。而在外汇交易中&#xff0c;MetaTrader 5(以下简称MT5)作为一种功能强大的交易平台&#xff0c;提供了多种挂单方式&#xff0c;帮助交易者更好地执行交易策略。本文将对MT5的6种挂单方式进行详细解析&#x…

3DCAT+上汽奥迪:打造新零售汽车配置器实时云渲染解决方案

在 5G、云计算等技术飞速发展的加持下&#xff0c;云渲染技术迎来了突飞猛进的发展。在这样的背景下&#xff0c;3DCAT应运而生&#xff0c;成为了业内知名的实时云渲染服务商之一。 交互式3D实时云看车作为云渲染技术的一种使用场景&#xff0c;也逐步成为一种新的看车方式&a…