采取以下方式来切换成 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.application.logger属性,默认会找log4j,就会报错

log4j:WARN No appenders could be found for logger (com.alibaba.dubbo.common.logger.LoggerFactory).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.