标签:style http color io os java ar 文件 数据
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!-- 控制台输出 -->
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
</encoder>
</appender>
<!-- 时间滚动输出 level为 DEBUG 日志 -->
<appender name="file—debug"
class="ch.qos.logback.core.rolling.RollingFileAppender">
在这里存在一个过滤的行为,一旦您需要用到EvaluatorFilter过滤器来过滤Msg日志中的特殊字符需要导入
其的依赖包janino-2.3.2.jar
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>DEBUG</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY </onMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<FileNamePattern>D:/logs/debug.%d{yyyy-MM-dd}.log</FileNamePattern>
<MaxHistory>30</MaxHistory>
</rollingPolicy>
<encoder>
<pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
</encoder>
</appender>
<!-- 时间滚动输出 level为 ERROR 日志 -->
<appender name="file—error"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY </onMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<FileNamePattern>D:/logs/error.%d{yyyy-MM-dd}.log</FileNamePattern>
<MaxHistory>30</MaxHistory>
</rollingPolicy>
<encoder>
<pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
</encoder>
</appender>
<!-- 特定过滤含有某字符串的日志 -->
<appender name="file-str"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("str")</expression>
</evaluator>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<FileNamePattern>D:/logs/contains.%d{yyyy-MM-dd}.log
</FileNamePattern>
<MaxHistory>30</MaxHistory>
</rollingPolicy>
<encoder>
<pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
</encoder>
</appender>
<!-- 数据库输出 -->
<appender name="db" class="ch.qos.logback.classic.db.DBAppender">
<connectionSource
class="ch.qos.logback.core.db.DriverManagerConnectionSource">
<driverClass>com.mysql.jdbc.Driver</driverClass>
<url>jdbc:mysql://host_name:3306/datebase_name</url>
<user>username</user>
<password>password</password>
</connectionSource>
</appender>
<logger name="java.sql.Connection">
<level value="DEBUG" />
</logger>
<logger name="java.sql.Statement">
<level value="DEBUG" />
</logger>
<logger name="com.ibatis">
<level value="DEBUG" />
</logger>
<logger name="com.ibatis.common.jdbc.SimpleDataSource">
<level value="DEBUG" />
</logger>
<logger name="com.ibatis.common.jdbc.ScriptRunner">
<level value="DEBUG" />
</logger>
<logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate">
<level value="DEBUG" />
</logger>
<logger name="com.danga.MemCached">
<level value="INFO" />
</logger>
<logger name="org.springframework.test">
<level value="DEBUG" />
</logger>
<logger name="org.apache.struts2">
<level value="DEBUG" />
</logger>
<root level="DEBUG">
<appender-ref ref="stdout" />
<appender-ref ref="file—debug" />
<appender-ref ref="file—error" />
<appender-ref ref="file-str" />
<appender-ref ref="db" />
</root>
</configuration>
对于Logback的简单说明:
1、Logback为取代log4j而生
Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。
2、Logback的核心对象:Logger、Appender、Layout
Logback主要建立于Logger、Appender 和 Layout 这三个类之上。
1 : Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也可以定义日志类型、级别。Logger对象一般多定义为静态常量,如:
2: Appender:用于指定日志输出的目的地,目的地可以是控制台,文件,远程套接字,Mysql,PostreSQL,Oracle,和其他数据库
3:layout:负责把时间转换成字符串,格式话的日志信息的输出.
3 Level的幼小的级别,Logger可以分配级别,级别包括:trace,Debug,Info,Warn,和Error,定义于
ch.qos.logback.classic.Level类,程序会打印高于或者等于所设置级别的izhi,设置级别的日志等级越高,打印出来的日
志就越少,如果设置级别为info的日志信息可以被输出,小于该级别的如DEBUG不会被输出,为确保所有logger都能最
终继承一个级别,因此根的logger也总是有级别,一般而言,这个级别是DEBUG
4:三值逻辑
在logback的过滤器基于三值逻辑,允许把他们组装成为链条,从而组装成任意符合过滤策略,过滤器很大的程度上受到了 iptables的启发,这里所谓三值逻辑是说:
如果返回Deny, 那么记录时间立即被抛弃,不在经过剩余的过滤器
如果返回Neutral,那么有序列表里的下一个过滤器会接着处理记录事件
如果返回Accept,那么记录时间被立即处理,不再经过剩余的过滤器
5 Filter 过滤
logback-classic 提供两种类型的过滤:
5.1: 常规过滤器
5.2:TuroboFilter过滤器
整体的日志处理流程如下图:

标签:style http color io os java ar 文件 数据
原文地址:http://my.oschina.net/u/1791874/blog/312308