四、Logback的默认配置
如果配置文件 logback-test.xml 和 logback.xml 都不存在,那么 logback 默认地会调用BasicConfigurator ,创建一个最小化配置。最小化配置由一个关联到根 logger 的ConsoleAppender 组成。输出用模式为%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n的 PatternLayoutEncoder 进行格式化。root logger 默认级别是 DEBUG。
1、Logback的配置文件
Logback 配置文件的语法非常灵活。正因为灵活,所以无法用 DTD 或 XML schema 进行定义。尽管如此,可以这样描述配置文件的基本结构:以<configuration>开头,后面有零个或多个<appender>元素,有零个或多个<logger>元素,有最多一个<root>元素。
2、Logback默认配置的步骤
(1). 尝试在 classpath 下查找文件 logback-test.xml;
(2). 如果文件不存在,则查找文件 logback.xml;
(3). 如果两个文件都不存在,logback 用 Bas icConfigurator 自动对自己进行配置,这会导致记录输出到控制台。
3、logback.xml 文件
1 <?xml version="1.0" encoding="UTF-8"?> 2 <configuration> 3 <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径--> 4 <property name="LOG_HOME" value="c:/log" /> 5 <!-- 控制台输出 --> 6 <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> 7 <!-- 日志输出编码 --> 8 <Encoding>UTF-8</Encoding> 9 <layout class="ch.qos.logback.classic.PatternLayout"> 10 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符--> 11 <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n 12 </pattern> 13 </layout> 14 </appender> 15 <!-- 按照每天生成日志文件 --> 16 <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> 17 <Encoding>UTF-8</Encoding> 18 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> 19 <!--日志文件输出的文件名--> 20 <FileNamePattern>${LOG_HOME}/myApp.log.%d{yyyy-MM-dd}.log</FileNamePattern> 21 <MaxHistory>30</MaxHistory> 22 </rollingPolicy> 23 <layout class="ch.qos.logback.classic.PatternLayout"> 24 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符--> 25 <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n 26 </pattern> 27 </layout> 28 <!--日志文件最大的大小--> 29 <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> 30 <MaxFileSize>10MB</MaxFileSize> 31 </triggeringPolicy> 32 </appender> 33 <!-- show parameters for hibernate sql 专为 Hibernate 定制 --> 34 <logger name="org.hibernate.type.descriptor.sql.BasicBinder" level="TRACE" /> 35 <logger name="org.hibernate.type.descriptor.sql.BasicExtractor" level="DEBUG" /> 36 <logger name="org.hibernate.SQL" level="DEBUG" /> 37 <logger name="org.hibernate.engine.QueryParameters" level="DEBUG" /> 38 <logger name="org.hibernate.engine.query.HQLQueryPlan" level="DEBUG" /> 39 40 <!-- 日志输出级别 --> 41 <root level="INFO"> 42 <appender-ref ref="STDOUT" /> 43 <appender-ref ref="FILE" /> 44 </root> 45 46 <!--日志异步到数据库 --> 47 <appender name="DB" class="ch.qos.logback.classic.db.DBAppender"> 48 <!--日志异步到数据库 --> 49 <connectionSource class="ch.qos.logback.core.db.DriverManagerConnectionSource"> 50 <!--连接池 --> 51 <dataSource class="com.mchange.v2.c3p0.ComboPooledDataSource"> 52 <driverClass>com.mysql.jdbc.Driver</driverClass> 53 <url>jdbc:mysql://127.0.0.1:3306/databaseName</url> 54 <user>root</user> 55 <password>root</password> 56 </dataSource> 57 </connectionSource> 58 </appender> --> 59 </configuration>
五、在程序用引用logback
1 package com.stu.system.action; 2 3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5 6 public class BlogAction{ 7 //定义一个全局的记录器,通过LoggerFactory获取 8 private final static Logger logger = LoggerFactory.getLogger(BlogAction.class); 9 /** 10 * @param args 11 */ 12 public static void main(String[] args) { 13 logger.info("logback 成功了"); 14 logger.error("logback 成功了"); 15 } 16 }