您的位置:首页 > 其它

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进行日志输出。

        
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: