dubbo使用logback输出日志

原创 2015年11月20日 15:00:15

最近在做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源码,查找日志适配器部分:

// 查找常用的日志框架
	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项目中使用logback输出日志

初次建立dubbo项目,并启动服务提供方时会看到如下的警告。log4j:WARN No appenders could be found for logger (com.alibaba.dubbo.c...

dubbo 的使用

dubbo 官方使用说明: http://alibaba.github.io/dubbo-doc-static/Home-zh.htm [2] Dubbo是[3] 阿里巴巴公司开源的一个高性能优秀...
  • liuc0317
  • liuc0317
  • 2014年12月30日 15:06
  • 28131

dubbo 的使用

dubbo 官方使用说明: http://alibaba.github.io/dubbo-doc-static/Home-zh.htm [2] Dubbo是[3] 阿里巴巴公司开源的一个...
  • fuck487
  • fuck487
  • 2016年07月02日 02:03
  • 1309

dubbo使用logback输出日志

文章来源:http://blog.csdn.net/long243416336/article/details/49946833 最近在做dubbo协议扩展,发现dubbo错误信息没有打印。...

如何开启Dubbo框架内部的日志?

欢迎加入DUBBO交流群:259566260 这里将对如何在自己的项目里面开启dubbo框架自己的日志,并对输出的日志进行控制。在讲这些之前,先看看dubbo在处理日志的时候是怎么做的?  ...

dubbo学习

1.Dubbo 集群容错   当我们的系统中用到Dubbo的集群环境,因为各种原因在集群调用失败时,Dubbo提供了多种容错方案,缺省为failover重试   Failover Clust...

dubbo提供者打包,解决jar不能正常运行(不能注册到注册中心)

这几天打包发布dubbo消费者,出现了各种问题. 今天记录的是直接在Eclispe是运行Main方法时正常使用服务.打包成jar在服务运行时不能正常使用问题. 我写的Main方法: public cl...
  • vispin
  • vispin
  • 2015年05月25日 15:06
  • 5046

一个异常引起的反思

昨天在调试程序的时候,看到程序报错如下: log4j:WARN No appenders could be found for logger (com.alibaba.dubbo.common.lo...

[转载,感觉写的非常详细]DUBBO配置方式详解

DUBBO 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是阿里巴巴 SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次...

Log4j日志配置详解

原文地址:http://www.cnblogs.com/ITtangtang/p/3926665.html 一、Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appende...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:dubbo使用logback输出日志
举报原因:
原因补充:

(最多只允许输入30个字)