He3DB-部署集群(4)集成Prometheus Client

本文详细介绍了如何安装和配置prometheus-client-c库,涉及新参数设置、多进程集成策略,以及如何在多进程中共享指标数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、安装prometheus-client-c库

需要安装prom、promhttp两个库,其中promhttp依赖microhttd库; 安装包下载路径:

链接:https://www.ecpan.cn/web/#/yunpanProxy?path=%2F%23%2Fdrive%2Foutside&data=fb07a83cb8d5fe8e7e4ce36730bb5488Wlq3edsza2&isShare=1 
提取码:BJZLBD

安装命令:

dpkg -i libprom-dev-0.1.3-Linux.debapt 
install libmicrohttpd-dev  
# 若出错  
apt --fix-broken install
dpkg -i libpromhttp-dev-0.1.3-Linux.deb

二、参数说明

新增两个GUC参数:

he3db_prom_enable

表示是否开启采集指标,取值true(开启)|false(关闭),默认true

he3db_prometheus_port

metrics指标端口,取值1-65535

三、集成说明

因prometheus-client-c库申请内存资源为进程私有,不支持使用共享内存, 所以多进程无法直接使用一个客户端,He3DB在集成时使用单独子进程注册采集器、开启metrics http服务,并采用共享队列的方式实现多进程使用同一个客户端,具体如下::
(1)首先为队列申请共享内存,并初始化队列值,队列主要用于暂存采集的指标值, 目前定义了double类型的队列,如要新增其他数据类型的指标采集,则需要再次申请共享内存并新建一个共享队列; (详见代码prometheusclient.c: He3dbPrometheusClientSize、He3dbPrometheusClientInit)
(2)初始化prometheus采集器并注册需要采集的metric, 如新增一个指标需要再注册一个metric;prometheus-client-c库支持三种类型指标的采集: counter、gauge、 histogram,建议除histogram类型指标外, 其他采用扩展pg_exporter的方式收集指标(可参考pr add view、testcase); (详见代码 prometheusclient.c:init)
(3)在指标生产的代码中调用入队方法,将指标推送到共享队列(注意添加he3db_prom_enable的判断,true时再推送指标), 并在PrometheusClientMain的循环中添加消费队列的方法,消费队列值插入metric采集器中。(详见代码prometheusclient.c:PrometheusClientMain)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值