一个可扩展的报警系统Quick-Alarm

一个可扩展的报警系统Quick-Alarm

背景

平常的系统中,报警是不可缺乏的一环,目前报警方式不少,最多见的有直接打日志,微信报警,短信报警,邮件报警等;而涉及到报警,通常不可避免的须要提早设置一些基本信息,如报警方式,报警频率,报警用户,开关等;java

另一个常见的问题是通常采用的是单一的报警方式,好比无论什么类型的报警所有都用短信方式触达,而后就会发现手机时常处于被淹没的状态了,长此以往对报警短信就不会敏感了git

目标

所以咱们准备设计一个通用的报警框架github

  • 能够自由选择报警方式,
  • 支持用户自定义报警方式拓展
  • 支持动态的报警配置,
  • 支持用户自定义报警规则拓展
  • 支持报警方式自动切换规则设定
  • 支持报警方式自定义自动切换规则拓展

设计

总体来讲,报警主要能够划分为三个步骤,以下:微信

IMAGE

  • 提交报警:对外部使用者提供的接口
  • 选择报警:根据报警相关信息,选择具体的报警执行单元
  • 执行报警:实现具体的报警逻辑

从任务划分上来看,比较清晰简单,可是每一块的内容又必须能够拓展,架构

  • 选择报警:框架

    • 报警规则的制定
    • 报警规则加载器 ConfLoader
    • 报警规则变动的触发器 ConfChangeTrigger
    • 报警规则解析器
      • ConfParse : 解析文本格式报警规则为业务对象
      • AlarmSelector :根据报警规则和报警类型,选择具体报警执行器 AlarmExecute
  • 执行报警:学习

    • 线程池执行(以防止影响主业务流程)
    • AlarmExecute的动态拓展(支持用户自定义的报警器实现)
    • 实际的报警逻辑

根据上面的拆解,在应用启动的时候,就有一些事情必须去作了ui

  1. ConfLoader的选择
  2. 报警规则加载
  3. AlarmExecute的加载(包括默认的+自定义实现的)

下图显示在应用启动时,报警规则解析的相关步骤线程

应用启动.png

至于报警执行器的加载就比较简单了,以下图设计

IMAGE

所以,整个的工做流程以下图

alarm-arch.jpg

任务拆解

经过前面的任务设计以后,对须要作的东西有了一个大概的脉络了,所以在正式操刀实现以前,下对整个架构进行任务拆解,看下能够具体的执行步骤能够怎么来

  • 最直接的就是设计报警执行器AlarmExecute
    • 定义基本接口
    • 制定自定义扩展规则
  • 接下来就是设计报警规则
    • 如何加载报警规则?
    • 报警规则具体的定义细则
    • 报警规则的解析:即根据报警类型来获取报警执行器
    • 报警规则动态更新支持
  • 报警线程池
    • 维护报警队列
    • 报警的计数与频率控制
  • 封装对外使用接口

因此,经过上面的分析能够看出,这个系统的结构仍是蛮简单的,整个只须要四个部分就能够搞定,其中最主要的就是前面两个了,后面将分别说明

小结

作一个东西,固然是但愿能够带来一些用处,或者能学习到什么东西,才不枉花费精力来折腾一下,那么咱们这个报警系统,究竟有什么用,或者能够从中学习到什么东西呢?

用途:

  • 支持灵活可配的报警规则,以及具体报警业务的自定义拓展
  • 目标就是统一报警的使用姿式,也就是无论什么报警,都一个姿式,可是内部能够玩出各类花样,对使用者而言就方便简洁了

学习:

抛开特有的知识点,能够抽象一些公共可用的地方,大概就下面这两点了

  • 咱们能够如何支持功能的动态可拓展
  • 线程池的使用

IV. 其余

相关博文

  1. 报警系统QuickAlarm总纲
  2. 报警系统QuickAlarm之报警执行器的设计与实现
  3. 报警系统QuickAlarm之报警规则的设定与加载
  4. 报警系统QuickAlarm之报警规则解析
  5. 报警系统QuickAlarm之频率统计及接口封装
  6. 报警系统QuickAlarm使用手册

项目

声明

尽信书则不如,已上内容,纯属一家之言,因本人能力通常,看法不全,若有问题,欢迎批评指正

扫描关注,java分享

QrCode

相关文章
相关标签/搜索