SLF4J官网:http://www.slf4j.org/

SLF4J的作用通俗点讲,就是可以让我们的项目以最小的代价更换不同的日志系统。无需修改代码,只需要添加、删除相应的jar包和配置文件。

1.添加”slf4j-api-xxx.jar”到项目中。(xxx代表版本号,本文用的是1.7.7版本)

2.建个项目,编写几句简单的日志记录的代码。

//import org.apache.log4j.PropertyConfigurator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; public class test_slf4j { public static void main(String[] args) {
// PropertyConfigurator.configure("log4j.properties");
Logger logger = LoggerFactory.getLogger(test_slf4j.class);
logger.trace("I'm trace log.");
logger.debug("I'm debug log.");
logger.info("I'm info log.");
logger.warn("I'm warn log.");
logger.error("I'm error log.");
}
}

3.下载的SLF4J压缩包里自带了很多的日志系统,体验一下几个常用的。

【Simple】

先来用一下简单日志,添加”slf4j-simple-xxx.jar”到项目中。

然后直接运行上面的代码,控制台输出结果:

[main] INFO test_slf4j - I'm info log.
[main] WARN test_slf4j - I'm warn log.
[main] ERROR test_slf4j - I'm error log.

貌似因为没有自定义配置文件,默认配置把trace和debug级别的日志给过滤了。

【JDK】

再来试试jdk自带的日志系统,删除”slf4j-simple-xxx.jar”,添加”slf4j-jdk14-xxx.jar”到项目中。

注意:项目中不能有多个日志系统,否则SLF4J因为不知道用哪个会报错。

然后直接运行上面的代码,控制台输出结果:

八月 30, 2014 12:44:12 下午 test_slf4j main
信息: I'm info log.
八月 30, 2014 12:44:13 下午 test_slf4j main
警告: I'm warn log.
八月 30, 2014 12:44:13 下午 test_slf4j main
严重: I'm error log.

结果和简单日志差不多,除了日志格式不同,多了日志记录时间,也是被过滤了trace和debug级别的日志。

【Log4j】

上面的日志内容实在是过于简单,对我们实际开发可以说是作用甚微。日志文件当然是越详细越好,尤其是在修复BUG时,能够准确的定位到哪一行代码是极好的。

来试一下大家常用的Log4j,删除其他日志系统的jar包,添加”slf4j-log4j12-xxx.jar”,还需添加一个Log4j1.2版本的jar包,去Log4j的官网上下载一个。现在Log4j1已经停止更新,Log4j2说是比1提升非常多。我一开始用SLF4J + Log4j2,但是一直不成功。网上的资料也不多,等回头有时间研究一下再写一篇SLF4J + Log4j2的文章,这里我用的是SLF4J-1.7.7 + Log4j-1.2.17。

添加了需要的jar包,还需添加Log4j的配置文件”log4j.properties”。

我配置的log4j.properties具有三种Logger。

Console:控制台输出DEBUG级别以上的日志。

LogFile:文本记录INFO级别以上的日志,文件最大不超过2MB。

ErrorFile:文件记录ERROR级别以上的日志,以日期格式命名文件,如“error.log.2014-08-01”、“error.log.2014-08-02”。

# Set log levels #
log4j.rootLogger = DEBUG, Console, LogFile, ErrorFile # Output the log info to the Java Console #
log4j.appender.Console = org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target = System.out
log4j.appender.Console.Threshold = DEBUG
log4j.appender.Console.layout = org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern = <%-d{yyyy-MM-dd HH:mm:ss}> <%t> %l %n<%p> %m%n%n # Save the log info to the log file #
log4j.appender.LogFile = org.apache.log4j.RollingFileAppender
log4j.appender.LogFile.File = logs/log.log
log4j.appender.LogFile.Append = true
log4j.appender.LogFile.MaxFileSize = 2MB
log4j.appender.LogFile.MaxBackupIndex = 100
log4j.appender.LogFile.Threshold = INFO
log4j.appender.LogFile.layout = org.apache.log4j.PatternLayout
log4j.appender.LogFile.layout.ConversionPattern = <%-d{yyyy-MM-dd HH:mm:ss}> <%t> %l %n<%p> %m%n%n # Save the error info to the error file. A file one day. #
log4j.appender.ErrorFile = org.apache.log4j.DailyRollingFileAppender
log4j.appender.ErrorFile.File = logs/error.log
log4j.appender.ErrorFile.Append = true
log4j.appender.ErrorFile.Threshold = ERROR
log4j.appender.ErrorFile.layout = org.apache.log4j.PatternLayout
log4j.appender.ErrorFile.layout.ConversionPattern = <%-d{yyyy-MM-dd HH\:mm\:ss}> <%t> %l %n<%p> %m%n%n

在src根目录下创建“log4j.properties”,Log4j在启动时会默认寻找这个配置文件。如果你将配置文件放在其他地方,可以用上面注释掉的代码先加载指定的配置文件,支持绝对路径和相对路径。

还是直接运行上面的代码,控制台输出结果:

<2014-08-30 13:17:03> <main> test_slf4j.main(test_slf4j.java:17)
<DEBUG> I'm debug log. <2014-08-30 13:17:03> <main> test_slf4j.main(test_slf4j.java:18)
<INFO> I'm info log. <2014-08-30 13:17:03> <main> test_slf4j.main(test_slf4j.java:19)
<WARN> I'm warn log. <2014-08-30 13:17:03> <main> test_slf4j.main(test_slf4j.java:20)
<ERROR> I'm error log.

我配置的log4j.rootLogger = DEBUG,所以trace没有被输出。去查看两个日志文件,也成功记录了相应的日志。

SLF4J日志门面的更多相关文章

  1. SLF4J 日志门面

    目录 01.简单介绍 02.日志级别 03.入门案例 03.动态打印 04.异常打印 05.日志集成 06.集成 logback 07.集成 slf4j-nop 08.集成 log4j 09.集成 j ...

  2. Log4j2日志框架集成Slf4j日志门面

    1.说明 本文介绍使用日志门面Slf4j打印日志, 底层日志实现使用Log4j2框架, 方便以后切换底层日志实现, Log4j2可以替换成Logback等. 2.依赖管理 在pom.xml依赖管理中导 ...

  3. catalina.out日志膨胀问题解决实例,日志门面commons-logging的实践

    声明:迁移自本人CSDN博客https://blog.csdn.net/u013365635 笔者在公司的时候,遇到一个问题,2个模块A.B Tomcat中的catalina.out及catalina ...

  4. SLF4J 简单日志门面 介绍和使用

    参考:http://singleant.iteye.com/blog/934593        http://liuzidong.iteye.com/blog/776072 介绍: 简单日记门面(s ...

  5. springboot结合日志门面SLF4j和日志实现Logback的使用

    一.此处主要介绍在springboot工程下如何使用 logback + slf4j  进行日志记录. logback主要包含三个组成部分:Loggers(日志记录器).Appenders(输出目的在 ...

  6. slf4j日志的使用

    slf4j(simple logging facade for Java)是Java的简单的日志门面,它不是具体的日志解决方案,它只服务于各种各样slf4j-logo的日志系统.这里的slf4j-lo ...

  7. Log4j,Log4j2,logback,slf4j日志学习

    日志学习笔记 Log4j Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.数据库等:我们也可以控制每一条日志的输出格式:通过定义每一条 ...

  8. Log4j,Log4j2,logback,slf4j日志学习(转)

    日志学习笔记Log4jLog4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.数据库等:我们也可以控制每一条日志的输出格式:通过定义每一条日志 ...

  9. 日志系列1——slf4j日志框架原理

    目录 1.前言 2.日志门面 3.日志库 4.日志适配器 5.日志库的选用 6.logback.xml 配置文件 1.前言 ​ 说到日志工具,日常工作或学习中肯定听过这些名词:log4j.logbac ...

随机推荐

  1. POJ 1703

    种类并查集,基本思想是每次压缩路径都必须同时更新子节点和根节点的关系,这种关系是通过子节点和父亲节点的关系,以及父亲节点与根节点的关系运算出来. 压缩路径的findme();参考了大神的代码,做的第二 ...

  2. C++primer 练习13.44

    13.44:编写标准库string类的简化版本,命名为String.你的类应该至少有一个默认构造函数和一个接受C 风格字符串指针参数的构造函数.使用allocator为你的String类分配所需内存 ...

  3. nyoj 97 兄弟郊游问题

    点击打开链接 兄弟郊游问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:2 描述 兄弟俩骑车郊游,弟弟先出发,每分钟X米,M分钟后,哥哥带一条狗出发.以每分钟Y米的速度去追弟弟 ...

  4. OC基础(7)

    封装 继承基本概念 继承相关特性 多态基本概念 多态的实现 *:first-child { margin-top: 0 !important; } body > *:last-child { m ...

  5. HRBUST1530

    链接 http://acm.hrbust.edu.cn/index.php?m=ProblemSet&a=showProblem&problem_id=1530 这个是典型的二分题,题 ...

  6. g++/gcc 链接头文件 库 PATH

    转自http://blog.csdn.net/kankan231/article/details/24243871 在Linux下编译链接或运行c/c++程序时可能会遇到找不到头文件,找不到库文件的错 ...

  7. java数据结构之列表——ArrayList,LinkedList,比较

    刚看完<数据结构与算法分析java语言描述>的第3章中的表,下面回忆下主要知识点,主要说明各列表之间的关系,以及各自的优缺点.其中牵涉到内部类和嵌套类. 1 Collection APIp ...

  8. Xcode entitlement 问题定位和解决指南

    背景故事 前两天,本来一个运行正常.打包测试都没问题的XCode工程突然爆出各种奇怪的Entitlement错误: 什么签名的内容跟配置文件的不一致. 又或者 无法安装,因为签名或者配置文件的配置错误 ...

  9. 搭建基于Windows + Apache + PHP + MySQL的Moodle平台

    说起Moodle,我相信学习教育技术的同学应该都不陌生,在大学的网络与远程教育课中,我有幸与传说中的Moodle相遇,然后相知,但是我绝对不会跟你们说一直到我毕业,我都没有找到一个合适的时间与这位Ms ...

  10. Flex开发自定义控件

    前期准备: 点击File菜单 -> New -> MXML Component,然后弹出一个对话框. 在对话框中输入组件名,选择此组件继承的类型,如:Canvas,DataGrid,Com ...