MyBatis源码解析之日志记录-创新互联

一 .概述

为湟源等地区用户提供了全套网页设计制作服务,及湟源网站建设行业解决方案。主营业务为成都网站制作、做网站、湟源网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

MyBatis没有提供日志的实现类,需要接入第三方的日志组件,但第三方日志组件都有各自的Log级别,且各不相同,但MyBatis统一提供了trace、debug、warn、error四个级别;

自动扫描日志实现,并且第三方日志插件加载优先级如下:slf4J → commonsLoging → Log4J2 → Log4J → JdkLog;

日志的使用要优雅的嵌入到主体功能中;

二.设计模式
MyBatis源码解析之日志记录
将各种日志组件如(slf4J ,commonsLoging ,Log4J2 , Log4J , JdkLog)统一输出,定义了trace、debug、warn、error四个级别;
日志模块类图
MyBatis源码解析之日志记录
代理模式
MyBatis源码解析之日志记录
MyBatis源码解析之日志记录
三.MyBatis源码日志实现

1.MyBatis整合各方日志组件
MyBatis源码解析之日志记录

MyBatis源码解析之日志记录
容器启动时,按照日志组件优先级 slf4J → commonsLoging → Log4J2 → Log4J → JdkLog进行 加载,每个日志主键都做了了适配器的实现类
MyBatis源码解析之日志记录
2.jdbc日志增强模块
MyBatis源码解析之日志记录
MyBatis源码解析之日志记录
链接阶段:
MyBatis源码解析之日志记录
MyBatis源码解析之日志记录
实现了InvocationHandler接口是一个代理类,返回的是具有日志能力的Connection,同时打印了参数

MyBatis源码解析之日志记录
并且调用了
MyBatis源码解析之日志记录
PreparedStatementLogger来创建代理对象。

由此jdbc由链接阶段进入准备阶段:
MyBatis源码解析之日志记录
PreparedStatementLogger实现了InvocationHandler接口是一个代理类,返回的是具有日志能力的ResultSet,同时打印了参数

并且调用了ResultSetLogger来创建代理对象,

由此jdbc由链接阶段进入执行阶段:
MyBatis源码解析之日志记录
MyBatis源码解析之日志记录

ResultSetLogger实现了InvocationHandler接口是一个代理类,返回的是具有日志能力的ResultSet,同时打印了具体的sql语句。传入参数,以及返回结果。

总结:

mybatis自身没有日志的实现通过适配器模式整合各日志厂商的日志组件,并统一了输出接口,并使用了代理模式,从链接,至编译,最后到执行阶段,进行层层代理,使日志优雅的嵌入到主体功能中;

举例:一个苹果从果树到消费者手中,果农—收购商—批发商—农贸市场—消费者,在该代理链中,消费者买苹果的价格不是某一个环节加价的,而是层层加价,同时消费者只需要在农贸市场买入苹果,而不必知道苹果如何进入农贸市场的。

对农贸市场也是如此。苹果到消费者手中共经过 收购商—批发商—农贸市场 3个代理商 ,每个代理商返回的都是加价过的代理对象,对消费者屏蔽了苹果来源。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


新闻标题:MyBatis源码解析之日志记录-创新互联
标题链接:http://myzitong.com/article/coigep.html