业务系统的Prometheus实践
什么是Prometheus
Prometheus(普罗米修斯)是古希腊的一个神明,名字的意思是先见之明。从它的名字可以看出,Prometheus是做先见之明的监控告警用途。
官网描述为Frommetricstoinsight,用指标洞察系统。
Prometheus其实就是一个数据监控解决方案,它能帮你简单快速地搭建起一套可视化的监控系统。
例如研发比较关注机器的CPU、内存、硬盘,产品和运营比较关注运营层面的指标,例如新增用户数,日活等,都可以通过Prometheus和grafana简单,直观化展示。
例如下图JVM的监控。
业务实践背景
公司某个业务需要n个评审专家对同一批n张业务报表批量签字。3方签字接口只有支持单个报表签字,所以需要nn次,单次签字逻辑复杂,流程较长,所有后台用线程池做了异步化。
签字作为业务的核心节点,不能有故障。所以怎么监控线程池的关键指标,实现动态调整参数,当任务数量过多告警,是一个需要解决的痛点。
我们通过Prometheus自定义线程池的指标,grafana展示,apollo动态调整线程池的变量,实现弹性扩展。实践线程池参数动态更新
通过接入apollo配置,当检测到线程池的配置变化时,重新设置:核心线程数最大线程数修改线程空闲时间ComponentpublicclassApolloRefreshConfig{ResourceprivateRefreshScoperefreshSResourceprivateApplicationContextapplicationCResourceprivateThreadPoolExecutorexecutorSApolloConfigChangeListenerpublicvoidonChange(ConfigChangeEventchangeEvent){applicationContext。publishEvent(newEnvironmentChangeEvent(changeEvent。changedKeys()));refreshScope。refreshAll();刷新变量asyncRequestTaskConfigChange(changeEvent。changedKeys());}privatevoidasyncRequestTaskConfigChange(SetStringchangedKeys){apollo变更的是线程池变量if(changedKeys。contains(EvaluationProcessAsyncRequestTaskConfig。ASYNCREQUESTTASKCHANGEFLAGKEY)){核心线程数IntegercorePoolSizeOldexecutorService。getCorePoolSize();if(!corePoolSize。equals(corePoolSizeOld)){executorService。setCorePoolSize(corePoolSize);}最大线程数IntegermaximumPoolSizeOldexecutorService。getMaximumPoolSize();if(!maximumPoolSize。equals(maximumPoolSizeOld)){executorService。setMaximumPoolSize(maximumPoolSize);}修改线程空闲时间LongkeepAliveTimeOldexecutorService。getKeepAliveTime(TimeUnit。MINUTES);if(!keepAliveTime。equals(keepAliveTimeOld)){executorService。setKeepAliveTime(keepAliveTime,TimeUnit。MINUTES);}}}}线程池指标上报
在springboot版本2。X版本以后,使用Prometheus进行监控,只需引入SpringBootActuator相关的jar,就可以简单集成,然后我们就可以自定义业务指标,上报Prometheus了dependencygroupIdcn。gov。zcy。bootgroupIdspringbootstarteractuatorartifactIddependency
Prometheus中的核心类io。micrometer。core。instrument。MeterRegistry中可以定制各种业务指标,也有封装的例如计数类Counter,这里引用一个Gauge只定义的指标ComponentpublicclassMonitorFactory{ResourceprivateMeterRegistrymeterRResourceprivateThreadPoolExecutorthreadPoolEprivateThreadPoolSizeMonitorthreadPoolSizeMonitornewThreadPoolSizeMonitor(threadPoolExecutor);classThreadPoolSizeMonitorimplementsToDoubleFunction{privateThreadPoolE计数privateAtomicDoublemonitornewAtomicDouble(0);publicObjectgetMonitor(){}publicThreadPoolSizeMonitor(ThreadPoolExecutorexecutor){this。}OverridepublicdoubleapplyAsDouble(Objecto){monitor。set(executor。getPoolSize());returnmonitor。get();}}上报指标,初始化时注册指标PostConstructpublicvoidmonitorThreadPool(){当前存活线程数Gauge。builder(ReportBatchSignPoolpoolSizeMonitor,threadPoolSizeMonitor。getMonitor(),threadPoolSizeMonitor)。register(meterRegistry);当前活跃(忙碌)线程数核心存活线程数提交的任务数执行完毕的任务数任务队列积压监控}1分钟更新一次指标数据Scheduled(cron001?)publicvoidpublishWatcher(){threadPoolSizeMonitor。applyAsDouble(null);}}Prometheus指标展示
用Prometheusquering语句查询出具体数值最后一列展示向量结果16,查询语法如下
https:prometheus。iodocsprometheuslatestqueryingbasics
grafana可视化展示
告警配置
grafana配置告警,配置具体的通知信息,触发规则,告警的通知渠道参考官方文档
https:grafana。comdocsgrafanalatestalerting
通知到叮叮告警群总结
本文介绍了研发人员通过配置Prometheus自定义的业务指标,实现监控告警完整链路的大致的流程。大家也可以定制化除了系统指标(例如CPU、JVM、IO等)外,梳理出自己系统的核心业务,添加告警,增强系统的稳定性,做到未雨绸缪,防患于未然。参考文献
Prometheus官方文档(https:prometheus。iodocsintroductionoverview)
grafana告警文档(https:grafana。comdocsgrafanalatestalerting)
作者:后青
来源:微信公众号:政采云技术
出处:https:mp。weixin。qq。comsdNWkBR30LZHSs9lj6qFw
天津银行上海分行被罚款710万!涉十四宗罪7月29日消息,中国银保监会上海监管局官网显示,天津银行股份有限公司上海分行(下称天津银行上海分行)因十四宗罪被罚款710万元。具体来看,该分行的主要违法违规行为包括以贷……
壮观的开幕式标志着2022年卡塔尔世界杯的开始2022年卡塔尔世界杯在AlBayt体育场举行的揭幕战中,厄瓜多尔队与东道主卡塔尔队取得了胜利开局在一场令人惊叹的开幕式后开始了。有67372人参加了A组的比赛,由于恩纳……
经合组织下调2023年全球经济增长预期至2。2经济合作与发展组织(经合组织)26日发布中期经济展望报告说,全球经济放缓程度超过预期,预计2022年增速仅为3,2023年将进一步放缓至2。2,低于今年6月预测的2。8。……
烟戒了,就不会得肺癌了?研究发现,在这个年纪前戒烟,损害小点抽烟会伤肺,会增加肺癌风险这已经是一个老生常谈,都快被说烂的问题。连烟厂都很有良心的在烟盒上刻上吸烟有害健康六个大字作为警醒,但最后依然成了浪费油墨的摆设。其实肺癌只是抽烟产物……
尽力了!湖人提出威少3个选秀权交易步行者两悍将,仍惨遭拒绝自从休赛期开始,洛杉矶湖人就有传言要交易威斯布鲁克。然而,湖人管理层在寻找交易伙伴方面困难重重。目前,许多人认为步行者有兴趣得到威斯布鲁克,但他们也不愿意出高价。据悉,湖……
10位球星集体出战!谁才是国乒一哥一姐?答案即将揭晓2022年WTT澳门冠军赛将于10月19至10月23日在澳门塔石体育馆举行。该项赛事云集了目前国际乒联世界排名前30的男单、女单球员,比赛含金量甚至超过了奥运会、世锦赛。中国队……
拖沓天王的降生小嘉6岁小作预产期4月10日,我暗自庆幸熬过了清明节,期待小嘉的到来。4月10日准时见红了,心想虽然孕期各种状况,临盆还挺准时的嘛。(事实我又错了,孕期各种问题都提……
景东凤冠古茶山神仙姐姐居住的地方无量剑湖瀑布普洱市景东县的地形是两山夹一河,把边江的上游川河由北向南纵贯县境,其东边是哀牢山,西边是无量山,因此景东是中国著名的生态高地,坐拥无量山、哀牢山两条著名山脉,……
秋季胃口差,试试这几道家常菜,营养全面又好吃又不贵【豆角土豆炖排骨】材料精肋排2根,土豆2个,豆角300克,宴友食用油、冰糖2小块,老抽2大匙,姜1小块,盐,鸡精,八角2个,香叶2片,干辣椒34个,花椒适量,山奈3……
西班牙王后用链条单肩包穿出精致优雅感,值得借鉴的通勤搭配如果让我选一款通勤包,我会选链条单肩包。金属链条给包包增添了灵动美感,时尚又优雅。西班牙王后莱蒂齐亚是链条单肩包的忠实拥趸者。如何用链条单肩包穿出精致优雅感?可以参考一下……
赵俊鹏强势横扫12号种子,第三轮遭遇马来西亚一哥北京时间8月24日,2022年羽毛球世锦赛在日本东京继续进行,中国队又有一位男单闯入第三轮。面对印度名将斯里坎斯,赵俊鹏发挥出色,他以2比0横扫对手闯入第三轮。本届世锦赛……
投机的加密货币比特币、以太坊跌幅近20,FTT直接崩盘,一小时内跌幅超过30,24小时内跌超70幻想一夜暴富的加杠杆炒币者,账户里的资产瞬间灰飞烟灭。11月11日,全球第二大加密货币平……