【Bug】使用Log4j可以打印日志,使用Slf4j无法打印日志

刚学习了点Tomcat的知识,于是想在服务中监测下Tomcat的启动时间,优化一下试试,于是写了如下的代码:

java 复制代码
@Component
@Slf4j
public class StartupTimeListener implements ApplicationListener<ApplicationStartedEvent> {

    private final long startTime;

    public StartupTimeListener() {
        startTime = System.currentTimeMillis();
    }

    @Override
    public void onApplicationEvent(ApplicationStartedEvent event) {
        long endTime = System.currentTimeMillis();
        long duration = endTime - startTime;
        System.out.println("Tomcat启动消耗" + (endTime - startTime) + "毫秒");
        log.info("Tomcat启动耗时" + duration + "毫秒");
    }

}

非常正常的代码,一个事件监听器,记录下开始时间和结束时间,最后打印出耗时,出现的问题是控制台完全没有日志信息,但是sout的输出被正常打印

这个时候我也没多想,把Slf4j换成了Log4j,结果日志正常打印了

这时候我不明白的一个点是,大家都是 info 级别的打印,如果限制了日志级别,凭什么 Log4j 可以而 Slf4j 就不行,后来发现这个问题我出现的太巧合了

Log4j 使用的时候是需要有配置文件初始化的,一般叫 log4j.properties ,没有这个配置文件的话根本不会打印任何数据,但这跟我的情况不一样,我是可以打印,所以我就去找这个配置文件。

发现由于业务有加密的需要,因此引入了自定义的区块链依赖,其中包括了 log4j 依赖和 dzsjfcgpt-encode 依赖,后面的这个依赖里有关于 log4j 的配置文件,其中定义了 log4j 输出日志的最低级别为 DEBUG ,因此可以正常打印出 Info 级别的日志,那为什么 Slf4j 的日志没有被打印出来呢?

application.yaml中有这样的一个配置项:

yaml 复制代码
logging:
  level:
    root: warn

这个配置项设置了 Slf4j 打印日志的最低等级,为了减少生产环境的日志信息,一般至少配置到 warn 级别,本地测试时没有修改导致日志没有输出到控制台。

总结问题出现的原因:

  • 某个依赖中引入了 log4j 的配置文件,且配置文件的日志级别比使用的要低
  • 配置文件中定义了 slf4j 的日志级别
相关推荐
014-code2 小时前
日志规范:怎么写才不算写废话
java·开发语言·设计模式·日志
疯狂成瘾者1 天前
SLF4J的学习路线
java·学习·slf4j
数据皮皮侠AI2 天前
顶刊同款!中国地级市风灾风险与损失数据集(2000-2022)|灾害 / 环境 / 经济研究必备
大数据·人工智能·笔记·能源·1024程序员节
WiChP3 天前
【V0.1B6】从零开始的2D游戏引擎开发之路
java·log4j·游戏引擎
Fab1an3 天前
Busqueda——Hack The Box 靶机
linux·服务器·学习·1024程序员节
技术专家4 天前
Stable Diffusion系列的详细讨论 / Detailed Discussion of the Stable Diffusion Series
人工智能·python·算法·推荐算法·1024程序员节
Ops菜鸟(Xu JieHao)4 天前
Linux快速生成测试日志flog
linux·运维·服务器·日志·log
__zRainy__4 天前
Node.js 日志选型指南:Winston vs Log4js 全方位对比与实战
node.js·log4j·winston
色空大师6 天前
【日志文件配置详解】
java·logback·log4j2·日志
学传打活6 天前
古代汉语是源,现代汉语是流,源与流一脉相承。
微信公众平台·1024程序员节·汉字·中华文化