分析 MyBatis/MyBatis-Plus 慢 SQL 的分析组件 --SQL 慢镜🕵️‍♀️

大家好!我是聪ζ🌱我做了一个分析 MyBatis/MyBatis-Plus 慢 SQL 的分析组件 --SQL 慢镜🕵️‍♀️

GitHub仓库地址🚀: github.com/lhccong/sql... 点点 star 我的朋友们✨

背景🧊:

大家在编写项目的过程中是否经常遇到要分析 SQL 语句是否要加索引的问题,SQL 太慢使用了 MyBatis 有多个无法快速定位的问题,让我们十分头痛🤡。

项目介绍💡 :

该项目后端基于 MyBatis + MyBatis-Plus + easyRule(规则引擎) 进行开发组件。😁 项目参考了京东开源组件 sql-analysis 进行开发,不愧是京东⚡。

功能介绍🌈:

SQL 慢镜是一个能帮助到大家快速定位慢 SQL 以及分析慢 SQL 的组件,通过分析 MySQL 的执行计划来给出结果评分。

1、用户可以通过自定义输出如:发送 MQ、保存数据库等自定义的方式来输出。

2、用户可以自定义规则,来按照自己想要的规则来进行 SQL 的打分📑。

3、通过可以通过 慢镜 给出的分析结果来选择是否对 SQL 进行修改、添加索引等操作简单明了。

亮点✨:

1、使用了 MyBatis 拦截切面来进行 SQL 获取。

2、通过分析 MyBatis 的 Invocation 来进行 SQL 语句的解析。

3、实现了通过读取 YML 配置来进行属性注入。

4、使用了函数式编程来进行日志的打印输出。

5、使用了 easyRule 规则引擎来进行 SQL 分析计划的评分。

6、项目对各个方面操作做了清晰的注释以及清晰的 demo,方便大家阅读学习

扩展思路🔥:

1、SQL 替换,在 SQL 执行前根据指定的 Sqlid 替换掉指定的 SQL。

2、实现 MQ 发送日志的形式。

3、实现将分析结果生成文件。

4、通过封装 Starter 来进行注解拦截分析。

5、实现 Hibernate JPA 的方式进行拦截处理。

相关推荐
阿虎儿9 分钟前
本地部署docker完整版minIO镜像
后端
亚当10 分钟前
SpringBoot中使用MyBatis入门笔记
后端
诺斯贝克21 分钟前
Unable to create converter for xxx.NetworkResponse<Auth> for method AuthService
前端·后端
用户693717500138423 分钟前
29.Kotlin 类型系统:智能转换:类型检查 (is) 与类型转换 (as)
android·后端·kotlin
用户693717500138423 分钟前
30. Kotlin 扩展:为“老类”添“新衣”:扩展函数与扩展属性
android·后端·kotlin
用户21903265273528 分钟前
Spring Boot 集成 Redis 实现看门狗 Lua 脚本分布式锁
java·后端
PFinal社区_南丞37 分钟前
Git 那些不太常用但非常实用的命令
后端
沸腾_罗强37 分钟前
GORM 软删除方案:使用 deleted_at 替代 is_deleted,用来支持表唯一索引创建
后端
R.lin41 分钟前
Spring AI Alibaba 1.1 正式发布!
java·后端·spring
程序员阿明1 小时前
spring security 6的知识点总结
java·后端·spring