您的位置:首页 > 编程语言 > Java开发

java的日志记录工具 slf4j的使用

2015-06-26 17:32 519 查看
<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

[java] view
plaincopyprint?

import org.slf4j.Logger;  

import org.slf4j.LoggerFactory;  

2. 声明日志类

[java] view
plaincopyprint?

private final Logger logger = LoggerFactory.getLogger(LoggingSample.class);  

3. 使用debug、warn、info、error方法并跟踪适合的参数。

所有的方法默认都使用字符串作为输入。

[java] view
plaincopyprint?

logger.info("This is sample info statement");  

SLF4J结合Logback

在pom.xml包含下面的依赖:它会自动包含所有的依赖包logback-core、slf4j-api……

[html] view
plaincopyprint?

<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包含下面的依赖

[html] view
plaincopyprint?

<dependency>  

  <groupId>org.slf4j</groupId>  

  <artifactId>slf4j-log4j12</artifactId>  

  <version>1.7.2</version>  

</dependency>  

SLF4J结合JUL (java.util.logging)

在pom.xml包含下面的依赖

[html] view
plaincopyprint?

<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.

在不同的风格中切换只需要在部署期切换类库就可以了,和开发时无关。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: