log日志格式

<?xml version="1.0" encoding="UTF-8"?>

<!-- scan属性未true时,如果配置文档发生改变将会进行重新加载 -->

<!-- scanPeriod属性设置监测配置文件修改的时间间隔,默认单位为毫秒,在scan为true时才生效 -->

<!-- debug属性如果为true时,会打印出logback内部的日志信息 -->

<configuration scan="true" scanPeriod="60 seconds" debug="false">

<!-- 定义参数常量 -->

<!-- 日志级别:TRACE<DEBUG<INFO<WARN<ERROR,其中常用的是DEBUG、INFO和ERROR -->

<property name="log.level" value="debug" />

<!-- 文件保留时间  60天-->

<property name="log.maxHistory" value="60" />

<!-- 日志存储路径 -->

<property name="log.filePath" value="/opt/logs" />

<!-- 日志的显式格式 -->

<property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50}-%msg%n"></property>

<!-- 用于说明输出介质,此处说明控制台输出 -->

<appender name="consoleAppender" class="ch.qos.logback.core.ConsoleAppender">

<!-- 类似于layout,除了将时间转化为数组,还会将转换后的数组输出到相应的文件中 -->

<encoder>

<!-- 定义日志的输出格式 -->

<pattern>${log.pattern}</pattern>

</encoder>

</appender>

<!-- DEBUG,表示文件随着时间的推移按时间生成日志文件 -->

<appender name="debugAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">

<!-- 文件路径 -->

<file>${log.filePath}/debug.log</file>

<!-- 滚动策略 -->

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<!-- 设置文件名称 -->

<fileNamePattern>

${log.filePath}/debug/debug.%d{yyyy-MM-dd}.log

</fileNamePattern>

<!-- 设置最大保存周期 -->

<MaxHistory>${log.maxHistory}</MaxHistory>

</rollingPolicy>

<encoder>

<pattern>${log.pattern}</pattern>

</encoder>

<!-- 过滤器,过滤掉不是指定日志水平的日志 -->

<filter class="ch.qos.logback.classic.filter.LevelFilter">

<!-- 设置日志级别 -->

<level>DEBUG</level>

<!-- 如果跟该日志水平相匹配,则接受 -->

<onMatch>ACCEPT</onMatch>

<!-- 如果跟该日志水平不匹配,则过滤掉 -->

<onMismatch>DENY</onMismatch>

</filter>

</appender>

<!-- INFO,表示文件随着时间的推移按时间生成日志文件 -->

<appender name="infoAppender"

class="ch.qos.logback.core.rolling.RollingFileAppender">

<!-- 文件路径 -->

<file>${log.filePath}/info.log</file>

<!-- 滚动策略 -->

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<!-- 设置文件名称 -->

<fileNamePattern>

${log.filePath}/info/info.%d{yyyy-MM-dd}.log.gz

</fileNamePattern>

<!-- 设置最大保存周期 -->

<MaxHistory>${log.maxHistory}</MaxHistory>

</rollingPolicy>

<encoder>

<pattern>${log.pattern}</pattern>

</encoder>

<!-- 过滤器,过滤掉不是指定日志水平的日志 -->

<filter class="ch.qos.logback.classic.filter.LevelFilter">

<!-- 设置日志级别 -->

<level>INFO</level>

<!-- 如果跟该日志水平相匹配,则接受 -->

<onMatch>ACCEPT</onMatch>

<!-- 如果跟该日志水平不匹配,则过滤掉 -->

<onMismatch>DENY</onMismatch>

</filter>

</appender>

<!-- ERROR,表示文件随着时间的推移按时间生成日志文件 -->

<appender name="errorAppender"

class="ch.qos.logback.core.rolling.RollingFileAppender">

<!-- 文件路径 -->

<file>${log.filePath}/error.log</file>

<!-- 滚动策略 -->

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<!-- 设置文件名称 -->

<fileNamePattern>

${log.filePath}/error/error.%d{yyyy-MM-dd}.log.gz

</fileNamePattern>

<!-- 设置最大保存周期 -->

<MaxHistory>${log.maxHistory}</MaxHistory>

</rollingPolicy>

<encoder>

<pattern>${log.pattern}</pattern>

</encoder>

<!-- 过滤器,过滤掉不是指定日志水平的日志 -->

<filter class="ch.qos.logback.classic.filter.LevelFilter">

<!-- 设置日志级别 -->

<level>ERROR</level>

<!-- 如果跟该日志水平相匹配,则接受 -->

<onMatch>ACCEPT</onMatch>

<!-- 如果跟该日志水平不匹配,则过滤掉 -->

<onMismatch>DENY</onMismatch>

</filter>

</appender>

<!-- 用于存放日志对象,同时指定关联的package位置 -->

<!-- name指定关联的package -->

<!-- level表明指记录哪个日志级别以上的日志 -->

<!-- appender-ref指定logger向哪个文件输出日志信息 -->

<!-- additivity为true时,logger会把根logger的日志输出地址加入进来,但logger水平不依赖于根logger -->

<logger name="com.campus.o2o" level="${log.level}" additivity="true">

<appender-ref ref="debugAppender" />

<appender-ref ref="infoAppender" />

<appender-ref ref="errorAppender" />

</logger>

<!-- 特殊的logger,根logger -->

<root lever="info">

<!-- 指定默认的日志输出 -->

<appender-ref ref="consoleAppender" />

</root>

</configuration>

————————————————

版权声明:本文为CSDN博主「石硕页」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/u014209205/article/details/80830904

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容