文档章节

Dubbo日志打印剖析(自适配)

BakerZhu
 BakerZhu
发布于 2018/09/26 15:10
字数 768
阅读 3.4K
收藏 8

Dubbo 的日志打印机制

在以往的业务系统项目中,经常引入我们想接入的日志输出POM依赖, 利用相应的Logger API 输出日志或想打印的信息。但在依赖Spring Framework,Dubbo 或者其他项目时发现,只需要引入Logger相关Jar包依赖,就可以自适配Log 输出,利用适配后的日志输出系统打印相关信息。 它们的自适配是如何实现的呢?

这些框架是如何实现不同的日志系统与日志API解耦的

  • Dubbo自己实现了自己的日志打印系统
  • Spring Framework使用了 apache 的 commons-logging 来实现不同方式的日志打印与获取日志对象的解耦

首先分析下Dubbo源码的日志实现

Dubbo日志的调用方式,针对不同的日志打印系统,采用统一的API调用及输出,如:

/**
 * ChannelListenerDispatcher
 *
 * @author william.liangf
 */
public class ChannelHandlerDispatcher implements ChannelHandler {

    private static final Logger logger = LoggerFactory.getLogger(ChannelHandlerDispatcher.class);
    ........
}

LoggerFactory.getLogger 就可以获取这个类的统一的调用对象。

接下来查看日志相关源码位置

Dubbo日志结构图

Dubbo 日志相关代码在common.logger下,分模块分包也是Dubbo模块化分层的方式之一。

日志系统UML图如下所示:

Dubbo日志结构图

用到的设计模式:

装饰者模式

Dubbo中的适配器模式

适配器模式

Dubbo中的装饰者模式

核心源码

Dubbo采用的日志输出方式是首先从dubbo.application.logger 系统变量中获取属性值,来判断到底采用哪种日志输出方式,如果没设置则按照默认的加载顺序加载相应的日志输出类,直到成功加载:

顺序为:log4jLogger > slf4jLogger > JclLogger > JdkLogger 。

接下来看LoggerFactory在类加载过程中变量的初始化过程:

static {
    String logger = System.getProperty("dubbo.application.logger");
    if ("slf4j".equals(logger)) {
        setLoggerAdapter(new Slf4jLoggerAdapter());
    } else if ("jcl".equals(logger)) {
        setLoggerAdapter(new JclLoggerAdapter());
    } else if ("log4j".equals(logger)) {
        setLoggerAdapter(new Log4jLoggerAdapter());
    } else if ("jdk".equals(logger)) {
        setLoggerAdapter(new JdkLoggerAdapter());
    } else {
        try {
            setLoggerAdapter(new Log4jLoggerAdapter());
        } catch (Throwable e1) {
            try {
                setLoggerAdapter(new Slf4jLoggerAdapter());
            } catch (Throwable e2) {
                try {
                    setLoggerAdapter(new JclLoggerAdapter());
                } catch (Throwable e3) {
                    setLoggerAdapter(new JdkLoggerAdapter());
                }
            }
        }
    }
}

可以看出相关加载过程。

LoggerFactory中有两个静态变量

private static final ConcurrentMap<String, FailsafeLogger> LOGGERS = new ConcurrentHashMap<String, FailsafeLogger>();
private static volatile LoggerAdapter LOGGER_ADAPTER;

LOGGER_ADAPTER 保存输出方式对应的适配器对象。(切换日志输出时,保证内存的可见)

LOGGERS 存有不同Service业务类对象的Logger对象。 避免同一业务类的Logger对象频繁创建问题。 (避免了业务人员对每次业务方法都通过LoggerFactory.getLogger 获取Logger对象,导致的Logger对象的频繁创建问题)

Dubbo通过这种方式在系统初始化(类加载)期间,完成了Logger的选型工作。

注: Logger 的选中根 dubbo.application.logger 系统变量设定 和 类加载顺序相关

赞赏支持

赞赏支持

© 著作权归作者所有

BakerZhu
粉丝 109
博文 517
码字总数 423077
作品 0
通州
程序员
私信 提问
加载中

评论(0)

Dubbo源码分析(7):SPI扩展机制剖析

我们都是知道一个合格的开源框架对于扩展的支持都要是相当弹性的,Dubbo 也不例外。Dubbo采用微内核+插件体系,使得设计优雅,扩展性强。Dubbo的扩展机制是基于SPI思想来实现的,但是并没有采...

郑加威
2018/09/28
135
0
SOFATracer 2.4.1/3.0.6 发布,蚂蚁金服开源分布式系统调用跟踪组件

一、本期发布内容 发布 SOFATracer 2.4.1/3.0.6, 主要变更如下: i. 升级 Dubbo 版本至 2.7.3. ii. 修复 Dubbo 插件中相关埋点参数获取问题 iii. 修复 Datasource 埋点中的若干问题 iiii. Ch...

SOFAStack
2019/08/06
1.6K
5
Dubbo剖析-Dubbo协议

一、前言 TCP协议栈中,每层模型都有自己的协议报文格式,TCP协议是网络七层模型中的传输层,在TCP上层是应用层,应用层协议常见的有telnet等,Dubbo协议作为建立在TCP协议之上的一种协议,自...

加多
2018/01/04
0
0
SOFATracer 发布 3.0.6 版本,分布式系统调用跟踪组件

1、发布 SOFATracer 3.0.5 版本,主要变更如下: 支持自定义扩展 Repoter 上报 Dubbo 2.7.x 系列支持 2.7.3 版本 修复 BasePreparedStatement 初始化问题 修复 SQLException 被覆盖问题 优化...

SOFAStack
2019/09/09
747
0
Dubbo分布式环境搭建测试(依赖mybatis,spring,druid)

此文档针对初学者。 废话不多说,先上源码: http://git.oschina.net/alexgaoyh/Dubbo-parent http://git.oschina.net/alexgaoyh/Dubbo-parent/attach_files Maven项目,只需要注意下图中红色...

alexgaoyh
2015/10/20
3.2K
6

没有更多内容

加载失败,请刷新页面

加载更多

如何上好网课 — 老师录课和在线上课教学经验谈

工具/原料 授课工具 教材教案 电脑,麦克风,摄像头 讲课工具 先下载讲课助手工具,这个工具能够把老师语音、PPT讲稿、电脑操作界面直播到网络上,可以满足您做直播教学的需要。 软件下载地址...

osc_9i00cx5n
15分钟前
8
0
安装node.js和cnpm

1.安装node.js(新版node.js已经集成了npm) 到node.js官网下载 点击下载的安装包,开始安装(无脑点击下一步) 再命令行输入node -v和npm -v 都能出现版本号,就是安装成功 2.安装淘宝镜像(...

zlj012607
15分钟前
11
0
如何上好网课 — 老师录课和在线上课教学经验谈

工具/原料 授课工具 教材教案 电脑,麦克风,摄像头 讲课工具 先下载讲课助手工具,这个工具能够把老师语音、PPT讲稿、电脑操作界面直播到网络上,可以满足您做直播教学的需要。 软件下载地址...

osc_fnto2dbd
16分钟前
22
0
我说我懂多线程,面试官立马给我发了offer

前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 在上周总结了一篇「工作中常用到的Java集合类」,反响还不错。这周来写写Java另...

Java3y
18分钟前
18
0
如何上好网课 — 老师录课和在线上课教学经验谈

工具/原料 授课工具 教材教案 电脑,麦克风,摄像头 讲课工具 先下载讲课助手工具,这个工具能够把老师语音、PPT讲稿、电脑操作界面直播到网络上,可以满足您做直播教学的需要。 软件下载地址...

osc_xu7n68ts
18分钟前
19
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部