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

server/2024/10/25 8:45:09/

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

@Component
@Slf4j
public class StartupTimeListener implements ApplicationListener<ApplicationStartedEvent> {private final long startTime;public StartupTimeListener() {startTime = System.currentTimeMillis();}@Overridepublic void onApplicationEvent(ApplicationStartedEvent event) {long endTime = System.currentTimeMillis();long duration = endTime - startTime;System.out.println("Tomcat启动消耗" + (endTime - startTime) + "毫秒");log.info("Tomcat启动耗时" + duration + "毫秒");}}

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

image-20241024131224704

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

image-20241024114723882

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

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

image-20241024131455080

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

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

logging:level:root: warn

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

总结问题出现的原因:

  • 某个依赖中引入了 log4j 的配置文件,且配置文件的日志级别比使用的要低
  • 配置文件中定义了 slf4j日志级别

http://www.ppmy.cn/server/134661.html

相关文章

后端消息推送方案方案(轮询,长轮询,websocket,SSE)

1.轮询&#xff1a; 轮询是一种客户端定期向服务器发送HTTP请求&#xff0c;服务器实时返回数据给浏览器&#xff0c;用以检查是否有新的数据或更新的方式。客户端会设置一个固定的时间间隔&#xff0c;不停地向服务器发起HTTP请求&#xff0c;无论是否有新数据返回&#xff0…

Ubuntu下Mysql修改默认存储路径

首先声明&#xff0c;亲身经验&#xff0c;自己实践&#xff0c;网上百度了好几个帖子&#xff0c;全是坑&#xff0c;都TMD的不行&#xff0c;修改各种配置文件&#xff0c;就是服务起不来&#xff0c;有以下几种配置文件需要修改 第一个文件/etc/mysql/my.cnf 这个文件是存…

闯关leetcode——206. Reverse Linked List

大纲 题目地址内容 解题代码地址 题目 地址 https://leetcode.com/problems/reverse-linked-list/ 内容 Given the head of a singly linked list, reverse the list, and return the reversed list. Example 1: Input: head [1,2,3,4,5] Output: [5,4,3,2,1] Example 2:…

【ChatGPT】如何通过实例提升 ChatGPT 的回答质量

如何通过实例提升 ChatGPT 的回答质量 ChatGPT 的输出质量直接受用户输入的提示&#xff08;Prompt&#xff09;影响。有效的提示设计能够引导模型生成更准确、符合需求的回答&#xff0c;而在提示中使用实例&#xff08;Examples&#xff09;是提高回答质量的关键方法之一。本…

docker集成Nginx和Mysql (教程)

文章目录 前言一、Docker 集成Nginx步骤 1&#xff1a;安装 Docker步骤 2&#xff1a;拉取官方的 Nginx Docker 镜像1.可以先搜索nginx镜像(查看nginx镜像)2.拉取nginx镜像步骤 3&#xff1a;运行 Nginx 容器 二、Docker 集成Mysql步骤 1&#xff1a;拉取mysql镜像步骤2、运行 …

【深度学习代码调试5】标准化数据集:TensorFlow Datasets (TFDS)自动化数据加载与预处理

【标准化数据集】TensorFlow Datasets、TFDS&#xff1a;自动化数据加载与预处理 写在最前面1. 什么是 TensorFlow Datasets (TFDS)?主要特点&#xff1a; 2. TFDS 的核心 API&#xff1a;tfds.builder 和 download_and_preparetfds.builder&#xff1a;创建数据集构建器示例&…

KubeSphere

初始密码 Account: admin Password: P88w0rd ansible部署 选一台master 节点 --- - hosts: k8s_mastersbecome: yestasks:- name: Install Gitpackage:name: gitstate: present- name: Download Helmget_url:url: https://get.helm.sh/helm-v3.16.2-linux-amd64.tar.gzdest: …

软工毕设开题建议

文章目录 &#x1f6a9; 1 前言1.1 选题注意事项1.1.1 难度怎么把控&#xff1f;1.1.2 题目名称怎么取&#xff1f; 1.2 开题选题推荐1.2.1 起因1.2.2 核心- 如何避坑(重中之重)1.2.3 怎么办呢&#xff1f; &#x1f6a9;2 选题概览&#x1f6a9; 3 项目概览题目1 : 深度学习社…