log4j,slf4j,logback简单介绍见 LogBack简易教程
Logback浅析
简单的将,slf4j是一个日志的框架,有各种日志的接口,但是并不包含实际的写日志的方法。
log4j,logback则各自独立的实现了日志的写入。
1.使用log4j独立生成日志
项目中导入log4j.jar,log4j.properties或log4j.xml
package com.spike.test; import java.io.IOException; import java.sql.SQLException; import org.apache.log4j.Logger; public class Log4jExample { static Logger log = Logger.getLogger(Log4jExample.class.getName()); public static void main(String[] args)throws IOException,SQLException{ log.debug("Debug"); log.info("Info"); log.error("error"); System.out.println(Log4jExample.class.getName()+" test"); } }
输出结果如下,日志写入到log4j配置文件指定的文件中
[03 14:04:02,721 DEBUG] [main] test.Log4jExample - Debug [03 14:04:02,723 INFO ] [main] test.Log4jExample - Info [03 14:04:02,723 ERROR] [main] test.Log4jExample - error com.spike.test.Log4jExample test
2.slf4j + log4j
项目中包含slf4j-api.jar,log4j.jar,slf4j-log4j.jar,以及log4j日志的配置文件
package com.spike.test; import java.io.IOException; import java.sql.SQLException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class Slf4jExample { /* Get actual class name to be printed on */ static Logger log = LoggerFactory.getLogger(Slf4jExample.class.getName()); public static void main(String[] args)throws IOException,SQLException{ log.debug("Debug"); log.info("Info"); log.error("error"); System.out.println(Slf4jExample.class.getName()+" test"); } }
输出结果如下,日志写入到log4j配置文件指定的文件
[03 14:07:50,548 DEBUG] [main] test.Slf4jExample - Debug [03 14:07:50,549 INFO ] [main] test.Slf4jExample - Info [03 14:07:50,549 ERROR] [main] test.Slf4jExample - error com.spike.test.Slf4jExample test
3.slf4j + logback
项目中导入slf4j-api.jar,logback-access.jar,logback-classic.jar,logback-core-1.1.7.jar,以及logback.xml配置文件
package com.spike.test; import java.io.IOException; import java.sql.SQLException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class LogbackExample { static Logger log = LoggerFactory.getLogger(Log4jExample.class.getName()); public static void main(String[] args)throws IOException,SQLException{ log.debug("Debug"); log.info("Info"); log.error("error"); System.out.println(Log4jExample.class.getName()+" test"); } }
输出结果如下,日志写入到logback.xml指定的文件中
2016-11-03 14:14:31,799 [DEBUG] [main] com.spike.test.Log4jExample [LogbackExample.java : 18] Debug 2016-11-03 14:14:31,803 [INFO] [main] com.spike.test.Log4jExample [LogbackExample.java : 19] Info 2016-11-03 14:14:31,803 [ERROR] [main] com.spike.test.Log4jExample [LogbackExample.java : 20] error com.spike.test.Log4jExample test
参考
分类:
Java
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· Apache Tomcat RCE漏洞复现(CVE-2025-24813)