1. logback介绍

Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-classic完整实现SLF4J API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging。logback-access访问模块与Servlet容器集成提供通过Http来访问日志的功能。

2. maven依赖

  1. <!-- logback+slf4j -->
  2. <dependency>
  3. <groupId>org.slf4j</groupId>
  4. <artifactId>slf4j-api</artifactId>
  5. <version>1.6.0</version>
  6. <type>jar</type>
  7. <scope>compile</scope>
  8. </dependency>
  9. <dependency>
  10. <groupId>ch.qos.logback</groupId>
  11. <artifactId>logback-core</artifactId>
  12. <version>0.9.28</version>
  13. <type>jar</type>
  14. </dependency>
  15. <dependency>
  16. <groupId>ch.qos.logback</groupId>
  17. <artifactId>logback-classic</artifactId>
  18. <version>0.9.28</version>
  19. <type>jar</type>
  20. </dependency>

如果你没有使用maven,那么你自己去下载jar包吧...

3. 配置和使用

1. 日志使用

我们使用org.slf4j.LoggerFactory,就可以直接使用日志了。

  1. protected final Logger       logger = LoggerFactory.getLogger(this.getClass());

使用:

  1. @Controller
  2. @RequestMapping(value = "")
  3. public class IndexController extends BaseController {
  4. /**
  5. * Success
  6. * @param response
  7. * @throws IOException
  8. */
  9. @RequestMapping(value = "")
  10. @ResponseBody
  11. public void hello(HttpServletResponse response) throws IOException {
  12. logger.debug("DEBUG TEST 这个地方输出DEBUG级别的日志");
  13. logger.info("INFO test 这个地方输出INFO级别的日志");
  14. logger.error("ERROR test 这个地方输出ERROR级别的日志");
  15. }
  16. }

2. 在控制台输出特定级别的日志

logback的配置文件都放在/src/main/resource/文件夹下的logback.xml文件中。其中logback.xml文件就是logback的配置文件。只要将这个文件放置好了之后,系统会自动找到这个配置文件。

下面的配置中,我们输出特定的ERROR级别的日志:

  1. <?xml version="1.0"?>
  2. <configuration>
  3. <!-- ch.qos.logback.core.ConsoleAppender 控制台输出 -->
  4. <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
  5. <encoder>
  6. <pattern>[%-5level] %d{HH:mm:ss.SSS} [%thread] %logger{36} - %msg%n</pattern>
  7. </encoder>
  8. </appender>
  9. <!-- 日志级别 -->
  10. <root>
  11. <level value="error" />
  12. <appender-ref ref="console" />
  13. </root>
  14. </configuration>

结果只在控制台输出ERROR级别的日志。

3. 设置输出多个级别的日志

  1. <?xml version="1.0"?>
  2. <configuration>
  3. <!-- ch.qos.logback.core.ConsoleAppender 控制台输出 -->
  4. <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
  5. <encoder>
  6. <pattern>[%-5level] %d{HH:mm:ss.SSS} [%thread] %logger{36} - %msg%n</pattern>
  7. </encoder>
  8. </appender>
  9. <!-- 日志级别 -->
  10. <root>
  11. <level value="error" />
  12. <level value="info" />
  13. <appender-ref ref="console" />
  14. </root>
  15. </configuration>

设置两个level,则可以输出 ERROR和INFO级别的日志了。

4. 设置文件日志

  1. <?xml version="1.0"?>
  2. <configuration>
  3. <!-- ch.qos.logback.core.ConsoleAppender 控制台输出 -->
  4. <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
  5. <encoder>
  6. <pattern>[%-5level] %d{HH:mm:ss.SSS} [%thread] %logger{36} - %msg%n
  7. </pattern>
  8. </encoder>
  9. </appender>
  10. <!-- ch.qos.logback.core.rolling.RollingFileAppender 文件日志输出 -->
  11. <appender name="file"
  12. class="ch.qos.logback.core.rolling.RollingFileAppender">
  13. <Encoding>UTF-8</Encoding>
  14. <File>/home/test.log</File>
  15. <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  16. <FileNamePattern>/home/test-%d{yyyy-MM-dd}.log
  17. </FileNamePattern>
  18. <MaxHistory>10</MaxHistory>
  19. <TimeBasedFileNamingAndTriggeringPolicy
  20. class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
  21. <MaxFileSize>5MB</MaxFileSize>
  22. </TimeBasedFileNamingAndTriggeringPolicy>
  23. </rollingPolicy>
  24. <layout class="ch.qos.logback.classic.PatternLayout">
  25. <pattern>[%-5level] %d{HH:mm:ss.SSS} [%thread] %logger{36} - %msg%n
  26. </pattern>
  27. </layout>
  28. </appender>
  29. <!-- 日志级别 -->
  30. <root>
  31. <!-- 定义了ERROR和INFO级别的日志,分别在FILE文件和控制台输出 -->
  32. <level value="error" />
  33. <level value="info" />
  34. <appender-ref ref="file" />
  35. <appender-ref ref="console" />
  36. </root>
  37. </configuration>

5. 精确设置每个包下面的日志

  1. <logger name="com.xxx" additivity="false">
  2. <level value="info" />
  3. <appender-ref ref="file" />
  4. <appender-ref ref="console" />
  5. </logger>

maven如何配置的更多相关文章

  1. 国内可用maven repository 配置

    国内可用maven repository 配置 发表于2016/1/4 23:08:04  10235人阅读 分类: maven 鉴于一些原因,从maven中央仓库download依赖包时,被各种折磨 ...

  2. MyEclipse中Maven的配置

    之前在MyEclipse这个IDE中配置Maven,完成配置后启动Maven时出现-Dmaven.multiModuleProjectDirectory system propery is not s ...

  3. maven的安装,maven库配置和Eclipse插件的安装

    maven的安装,maven库配置和Eclipse插件的安装 1.下载并解压maven 2.配置环境变量 3.配置maven配置文件 1.下载链接 Downloading Apache Maven 2 ...

  4. Eclipse下Maven插件配置

    要做一个基于C/S架构的汽车租赁系统,由于在实习期间接触过一些Java和SpringMVC,Spring,Hibernate的东西,所以决定使用这个框架组合来完成这个项目. 首先是Maven的配置,为 ...

  5. maven打包配置

    maven打包配置,到底要打包哪些文件,如何配置?? <build> <finalName>weatherAdminSys</finalName> <plug ...

  6. 开发流程和Maven的配置

    按照何种开发模型? V模型:项目需求--->概要设计(功能模块) --->详细设计(页面的设计,数据库的设计) --->编码(框架的搭建,功能的实现)---->测试(单元测试, ...

  7. Eclipse中Maven的配置

    Maven 的配置 1. 安装配置Maven: 1.1 从Apache网站 http://maven.apache.org/ 下载并且解压缩安装Apache Maven 1.2 配置 Maven 的c ...

  8. 【maven教程】(1)---maven环境配置

    maven环境配置 刚开始学习maven,现在项目需要用到maven,而且他确实很好用,也比较容易上手,我也是主要通过视频学习,在写博客的时候也会总结其它人所写 博客,从简到难,如果你也是初学者那接下 ...

  9. Eclipse上Maven环境配置使用 (全)

    Eclipse上Maven环境配置使用 (全) 1. 安装配置Maven: 1.1 从Apache网站 http://maven.apache.org/ 下载并且解压缩安装Apache Maven. ...

  10. Maven 环境配置

    1. 解压maven 2. 配置MAVEN_HOME环境变量 MAVEN_HOME   D:\maven\apache-maven-3.0.5-bin\apache-maven-3.0.5 path  ...

随机推荐

  1. HTML最新标准HTML5小结

    写在前面 HTML5出来已经很久了,然而由于本人不是专业搞前端的,只知道有这个东西,具体概念有点模糊(其实就是一系列标准规范啦):因此去年(2015.11.09),专门对HTML5做了个简单的小结,今 ...

  2. SSIS 实例——将SQL获取的信息传递到Email中

    最近在为公司财务开发一个邮件通知时遇到了一个技术问题.原来我设计SSIS的是每天将ERP系统支付数据导出到财务支付平台后 Email 通知财务,然后财务到支付平台上进行支付操作.由于那个时候开发时间很 ...

  3. 读取properties配置文件的方法

    一般在.properties文件中配置数据库连接的相关信息,我们需要从中读取信息,以便建立与数据库的连接. 文件目录: application.properties配置信息: url=jdbc:ora ...

  4. ASP.NET MVC 初体验

    MVC系列文章终于开始了,前段时间公司项目结束后一直在封装一个html+ashx+js+easyui的权限系统,最近差不多也完成了,迟些时候会分享源码给大家.当然这个MVC系列结束后如果时间允许还会另 ...

  5. 安装Ubuntu的那些事儿

    这是博主第一次写博客,本人虽然目前就读的专业属计算机,但目前也是属于新手上路的那一类人.正好不久前解决了一个困扰了我很久的问题 ,现在拿出来给大家分享一下. 上个学期学校的工作室给大家集中普及linu ...

  6. 测试EntityFramework,Z.EntityFramework.Extensions,原生语句在不同的查询中的表现。原来池化与非池化设定是有巨大的影响的。

    Insert测试,只测试1000条的情况,多了在实际的项目中应该就要另行处理了. using System; using System.Collections.Generic; using Syste ...

  7. 压缩和解压文件:tar gzip bzip2 compress(转)

    tar[必要参数][选择参数][文件] 压缩:tar -czvf filename.tar.gz targetfile解压:tar -zxvf filename.tar.gz参数说明: -c 建立新的 ...

  8. Winform进程、线程

    进程: 一般来说,一个程序就是一个进程,不过也有一个程序需要多个进程支持的情况. 进程要使用的类是:Process它在命名空间:System.Diagnostics; 1.静态方法Start(); 2 ...

  9. ubuntu源笔记

    比如说清华大学的ipv6镜像源:https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/ /etc/apt/sources.list为包管理工具apt的软件包 ...

  10. [LeetCode] Can I Win 我能赢吗

    In the "100 game," two players take turns adding, to a running total, any integer from 1.. ...