写点什么

基于统计的预警:同环比预警实现深度剖析

  • 2020-02-06
  • 本文字数:2708 字

    阅读完需:约 9 分钟

基于统计的预警:同环比预警实现深度剖析

一、UAV 预警功能简介

UAV.Monitor 提供了对全维监控指标的预警功能,各类型的监控指标均可配置预警策略,当预警策略被触发后,可通过邮件、HTTP 调用等方式进行通知报警,并会根据预警时间频率等对报警动作进行压制。


预警分为流式预警、统计预警以及混合预警三种。


  • 流式预警会对采集到的每一个监控指标数据进行预警判断,达到实时预警的目的;

  • 统计预警是对指标在固定时间段统计值的预警,通常都是定时进行预警判定;

  • 混合预警则是将流式预警与统计预警结合进行预警。


同环比预警就属于统计预警的一种。

二、什么是同环比预警

首先介绍一下同环比的概念,同环比描述的是统计数据的增/降幅度,即某一时间段(本期)的统计结果与之前另一相同长度时间段(基期)的比较结果。同比表示的是本期与上一个同期的比较,比如今年 4 月与去年 4 月比较,今天 8 点到 9 点与昨天 8 点到 9 点比较;环比表示的是本期与上期的比较,如今年 4 月与今年 3 月比较,今天 8 点到 9 点与 7 点到 8 点比较。而同环比预警则是对一段时间内监控指标的统计结果同比上一同期(或环比上期)的增/降幅进行预警,即指标的同/环比计算结果超过了策略指定的增/降幅度则进行报警。

三、同环比预警的实现

3.1 预警策略

预警条件与动作由预警策略定义,预警策略的结构如下:


strategy  
{
"type":"",
"instances":[],
"conditions":[],
"relations":[],
"actions":[]
}
condition
{
"expressions":[]
}
复制代码


一个预警策略(strategy)包含多个预警条件(condition),condition 是最小的预警判定元,每个 condition 可包含多个表达式(Expression);预警表达式定义了单一预警条件,表达式又分为统计(stat)表达式和流式(stream)表达式两种,分别对应统计预警条件与流式预警条件;relations 中各 relation 对应各 condition 中策略表达式 Expression 的逻辑判断关系。instances 表示该预警影响的实例,actions 表示预警触发后的报警动作,type 表示预警策略的类型,type 根据包含的表达式种类分为含统计表达式的统计(stat)策略和只含流式表达式的流式(stream)策略。

3.2 同环比预警表达式定义

同环比的计算公示为:同/环比值=本期数-基期数,同/环比率=(本期数-基期数)÷基期数×100%。根据计算公式,我们需要的输入条件是:


1)需预警的指标名。


监控的各项数值型指标均可作为预警的指标,如 cpu、访问量等。


2)本期时间段与基期时间段。


由于预警是一个比较实时性的动作,所以我们把时间段限制在了 24 小时内,对于大于 24 小时比如一周或一个月的统计值或同环比,以周报或月报的形式直接统计效果更好。基期时间则根据同比周期或环比间隔计算得出。


3)指标在时间段内统计值的计算方式。


同环比比较的是指标在一段时间内的统计值,统计方式有求和、求平均等。由于 UAV 的监控历史值都存储在 opentsdb,可通过 opentsdb 自带的聚合操作进行统计值的计算。


4)预警阈值


增/降幅上限,可设置为数值型阈值或百分比阈值。


同环比预警属于统计预警,所以同环比预警表达式也是统计(stat)类型的表达式。综上,同环比预警表达式结构如下。


expression  
{
"type":"stat",
"arg":"" //预警指标
"time_from":"" //初始时间段-from
"time_to":"" //初始时间段-to
"interval":"" //环比间隔(同比则此项为空)
"unit":"" //同比周期(环比则此项为空)
"aggr":"" //统计方式
"upperLimit":"" //比值上限
"lowerLimit":"" //比值下限
}
复制代码

3.3 预警策略判定原理

预警模块通过流式条件或定时任务触发对预警表达式的判定,过程如下


1571884305168017985.jpeg


当预警策略判定被触发时,各 condition 独立进行判定,遍历其中的各个 Expression 进行判定,然后将 Expression 判定结果按 relation 定义的逻辑关系进行组合判断,若结果为 true 则将结果汇总到策略判定结果,然后整合策略判定结果进行报警。

3.4 同环比预警判定原理

同环比预警属于统计预警的一种,所以同环比的预警流程就是统计预警的预警流程,预警模块启动一个用于统计策略判定的 Timer,每分钟(因为统计表达式的时间都是以分钟为单位,所以每分钟轮询一次即可)轮询一次策略,并触发统计策略的判定。


1571884312968007796.jpeg


当策略被触发后,便会遍历各 condition 下的表达式,进行一一判定,定时任务触发表达式判定的规则如下。


1571884320428014389.jpeg


当最小判定元 condition 内只有统计表达式时,遍历判定各统计表达式,首先会判定是否是统计表达示的判定时间,同环比表达式根据属性值 time_from,time_to 和环比间隔或同比周期来确定。若不是判定时间,考虑到多个统计表达式的组合判定情况时,各表达式的判定时间可能不一致,我们会取出缓存中上次的未过期的判定结果返回。若是判定时间,则进行同环比计算判定,构造 opentsdb 查询语句调用 API 查询本期值与基期值,计算得出同/环比值(率),并与阈值进行比较得出判定结果,结果会缓存到 redis,这里也会将此 condition 的判定置为有效,因为如果 condition 里的表达式都未达到判定时间,这次判定其实是无效的。


若 condition 内既有统计表达式又有流式表达式(即为混合预警)时,统计表达式会进行正常的判定运算操作,但对于定时任务触发的流式表达式则直接返回 false,因此 condition 判定结果也为 false。


混合预警的最终判定是在流式条件触发预警策略时产生,condition 中的流式表达式的判定会正常进行,统计表达式的判定过程如下


1571884327598090488.jpeg


如果流式条件的触发时间在表达式的判定时间(误差一分钟)内,会直接从缓存获取由定时任务触发策略时计算得出的未过期的判断结果返回,返回结果便可与流式表达式的结果一同得出混合预警的结果。


判定结果返回后,会根据预警表达式信息及判定结果生成报警信息。如图


1571884335658035393.jpeg


以上便是同环比预警的完整实现过程。

四、同环比预警的应用

实时预警关注的是系统的瞬时状态,同环比预警则反映了指标的变化趋势以及与过去同期相比的波动状态。比如系统服务访问量异常检测,由于系统量可能根据时间有一定的规律性,如周一到周五访问量大,周末访问量小。若采用流式预警只能定义一个预警阈值,不能根据不同时间设置不同的预警阈值,这时可以在业务高峰时间对系统访问量指标配置按周同比预警,便可对业务访问量异常做出及时有效的报警。


有时单一的同环比预警也不足够,比如刚才的情况下,如果我们不仅关心访问量的相对波动还需要报警时的平均响应时间大于某一阈值才报警,这时就需要与流式预警进行结合预警。


同环比预警丰富了预警体系,与流式预警相结合更有助于对系统异常与业务异常的及时精确发现。


下载 UAVStack 的源码(https://github.com/uavorg)


本文转载自宜信技术学院公众号。


原文链接:http://college.creditease.cn/detail/313


2020-02-06 21:331463

评论

发布
暂无评论
发现更多内容

语料智能·知识无界:AI 多功能语料库检索平台重塑语言研究新范式

上海拔俗

ASP.NET MVC+LayUI视频上传

追逐时光者

.net 微软 layui

分享 4 款基于 .NET 开源免费、实用的文件搜索工具,效率提升利器!

追逐时光者

.net

Gin笔记二之gin.Engine和路由设置

Hunter熊

golang gin

Web3项目的外包开发

北京木奇移动技术有限公司

区块链 软件外包公司 web3开发

Web开发外包服务 - 郑州寻路科技专业团队

寻路科技

web 服务 软件外包公司

视觉智能·场景进化:AI 视频系统训练平台重塑智能视觉新范式

上海拔俗

AI智能体开发:低代码+多模态技术,让智能应用落地更高效

上海拔俗

C#实现多线程的几种方式

追逐时光者

C# .net

企业IM突围:BeeWorks如何用“超级App”终结办公软件乱局

BeeWorks

即时通讯 IM 私有化部署

智能审核·精准治理:AI 智能审核系统重塑内容风控新范式

上海拔俗

知识融合·智能涌现:知识图谱构建及智能服务系统重塑企业认知新范式

上海拔俗

由 Mybatis 源码畅谈软件设计(七):从根上理解 Mybatis 一级缓存

京东科技开发者

星光不负 码向未来 | 从 Java 后端到鸿蒙开发者:我的真实成长蜕变记

谢道韫

springboot项目集成大数据第三方dolphinscheduler调度器

刘大猫

人工智能 云计算 算法 物联网 大模型

从“走出去”到“强起来”,中国出海三强的高端攻坚战

脑极体

AI

GitHub 发布 Agent HQ:欢迎回家,智能体们

掘金安东尼

商业用LED广告牌是数字招牌

Dylan

广告 LED LED display LED显示屏 LED屏幕

纯配时效服务-双Redis集群设计

京东科技开发者

YashanDB携手共促国产数据库核心场景突破!

极客天地

Last Call!对话式 AI 和对话式人类聚集!RTE Open Day@RTE2025,10.31/11.1,北京

声网

以 NoETL 指标语义层为核心:打造可信、智能的 Data Agent 产品实践

Aloudata

数据分析 智能分析 AIAgent ChatBI 智能问数

认知计算·精准应答:AI 智能问答系统重塑知识交互新范式

上海拔俗

智界亮相中国年度车双城盛典 品牌2.0实力获专业媒体集中检验

极客天地

知识赋能·智慧涌现:大语言模型专业知识库系统重塑企业智能新范式

上海拔俗

度量绿色价值:没有指标,何谈真正的绿电直连?

西格电力

光伏发电 新能源产业 风电 绿电直连

声纹洞察·语意精准:AI 智能语音识别系统重塑人机交互新范式

上海拔俗

AI Agent是新一轮「技术泡沫」?

禅道项目管理

人工智能 AI AI Agent 禅道项目管理软件

基于Strands Agent框架的考题生成及Agent 效果评估

亚马逊云科技 (Amazon Web Services)

Web3项目的外包开发

北京木奇移动技术有限公司

区块链开发 软件外包公司 web3开发

别急着上自动化!真正聪明的企业,先选对平台再出发

Techinsight

基于统计的预警:同环比预警实现深度剖析_语言 & 开发_UAV_InfoQ精选文章