java的日志记录工具 slf4j的使用
来源:互联网 发布:得力美工刀片型号 编辑:程序博客网 时间:2024/05/17 22:38
<span style="font-family: 'microsoft yahei'; background-color: rgb(255, 255, 255);"></span>
<span style="font-family: 'microsoft yahei'; background-color: rgb(255, 255, 255);">SLF4J是Simple Logging System for Java的缩写</span>
SLF4J是为各种loging APIs提供一个简单统一的接口,从而使得最终用户能够在部署的时候配置自己希望的loging APIs实现,抽象了各种日志框架例如Logback、Log4j、Commons-logging和JDK自带的logging实现接口。它使得用户可以在部署时使用自己想要的日志框架。SLF4J是轻量级的,在性能方面几乎是零消耗的。
SLF4J没有替代任何日志框架,它仅仅是标准日志框架的外观模式。如果在类路径下除了SLF4J再没有任何日志框架,那么默认状态是在控制台输出日志。
下载SLF4J的API
通过这个链接下载:
http://www.slf4j.org/download.html
SLF4J API用法
1. 从org.slf4j包导入Logger和LoggerFactory
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
2. 声明日志类
- private final Logger logger = LoggerFactory.getLogger(LoggingSample.class);
3. 使用debug、warn、info、error方法并跟踪适合的参数。
所有的方法默认都使用字符串作为输入。
- logger.info("This is sample info statement");
SLF4J结合Logback
在pom.xml包含下面的依赖:它会自动包含所有的依赖包logback-core、slf4j-api……- <dependency>
- <groupId>ch.qos.logback</groupId>
- <artifactId>logback-classic</artifactId>
- <version>1.0.7</version>
- </dependency>
SLF4J能用于现有的日志框架如Log4j、Commons-logging、java.util.logging(JUL)。
SLF4J结合Log4j
在pom.xml包含下面的依赖- <dependency>
- <groupId>org.slf4j</groupId>
- <artifactId>slf4j-log4j12</artifactId>
- <version>1.7.2</version>
- </dependency>
SLF4J结合JUL (java.util.logging)
在pom.xml包含下面的依赖
- <dependency>
- <groupId>org.slf4j</groupId>
- <artifactId>slf4j-jdk14</artifactId>
- <version>1.7.2</version>
- </dependency>
下边一段程序是经典的使用slf4j的方法.
<pre name="code" class="java">import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class Wombat { final Logger logger = LoggerFactory.getLogger(Wombat.class); Integer t; Integer oldT; public void setTemperature(Integer temperature) { oldT = t; t = temperature; logger.error("Temperature set to {}. Old temperature was {}.", t, oldT); if (temperature.intValue() > 50) { logger.info("Temperature has risen above 50 degrees."); } } } public static void main(String[] args) { Wombat wombat = new Wombat(); wombat.setTemperature(1); wombat.setTemperature(55); }}
下边介绍一下运行上边程序的过程。
1,编译上边的程序,需要classpath中加入slf4j-api-1.4.1.jar文件
2,运行时,需要classpath中加上slf4j-simple-1.4.1.jar
运行得到结果:
----------------------------
0 [main] ERROR Wombat - Temperature set to 1. Old temperature was null.
0 [main] ERROR Wombat - Temperature set to 55. Old temperature was 1.
0 [main] INFO Wombat - Temperature has risen above 50 degrees.
这个是simple log风格,
3,切换:如果想切换到jdk14的log的风格,只需要把slf4j-simple-1.4.1.jar
从classpath中移除,同时classpath中加入slj4j-jdk14-1.4.1.jar
这时的运行结果:
---------------------------------------------------
2007-7-9 10:40:15 Wombat setTemperature
严重: Temperature set to 1. Old temperature was null.
2007-7-9 10:40:16 Wombat setTemperature
严重: Temperature set to 55. Old temperature was 1.
2007-7-9 10:40:16 Wombat setTemperature
信息: Temperature has risen above 50 degrees.
已经变成jdk14的log风格了。
4,再次切换到log4j
同样移除slj4j-jdk14-1.4.1.jar,加入slf4j-log4j12-1.4.1.jar,同时加入log4j-1.2.x.jar
加入log4j.properties。得到显示结果:
---------------------------------------
10:42:27,328 ERROR Wombat: Temperature set to 1. Old temperature was null.
10:42:27,328 ERROR Wombat: Temperature set to 55. Old temperature was 1.
10:42:27,328 INFO Wombat: Temperature has risen above 50 degrees.
在不同的风格中切换只需要在部署期切换类库就可以了,和开发时无关。
- java的日志记录工具 slf4j的使用
- java 日志记录使用slf4j优于log4j的原因
- slf4j日志的使用
- slf4j日志的使用
- slf4j日志的使用
- SLF4J日志的使用
- 18、slf4j日志的使用
- SLF4J 日志门面的使用
- java的日志系统-slf4j
- 使用SLF4J+Logback作为Java项目的日志框架
- Java日志工具之SLF4J
- log4j,slf4j (日志记录工具)
- 浅析Log4j 日志记录工具的使用
- Atitit.日志系统slf4j的使用
- slf4j日志的使用和配置
- Java日志 Log4j+slf4j使用
- java使用slf4j 打印日志
- spring中使用slf4j记录日志
- nginx+php+php-fpm 安装 xdebug
- 使用popen()执行shell命令并获取内容
- 将Bitmap用Base64转码成字符串,再解码回来出现黑色背景的问题原因及解决办法。
- demo总结
- SQLServer2008把数据导出成可执行的sql脚本
- java的日志记录工具 slf4j的使用
- spring+redis整合入门
- 有道词典
- 策略模式
- CTreeCtrl 控件使用总结
- Java回调机制解析
- [linux-kernel] 实现支持poll的驱动设备
- Java实现的拦截器
- 开放平台-AS400通讯