需求背景
在大数据测试过程中,需要用到多种数据源,经常需要切换多个工具和网站;
并且数据源的配置比较分散,缺乏统一的数据源配置管理入口。因为需要一个统一的查询数据和管理配置的功能
需求分析
数据查询
- 执行查询时,需要知道数据源 id 和执行的 Query(命令或者 SQL)
- 记录每次查询,方便后续溯源;同时也要设置每种数据源慢查询阈值,发送告警信息
数据源配置管理
- 敏感信息需要加密(rsa 不对称加密,不能使用哈希,因为后端还要解密得到明文)
- 每个项目数据隔离
- 权限控制(管理员才能 CRUD 配置)
设计分析
数据查询
- 执行查询时,不管什么数据源,大致上都会经过几个特定的步骤,读取配置,创建连接,校验 query 合法性,执行 query,关闭连接, 序列化 query result, 写 query log,发通知
设计流程图
设计实现
根据设计分析得知,不管什么类型的数据查询,都会遵循固定的步骤;差别只是根据数据源来分别实现具体的步骤。
因此模板方法符合这种情况
抽象父类
父类 UML
父类定义
- 在模板方法中,在抽象父类定义一个公有方法,并且在里面按顺序调用对应的私有方法
具体就是定义execute
方法,依次调用_validate
_init_conn
_execute
__write_execute_log
_is_slow_query
这些私有方法
具体子类(MySQL)
子类 UML
子类 MySQL 定义和实现
具体子类(Redis)
子类 UML
子类 Redis 定义和实现
View 调用 Service
- 根据数据源类型,实例化对应的 service 对象
- 调用 service 对象的 execute 方法
总结
↙↙↙阅读原文可查看相关链接,并与作者交流