转自:http://www.importnew.com/22290.html
概述
LogBack是一个日志框架,它与Log4j可以说是同出一源,都出自Ceki Gülcü之手。(log4j的原型是早前由Ceki Gülcü贡献给Apache基金会的)下载地址:http://logback.qos.ch/download.html
LogBack、Slf4j和Log4j之间的关系
Slf4j是The Simple Logging Facade for Java的简称,是一个简单日志门面抽象框架,它本身只提供了日志Facade API和一个简单的日志类实现,一般常配合Log4j,LogBack,java.util.logging使用。Slf4j作为应用层的Log接入时,程序可以根据实际应用场景动态调整底层的日志实现框架(Log4j/LogBack/JdkLog…)。
LogBack和Log4j都是开源日记工具库,LogBack是Log4j的改良版本,比Log4j拥有更多的特性,同时也带来很大性能提升。详细数据可参照下面地址:Reasons to prefer logback over log4j。
LogBack官方建议配合Slf4j使用,这样可以灵活地替换底层日志框架。
TIPS:为了优化log4j,以及更大性能的提升,Apache基金会已经着手开发了log4j 2.0, 其中也借鉴和吸收了logback的一些先进特性,目前log4j2还处于beta阶段。
LogBack的结构
LogBack被分为3个组件,logback-core, logback-classic 和 logback-access。
其中logback-core提供了LogBack的核心功能,是另外两个组件的基础。
logback-classic则实现了Slf4j的API,所以当想配合Slf4j使用时,需要将logback-classic加入classpath。
logback-access是为了集成Servlet环境而准备的,可提供HTTP-access的日志接口。
配置详解
根节点包含的属性
- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true.
- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟.
- debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。
XML代码:
1
2
3
|
|
根节点的子节点
LogBack的配置大概包括3部分:appender, logger和root。
设置上下文名称
每个logger都关联到logger上下文,默认上下文名称为“default”。但可以使用
XML代码:
1
2
3
4
|
|
设置变量
用来定义变量值的标签,
例如使用
1
2
3
4
5
|
|
获取时间戳字符串
两个属性 key:标识此
例如将解析配置文件的时间作为上下文名称:
1
2
3
4
5
|
|
设置logger和root
用来设置某一个包或者具体的某一个类的日志打印级别、以及指定
- name:用来指定受此logger约束的某一个包或者具体的某一个类。
- level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,还有一个特殊值INHERITED或者同义词NULL,代表强制执行上级的级别。
如果未设置此属性,那么当前logger将会继承上级的级别。 - additivity:是否向上级logger传递打印信息。默认是true。
也是
- level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,不能设置为INHERITED或者同义词NULL。默认是DEBUG。
案例介绍
首先,Java类如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
package
logback;
import
org.slf4j.Logger;
import
org.slf4j.LoggerFactory;
public
class
LogbackDemo {
private
static
Logger log = LoggerFactory.getLogger(LogbackDemo.
class
);
public
static
void
main(String[] args) {
log.trace(
"======trace"
);
log.debug(
"======debug"
);
log.info(
"======info"
);
log.warn(
"======warn"
);
log.error(
"======error"
);
}
}
|
logback.xml配置文件
只配置root
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
36
} - %msg%n
|
其中appender的配置表示打印到控制台(稍后详细讲解appender )。
当执行logback.LogbackDemo类的main方法时,root将级别为“INFO”及大于“INFO”的日志信息交给已经配置好的名为“STDOUT”的appender处理,“STDOUT”appender将信息打印到控制台;
输出结果:
1
2
3
|
13
:
30
:
38.484
[main] INFO logback.LogbackDemo - ======info
13
:
30
:
38.500
[main] WARN logback.LogbackDemo - ======warn
13
:
30
:
38.500
[main] ERROR logback.LogbackDemo - ======error
|
带有logger的配置,不指定级别,不指定appender
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
36
} - %msg%n
|
其中appender的配置表示打印到控制台。
输出结果:
1
2
3
4
|
13
:
19
:
15.406
[main] DEBUG logback.LogbackDemo - ======debug
13
:
19
:
15.406
[main] INFO logback.LogbackDemo - ======info
13
:
19
:
15.406
[main] WARN logback.LogbackDemo - ======warn
13
:
19
:
15.406
[main] ERROR logback.LogbackDemo - ======error
|
没有设置additivity,默认为true,将此logger的打印信息向上级传递。
没有设置appender,此logger本身不打印任何信息。
当执行logback.LogbackDemo类的main方法时,因为LogbackDemo 在包logback中,所以首先执行
root接到下级传递的信息,交给已经配置好的名为“STDOUT”的appender处理,“STDOUT”appender将信息打印到控制台。
带有多个logger的配置,指定级别,指定appender
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
36
} - %msg%n
|
输出结果:
1
2
3
|
14
:
05
:
35.937
[main] INFO logback.LogbackDemo - ======info
14
:
05
:
35.937
[main] WARN logback.LogbackDemo - ======warn
14
:
05
:
35.937
[main] ERROR logback.LogbackDemo - ======error
|
没有设置additivity,默认为true,将此logger的打印信息向上级传递。
没有设置appender,此logger本身不打印任何信息。
additivity属性为false,表示此logger的打印信息不再向上级传递,指定了名字为“STDOUT”的appender。
当执行logback.LogbackDemo类的main方法时,先执行
如果将
没错,日志打印了两次,想必大家都知道原因了,因为打印信息向上级传递,logger本身打印一次,root接到后又打印一次:
1
2
3
4
5
6
|
14
:
09
:
01.531
[main] INFO logback.LogbackDemo - ======info
14
:
09
:
01.531
[main] INFO logback.LogbackDemo - ======info
14
:
09
:
01.531
[main] WARN logback.LogbackDemo - ======warn
14
:
09
:
01.531
[main] WARN logback.LogbackDemo - ======warn
14
:
09
:
01.531
[main] ERROR logback.LogbackDemo - ======error
14
:
09
:
01.531
[main] ERROR logback.LogbackDemo - ======error
|
详解
ConsoleAppender
把日志添加到控制台,有以下子节点:
:对日志进行格式化。(具体参数稍后讲解 ) :字符串 System.out 或者 System.err ,默认 System.out .
1
2
3
4
5
6
7
8
9
10
11
|
35
} - %msg %n
|
FileAppender
把日志添加到文件,有以下子节点:
:被写入的文件名,可以是相对目录,也可以是绝对目录,如果上级目录不存在会自动创建,没有默认值。 :如果是 true,日志被追加到文件结尾,如果是 false,清空现存文件,默认是true。 :对记录事件进行格式化。(具体参数稍后讲解 ) :如果是 true,日志会被安全的写入文件,即使其他的FileAppender也在向此文件做写入操作,效率低,默认是 false。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
true
35
} - %msg%n
|
RollingFIleAppender
滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件。有以下子节点:
:被写入的文件名,可以是相对目录,也可以是绝对目录,如果上级目录不存在会自动创建,没有默认值。 :如果是 true,日志被追加到文件结尾,如果是 false,清空现存文件,默认是true。 :对记录事件进行格式化。(具体参数稍后讲解 ) :当发生滚动时,决定 RollingFileAppender 的行为,涉及文件移动和重命名。 : 告知 RollingFileAppender 何时激活滚动。 :当为true时,不支持FixedWindowRollingPolicy。支持TimeBasedRollingPolicy,但是有两个限制,1不支持也不允许文件压缩,2不能设置file属性,必须留空。
>>>>rollingPolicy
- TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责触发滚动。有以下子节点:
- FixedWindowRollingPolicy: 根据固定窗口算法重命名文件的滚动策略。有以下子节点:
>>>>triggeringPolicy
- SizeBasedTriggeringPolicy: 查看当前活动文件的大小,如果超过指定大小会告知RollingFileAppender 触发当前活动文件滚动。只有一个节点:
例如:每天生产一个日志文件,保存30天的日志文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
30
35
} - %msg%n
|
又例如:按照固定窗口模式生成日志文件,当文件大于20MB时,生成新的日志文件。窗口大小是1到3,当保存了3个归档文件后,将覆盖最早的日志。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
1
3
35
} - %msg%n
|
另外还有SocketAppender、SMTPAppender、DBAppender、SyslogAppender、SiftingAppender,并不常用,这些就不在这里讲解了,大家可以参考官方文档。当然大家可以编写自己的Appender。
负责两件事,一是把日志信息转换成字节数组,二是把字节数组写入到输出流。
目前PatternLayoutEncoder 是唯一有用的且默认的encoder ,有一个
例如:
1
2
3
|
35
} - %msg%n
|
格式修饰符,与转换符共同使用:
可选的格式修饰符位于“%”和转换符之间。第一个可选修饰符是左对齐 标志,符号是减号“-”;接着是可选的最小宽度 修饰符,用十进制数表示。如果字符小于最小宽度,则左填充或右填充,默认是左填充(即右对齐),填充符为空格。如果字符大于最小宽度,字符永远不会被截断。最大宽度 修饰符,符号是点号”.”后面加十进制数。如果字符大于最大宽度,则从前面截断。点符号“.”后面加减号“-”在加数字,表示从尾部截断。
例如:%-4relative 表示,将输出从程序启动到创建日志记录的时间 进行左对齐 且最小宽度为4。
完整配置案例
最后附上相对比较完整的,涵盖大部分配置的案例,案例中有解析。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
|
0
} %msg%n
8
true
0
} %msg%n
8
0
} %msg%n
8
30
0
} %msg%n
8
1
3
30
0
512
|