(3)MySQL案例-模块关联图

在这里插入图片描述
所有的plugin都是按service来加载的。
在chaosblade-exec-jvm 工程的模块里全部插件都放在plugins里,此路径在module里写死了。

MysqlPlugin.java
整个MySQL插件的入口,包含了主要的getName()、PointCut、ModelSpec、Enhancer。

getName():返回目标插件的名字mysql。

PointCut :由MysqlPointCut.java实现,是拦截了需要匹配的目标类、方法。
String MYSQL_IO_CLASS = “com.mysql.jdbc.MysqlIO”; //这个是连接类,在mysql-connector-*8.0的源码里没有的到 String INTERCEPTOR_PRE_METHOD = “sqlQueryDirect”; String MYSQL8_NATIVE_SESSION_CLASS = “com.mysql.cj.NativeSession”; //在mysql-connector-*8.0的源码里找到 String MYSQL8_NATIVE_SESSION_METHOD = “execSQL”;

ModelSpec:action、flag的管理类。支持的增强action为(delay、throwCustomException),并且过滤的sqltype为(crud、show、replace、truncate、 drop、load、merge)。

Enhancer :由MysqlEnhancer.java实现,编织实现。

由上可知,MySQL插件主要是对类com.mysql.cj.NativeSession里的execSQL进行了增强。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值