在生产环境下,日志是最好的问题调试和跟踪方法,因此日志的地位是十分重要的。我们平时经常使用的log4j,slf4j,logback等等,他们的配置上大同小异。这里就结合spring boot配置一下logback的日志。
默认最简单的配置
默认情况下,如果对日志没有特殊处理,可以直接基于application.properties进行配置。
常用的参数有:
1
|
logging.level
|
配置日志的级别
1
2
|
logging.file
logging.path
|
这两个参数只能配置一个生效,一个是文件(可以有绝对路径或者相对路径);另一个是路径,文件的名称会默认为spring.log
日志默认按照大小进行切分,由于我这边没有产生那么大的文件,因此没有做实验。
这种方法最简单,但是不能处理那种复杂的日志轮转的机制。比如没天一个文件这种需求,因此可以考虑使用独立的日志文件进行配置:
使用独立的配置文件配置
如果有复杂的需求,可以像其他普通的web应用一样,配置独立的logback.xml:
首先注意的是这个文件必须放在resources目录下(我这边发现,如果通过logging.config指向另一个目录下的logback.xml会在程序启动时报错,报无法解析该xml。猜想可能是在其他目录下的xml都被当做spring的配置或者有xml schema信息的配置,单纯的logback.xml它不认识)
然后在application.properties文件中加入:
1
2
|
# 配置logback
logging.config=classpath:logback-spring.xml
|
即可。
注意如果是logging.config=classpath:xxxx/logback-spring.xml,
就不行了哈!我试过好多次!
配置的内容基本可以参考下面的来:
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
|
<?xml version= "1.0" encoding= "utf-8" ?>
<configuration>
<!-- 属性文件 -->
<property name= "processname" value= "xxx" />
<property name= "logdir" value= "/opt/logs/xxx" />
<!-- 默认的控制台日志输出,一般生产环境都是后台启动,这个没太大作用 -->
<appender name= "stdout" class = "ch.qos.logback.core.consoleappender" >
<!--<encoding>utf- 8 </encoding>-->
<layout class = "ch.qos.logback.classic.patternlayout" >
<pattern>%date [%thread] %-5level %logger{ 50 }:%l - %msg%n</pattern>
</layout>
</appender>
<!-- 配置文件轮转 -->
<appender name= "logfile" class = "ch.qos.logback.core.rolling.rollingfileappender" >
<!--<encoding>utf- 8 </encoding>-->
<file>${logdir}/service.log</file>
<rollingpolicy class = "ch.qos.logback.core.rolling.timebasedrollingpolicy" >
<filenamepattern>${logdir}/history/service.%d{yyyy-mm-dd}.log.gz</filenamepattern>
<maxhistory> 30 </maxhistory>
</rollingpolicy>
<layout class = "ch.qos.logback.classic.patternlayout" >
<pattern>%date [%thread] %-5level %logger{ 50 }:%l - %msg%n</pattern>
</layout>
</appender>
<!-- 修改其他包的日志输出级别 -->
<logger name= "org.apache.zookeeper" >
<level value= "warn" />
</logger>
<!-- root 默认日志配置 , 注意这里的级别哈!小心生产环境用debug,压爆你的磁盘!-->
<root level= "info" >
<appender-ref ref= "logfile" />
<appender-ref ref= "stdout" />
</root>
</configuration>
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/xing901022/p/7453909.html