最近在公司的一个项目里看到人家都在用self4j,开始不知道是什么。后来让我本身写一个工具须要写日志,就想起了log4j可是也不是很熟悉。就在网上找各类日志相关的资源,看到了诸如java.util.logging包中的logger ,log4j,slf4j,logback,common-logging 等好多日志相关的东西,搞得头晕脑胀的。从今天开始先研究。 java
sef4j的使用其实我也不知道那就从头开始喽。 api
slf4j的下载地址http://www.slf4j.org 函数
按照官方的说法,slf4j是一个用于日志系统的简单Facade,容许最终用户在部署其应用时使用其所但愿的日志系统。而在使用slf4j的时候,不须要在代码中或配置文件中指定你打算使用那个具体的日志系统,slf4j提供了统一的记录日志的接口,只要按照其提供的方法记录便可,最终日志的格式、记录级别、输出方式等经过具体日志系统的配置来实现,所以能够在应用中灵活切换日志系统。 工具
使用方式
this
在系统开发中,统一按照slf4j的API进行开发,在部署时,选择不一样的日志系统包,便可自动转换到不一样的日志系统上。好比:选择JDK自带的日志系统,则只须要将slf4j-api-1.6.1.jar和slf4j-jdk14-1.6.1.jar放置到classpath中便可,若是中途没法忍受JDK自带的日志系统了,想换成log4j的日志系统,仅须要用slf4j-log4j12-1.6.1.jar替换slf4j- jdk14-1.6.1.jar便可(须要log4j的jar及配置文件log4j.properties文件),也可使用slg4j提供的 simple log,slf4j-simple-1.6.1.jar替换slf4j-jdk14-1.6.1.jar。 spa
package com.test; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class Slf4jTest { // 统一按照slf4j的API进行开 Logger logger = LoggerFactory.getLogger(Slf4jTest.class); public void testLog(){ logger.info("this is a test log"); } public static void main(String[] args) { Slf4jTest slf = new Slf4jTest(); slf.testLog(); } }
2010-2-23 11:57:28 com.test.Slf4jTest testLog 信息: this is a test log
[main] INFO com.test.Slf4jTest - this is a test log
public static void main(String[] args) { System.setProperty("log4j.configuration", "log4j.properties"); Slf4jTest slf = new Slf4jTest(); slf.testLog(); }
logger.info("Today is {}, Temperature set to {}. Old temperature was {}.", objs);