java中SPI机制的使用说明
自动化测试系统现状
最近负责公司 自动化测试系统的重构,主要功能包括:
- 自动录入测试用例:自动录取测试环境输入操作,nginx层拦截获取request.response保存数据. 用到lua脚本。
- 比对规则维护
- 测试系统回放:功能测试、压力测试
- 测试系统数据库测试前数据备份,测试后数据还原。
现存系统存在的问题
- 系统是单体应用,没有分模块,耦合性严重。
- 接口上下文逻辑处理,现状是对接入的系统做功能开发,集成到主体流程中,耦合性严重。
- 测试执行前后为了不影响数据库已有数据,采用全库mysql dump方案备份还原。数据量大时效率极低。
解决方案
- 接口上下文问题,采用插件机制开发:
主流程定义需要的接口,各个业务系统接入方实现接口。 - 数据备份、还原比较慢的问题:
总体思路,只处理测试期间增量数据的还原。
mysql 采用美团dba团队开源的myflash方案。
oracle 计划采用flashback机制处理 - 日志采集,添加开关功能
- 产线流量导入测试环境,db数据同步问题采用自定义SQL实现大表的同步。
java sdk提供的SPI机制
Dubbo中SPI的处理方式
中间件开发,插件机制用到的地方比较多,各种方案可以参考借鉴。