分析 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 的方式进行拦截处理。

相关推荐
程序猿阿越44 分钟前
Kafka源码(一)Controller选举与创建Topic
java·后端·源码
程序员爱钓鱼1 小时前
Go语言项目工程化 — 常见开发工具与 CI/CD 支持
开发语言·后端·golang·gin
Jiude1 小时前
MinIO 社区版被故意阉割,Web管理功能全面移除。我来试试国产RustFS
后端·docker·架构
仰望星空@脚踏实地1 小时前
Spring Boot Web 服务单元测试设计指南
spring boot·后端·单元测试
羊小猪~~1 小时前
数据库学习笔记(十七)--触发器的使用
数据库·人工智能·后端·sql·深度学习·mysql·考研
用户8324951417322 小时前
JAVA 版本多版本切换 - 傻瓜式操作工具
后端
estarlee2 小时前
随机昵称网名API接口教程:轻松获取百万创意昵称库
后端
明天好,会的2 小时前
跨平台ZeroMQ:在Rust中使用zmq库的完整指南
开发语言·后端·rust
追逐时光者2 小时前
C#/.NET/.NET Core优秀项目和框架2025年6月简报
后端·.net
llwszx3 小时前
Spring中DelayQueue深度解析:从原理到实战(附结构图解析)
java·后端·spring·delayqueue·延迟任务