dubbo使用logback输出日志
2017-01-06 13:52
399 查看
文章来源:http://blog.csdn.net/long243416336/article/details/49946833
最近在做dubbo协议扩展,发现dubbo错误信息没有打印。于是跟踪源码发现,dubbo默认使用log4j作为日志输出,而我们项目是采用logback来输出日志。
采取以下方式来切换成slf4j:
(1)设置jvm启动参数来指定slf4j(这种方式无论是spring容器还是web容器均可适用)
-Ddubbo.application.logger=slf4j
(2)web项目,可继承ContextLoaderListener来设置
System.setProperty("dubbo.application.logger","slf4j");
设置前,启动日志如下:
c.a.d.common.logger.LoggerFactory - using logger: com.alibaba.dubbo.common.logger.log4j.Log4jLoggerAdapter
设置后,启动日志如下:
c.a.d.common.logger.LoggerFactory - using logger: com.alibaba.dubbo.common.logger.slf4j.Slf4jLoggerAdapter
大家看到,日志输出器已切换成slf4j。
下面贴出dubbo的loggerFactory源码,查找日志适配器部分:
[java] view
plain copy
// 查找常用的日志框架
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());
}
}
}
}
}
可看出如果没有设置,则默认采用log4j进行日志输出。
最近在做dubbo协议扩展,发现dubbo错误信息没有打印。于是跟踪源码发现,dubbo默认使用log4j作为日志输出,而我们项目是采用logback来输出日志。
采取以下方式来切换成slf4j:
(1)设置jvm启动参数来指定slf4j(这种方式无论是spring容器还是web容器均可适用)
-Ddubbo.application.logger=slf4j
(2)web项目,可继承ContextLoaderListener来设置
System.setProperty("dubbo.application.logger","slf4j");
设置前,启动日志如下:
c.a.d.common.logger.LoggerFactory - using logger: com.alibaba.dubbo.common.logger.log4j.Log4jLoggerAdapter
设置后,启动日志如下:
c.a.d.common.logger.LoggerFactory - using logger: com.alibaba.dubbo.common.logger.slf4j.Slf4jLoggerAdapter
大家看到,日志输出器已切换成slf4j。
下面贴出dubbo的loggerFactory源码,查找日志适配器部分:
[java] view
plain copy
// 查找常用的日志框架
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());
}
}
}
}
}
可看出如果没有设置,则默认采用log4j进行日志输出。
相关文章推荐
- 计算两个时间相差天数
- 取消普通域用户帐号加域权限&授权特定普通域用户加域权 ...
- 类、抽象类,接口
- python实现快速排序
- 【Java学习之代码学习】 Prog37_企业发放的奖金
- git常用命令: reset, stash
- 使用T4模板生成不同部署环境下的配置文件
- 浅谈web网站架构演变过程
- 并行编程之Java内存模式
- UnityShader实战 之 体积光的实现
- mysql学习
- MyBatis/Ibatis中#和$的区别
- Android中AnimationDrawable,Animator和Animation
- zxing的使用及优化
- 探索Lua5.2内部实现:Function
- "XX cannot be resolved to a type "eclipse报错及解决说明
- 解决【unity3d】播放视频的两种操作方式
- CSS选择器性能分析
- CSS3 选择器——基本选择器
- 我的 Android 开发实战经验总结