有个任务停留在任务列表中很久了:使用Appenders 完成 loger4j 的日志推送
,始终没有成功实现。追其原因,仍然是官方的文档没有认真看。在spring-boot
的项目中看到log4j
,就想当然的认为Spring-boot
使用的是log4j
,然后不假思索的去google
。最终导致的就是:功能没有实现,而且还浪费了很多不必要的时间,最后:还是老老实实的回来阅读spring-boot
的官方文档。
本文主要对官方文档Logging
部分进行解读。
如果你使用的是不是最新版本,那么应该使用
如:
76 日志
在web开中,我们仅需要依赖于spring-boot-starter-web
便自动启用了日志系统Logback
。
如果仅仅是想改变日志的等级,则可以直接使用logging.level
前缀在application.properties
中进行设置,比如:
logging.level.org.springframework.web=DEBUGlogging.level.org.hibernate=ERROR
除了控制日志的等级外,还可以使用logging.file
来定义日志输入到的文件位置。
如果我们还想配置更多选项,则可以在classpath
(resourse)中定义logback.xml
或logback-spring.xml
。
76.1 配置Logback
找到logback.xml
或logback-spring.xml
,复制以下基本内容:
使用idea
的ctrl+o
来打开spring-boot jar中的base.xml
,我们会看到配置信息包含一些特殊的字符,解读如下:
-
${PID}
当前的进程ID -
${LOG_FILE}
如果设置了logging.file
,则使用logging.file
做为日志输入文件。 -
${LOG_PATH}
同上.指定日志输出路径。 -
${LOG_EXCEPTION_CONVERSION_WORD}
..
我们自己定义日志输入的方式和字符串时,当然也可以使用它们了。
76.1.1 配置:将日志仅写入文件
如果我们想禁用控制台的日志输出(生产环境中,我们的确是要这么做的),然后把日志写入某个日志文件的话。那么需要新建logback-spring.xml
,并引入file-appender.xml
,比如:
然后:在application.properties
定义logging.file
来指定日志文件位置.
logging.file=myapplication.log
再看看上面是怎么回事:打开org/springframework/boot/logging/logback/file-appender.xml
内容如下:
${FILE_LOG_PATTERN} ${LOG_FILE} ${LOG_FILE}.%i 10MB
注意:这里面有个<appender name="FILE"
,指定了appender
名称为FILE
,对应logback-spring.xml
的以下语句:
总结
有了以上内容,我们知道了如下知识点:
-
spring-boot
默认使用的是Logback
而非log4j
。 - 我们可以单独建立
logback-spring.xml
来细化Logback
的配置。 - 在
Logback
中,是可以指定使用不同的appender
来定义日志的输出的。 - 是否可以自定义
appender
来达到将日志输出到我们的日志服务器,从而达到系统监控的目的呢?