|
@@ -1,156 +1,163 @@
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
-<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
|
|
|
- <property name="LOG_MAX_HISTORY" value="180"/>
|
|
|
|
- <springProperty scope="context" name="LOG_PATH" source="logging.path"/>
|
|
|
|
|
|
+<configuration>
|
|
|
|
+ <springProperty scope="context" name="LOG_MAX_HISTORY" source="logging.fdkk.maxHistory"/>
|
|
|
|
+ <!-- 日志根目录-->
|
|
|
|
+ <springProperty scope="context" name="LOG_HOME" source="logging.file.path"/>
|
|
|
|
|
|
- <!-- 控制台输出 -->
|
|
|
|
- <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
|
|
|
|
- <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
|
|
|
|
+ <!-- 日志级别 -->
|
|
|
|
+ <springProperty scope="context" name="LOG_LEVEL" source="logging.fdkk.level" defaultValue="DEBUG"/>
|
|
|
|
+
|
|
|
|
+ <!-- 标识这个"STDOUT" 将会添加到这个logger -->
|
|
|
|
+ <springProperty scope="context" name="STDOUT" source="log.stdout" defaultValue="STDOUT"/>
|
|
|
|
+
|
|
|
|
+ <!-- 日志文件名称-->
|
|
|
|
+ <property name="LOG_PREFIX" value="720yun"/>
|
|
|
|
+
|
|
|
|
+ <!-- 日志文件编码-->
|
|
|
|
+ <property name="LOG_CHARSET" value="UTF-8"/>
|
|
|
|
+
|
|
|
|
+ <!-- 日志文件路径+日期-->
|
|
|
|
+ <property name="LOG_DIR" value="${LOG_HOME}/%d{yyyyMMdd}"/>
|
|
|
|
+
|
|
|
|
+ <!--对日志进行格式化-->
|
|
|
|
+
|
|
|
|
+ <!--文件大小,默认10MB-->
|
|
|
|
+ <property name="MAX_FILE_SIZE" value="50MB"/>
|
|
|
|
+
|
|
|
|
+ <!-- 配置日志的滚动时间 ,表示只保留最近 10 天的日志-->
|
|
|
|
+ <property name="MAX_HISTORY" value="10"/>
|
|
|
|
+
|
|
|
|
+ <!--输出到控制台-->
|
|
|
|
+ <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
|
|
|
+ <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
|
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
|
|
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
|
|
- <pattern>${LOG_PATH}/%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %X{TRACE_ID} %-5level %logger{50} - %msg%n</pattern>
|
|
|
|
- <!--<charset>utf-8</charset>-->
|
|
|
|
|
|
+ <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
|
|
|
+ <charset>utf-8</charset>
|
|
</encoder>
|
|
</encoder>
|
|
</appender>
|
|
</appender>
|
|
- <!-- 按照每天生成日志文件:主项目日志 -->
|
|
|
|
- <appender name="file.all" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
- <!-- 追加日志到原文件结尾 -->
|
|
|
|
- <Prudent>true</Prudent>
|
|
|
|
|
|
+ <!--输出到文件-->
|
|
|
|
+ <appender name="0" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
+ </appender>
|
|
|
|
+
|
|
|
|
+ <!-- 定义 ALL 日志的输出方式:-->
|
|
|
|
+ <appender name="FILE_ALL" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
+ <!--日志文件路径,日志文件名称-->
|
|
|
|
+ <File>${LOG_HOME}/${LOG_PREFIX}_all.log</File>
|
|
|
|
+ <!-- 设置滚动策略,当天的日志大小超过 ${MAX_FILE_SIZE} 文件大小时候,新的内容写入新的文件, 默认10MB -->
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
- <!--日志文件输出的文件名 -->
|
|
|
|
- <FileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}.%i.log</FileNamePattern>
|
|
|
|
|
|
+ <!--日志文件路径,新的 ALL 日志文件名称,“ i ” 是个变量 -->
|
|
|
|
+ <FileNamePattern>${LOG_DIR}/${LOG_PREFIX}_all%i.log</FileNamePattern>
|
|
|
|
+
|
|
|
|
+ <!-- 配置日志的滚动时间 ,表示只保留最近 10 天的日志-->
|
|
<MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
<MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
|
|
+ <cleanHistoryOnStart>true</cleanHistoryOnStart>
|
|
|
|
+ <!--当天的日志大小超过 ${MAX_FILE_SIZE} 文件大小时候,新的内容写入新的文件, 默认10MB-->
|
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
- <!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
|
|
|
|
- <maxFileSize>10MB</maxFileSize>
|
|
|
|
|
|
+ <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
|
</timeBasedFileNamingAndTriggeringPolicy>
|
|
</timeBasedFileNamingAndTriggeringPolicy>
|
|
</rollingPolicy>
|
|
</rollingPolicy>
|
|
- <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
|
|
|
|
+ <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
|
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
|
|
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
|
|
- <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %X{TRACE_ID} %-5level %logger{500} - %msg%n</pattern>
|
|
|
|
- <!--<charset>utf-8</charset>-->
|
|
|
|
|
|
+ <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n </pattern>
|
|
|
|
+ <charset>utf-8</charset>
|
|
</encoder>
|
|
</encoder>
|
|
</appender>
|
|
</appender>
|
|
|
|
|
|
- <!--info日志统一输出到这里-->
|
|
|
|
- <appender name="file.info" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
- <Prudent>true</Prudent>
|
|
|
|
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
|
- <!--日志文件输出的文件名 每小时生成日志文件 -->
|
|
|
|
- <FileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/info/console-info.%d{yyyy-MM-dd-HH}.%i.log</FileNamePattern>
|
|
|
|
- <MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
|
|
- <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
|
|
- <!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
|
|
|
|
- <maxFileSize>10MB</maxFileSize>
|
|
|
|
- </timeBasedFileNamingAndTriggeringPolicy>
|
|
|
|
- </rollingPolicy>
|
|
|
|
- <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
|
|
- <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
|
|
|
|
- <pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %X{TRACE_ID} %-5level %logger{56}.%method:%L - %msg%n</pattern>
|
|
|
|
- <!--<charset>utf-8</charset>-->
|
|
|
|
- </encoder>
|
|
|
|
- <!-- 此日志文件只记录info级别的 -->
|
|
|
|
|
|
+ <!-- 定义 INFO 日志的输出方式:-->
|
|
|
|
+ <appender name="FILE_INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
+ <!-- 下面为配置只输出error级别的日志 -->
|
|
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
<level>INFO</level>
|
|
<level>INFO</level>
|
|
- <onMatch>ACCEPT</onMatch>
|
|
|
|
- <onMismatch>DENY</onMismatch>
|
|
|
|
|
|
+ <OnMismatch>DENY</OnMismatch>
|
|
|
|
+ <OnMatch>ACCEPT</OnMatch>
|
|
</filter>
|
|
</filter>
|
|
- </appender>
|
|
|
|
-
|
|
|
|
- <!--错误日志统一输出到这里-->
|
|
|
|
- <appender name="file.error" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
- <Prudent>true</Prudent>
|
|
|
|
|
|
+ <append>true</append>
|
|
|
|
+ <!--日志文件路径,日志文件名称-->
|
|
|
|
+ <File>${LOG_HOME}/${LOG_PREFIX}_info.log</File>
|
|
|
|
+ <!-- 设置滚动策略,当天的日志大小超过 ${MAX_FILE_SIZE} 文件大小时候,新的内容写入新的文件, 默认10MB -->
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
- <!--日志文件输出的文件名-->
|
|
|
|
- <FileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/error/console-error.%d{yyyy-MM-dd-HH}.%i.log</FileNamePattern>
|
|
|
|
- <!--日志文件保留天数-->
|
|
|
|
|
|
+
|
|
|
|
+ <!--日志文件路径,新的 INFO 日志文件名称,“ i ” 是个变量 -->
|
|
|
|
+ <FileNamePattern>${LOG_DIR}/${LOG_PREFIX}_info%i.log</FileNamePattern>
|
|
|
|
+
|
|
|
|
+ <!-- 配置日志的滚动时间 ,表示只保留最近 10 天的日志-->
|
|
<MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
<MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
|
|
+ <cleanHistoryOnStart>true</cleanHistoryOnStart>
|
|
|
|
+
|
|
|
|
+ <!--当天的日志大小超过 ${MAX_FILE_SIZE} 文件大小时候,新的内容写入新的文件, 默认10MB-->
|
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
- <!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
|
|
|
|
- <maxFileSize>10MB</maxFileSize>
|
|
|
|
|
|
+ <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
|
</timeBasedFileNamingAndTriggeringPolicy>
|
|
</timeBasedFileNamingAndTriggeringPolicy>
|
|
</rollingPolicy>
|
|
</rollingPolicy>
|
|
- <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
|
|
- <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
|
|
|
|
- <pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %X{TRACE_ID} %-5level %logger{56}.%method:%L - %msg%n</pattern>
|
|
|
|
- <!--<charset>utf-8</charset>-->
|
|
|
|
|
|
+
|
|
|
|
+ <!-- 输出的日志内容格式化-->
|
|
|
|
+ <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
|
|
|
+ <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
|
|
|
|
+ <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n </pattern>
|
|
|
|
+ <charset>utf-8</charset>
|
|
</encoder>
|
|
</encoder>
|
|
- <!-- 此日志文件只记录error级别的 -->
|
|
|
|
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
|
|
- <level>ERROR</level>
|
|
|
|
- <onMatch>ACCEPT</onMatch>
|
|
|
|
- <onMismatch>DENY</onMismatch>
|
|
|
|
- </filter>
|
|
|
|
</appender>
|
|
</appender>
|
|
|
|
|
|
- <!--warn日志统一输出到这里-->
|
|
|
|
- <appender name="file.warn" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
- <Prudent>true</Prudent>
|
|
|
|
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
|
- <!--日志文件输出的文件名 按小时生成日志-->
|
|
|
|
- <FileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/warn/console-warn.%d{yyyy-MM-dd-HH}.%i.log</FileNamePattern>
|
|
|
|
- <!--日志文件保留天数-->
|
|
|
|
- <MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
|
|
- <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
|
|
- <!-- 除按日志记录之外,还配置了日志文件不能超过10M(默认),若超过10M,日志文件会以索引0开始, -->
|
|
|
|
- <maxFileSize>10MB</maxFileSize>
|
|
|
|
- </timeBasedFileNamingAndTriggeringPolicy>
|
|
|
|
- </rollingPolicy>
|
|
|
|
- <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
|
|
- <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
|
|
|
|
- <pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %X{TRACE_ID} %-5level %logger{56}.%method:%L - %msg%n</pattern>
|
|
|
|
- <!--<charset>utf-8</charset>-->
|
|
|
|
- </encoder>
|
|
|
|
- <!-- 此日志文件只记录warn级别的 -->
|
|
|
|
|
|
+ <!-- 定义 ERROR 日志的输出方式:-->
|
|
|
|
+ <appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
+ <!-- 下面为配置只输出error级别的日志 -->
|
|
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
- <level>WARN</level>
|
|
|
|
- <onMatch>ACCEPT</onMatch>
|
|
|
|
- <onMismatch>DENY</onMismatch>
|
|
|
|
|
|
+ <level>ERROR</level>
|
|
|
|
+ <OnMismatch>DENY</OnMismatch>
|
|
|
|
+ <OnMatch>ACCEPT</OnMatch>
|
|
</filter>
|
|
</filter>
|
|
- </appender>
|
|
|
|
|
|
+ <!--日志文件路径,日志文件名称-->
|
|
|
|
+ <File>${LOG_HOME}/${LOG_PREFIX}_err.log</File>
|
|
|
|
|
|
- <!--debug级别日志统一输出到这里-->
|
|
|
|
- <appender name="file.debug" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
|
- <Prudent>true</Prudent>
|
|
|
|
|
|
+ <!-- 设置滚动策略,当天的日志大小超过 ${MAX_FILE_SIZE} 文件大小时候,新的内容写入新的文件, 默认10MB -->
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
- <!--日志文件输出的文件名 按小时生成日志-->
|
|
|
|
- <FileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/debug/console-debug.%d{yyyy-MM-dd-HH}.%i.log</FileNamePattern>
|
|
|
|
- <!--日志文件保留天数-->
|
|
|
|
|
|
+
|
|
|
|
+ <!--日志文件路径,新的 ERR 日志文件名称,“ i ” 是个变量 -->
|
|
|
|
+ <FileNamePattern>${LOG_DIR}/${LOG_PREFIX}_err%i.log</FileNamePattern>
|
|
|
|
+
|
|
|
|
+ <!-- 配置日志的滚动时间 ,表示只保留最近 10 天的日志-->
|
|
<MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
<MaxHistory>${LOG_MAX_HISTORY}</MaxHistory>
|
|
- <!-- 除按日志记录之外,还配置了日志文件不能超过5M,若超过5M,日志文件会以索引0开始,命名日志文件,例如console-debug.2018-08-24-09.1.log -->
|
|
|
|
|
|
+ <cleanHistoryOnStart>true</cleanHistoryOnStart>
|
|
|
|
+
|
|
|
|
+ <!--当天的日志大小超过 ${MAX_FILE_SIZE} 文件大小时候,新的内容写入新的文件, 默认10MB-->
|
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
- <maxFileSize>10MB</maxFileSize>
|
|
|
|
|
|
+ <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
|
</timeBasedFileNamingAndTriggeringPolicy>
|
|
</timeBasedFileNamingAndTriggeringPolicy>
|
|
</rollingPolicy>
|
|
</rollingPolicy>
|
|
- <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
|
|
- <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %method 方法名 %L 行数 %msg:日志消息,%n是换行符-->
|
|
|
|
- <pattern> %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %X{TRACE_ID} %-5level %logger{56}.%method:%L - %msg%n</pattern>
|
|
|
|
- <!--<charset>utf-8</charset>-->
|
|
|
|
|
|
+
|
|
|
|
+ <!-- 输出的日志内容格式化-->
|
|
|
|
+ <encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
|
|
|
+ <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
|
|
|
|
+ <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
|
|
|
+ <charset>utf-8</charset>
|
|
</encoder>
|
|
</encoder>
|
|
- <!-- 此日志文件只记录debug级别的 -->
|
|
|
|
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
|
|
- <level>DEBUG</level>
|
|
|
|
- <onMatch>ACCEPT</onMatch>
|
|
|
|
- <onMismatch>DENY </onMismatch>
|
|
|
|
- </filter>
|
|
|
|
</appender>
|
|
</appender>
|
|
|
|
|
|
- <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->
|
|
|
|
- <appender name="file.async" class="ch.qos.logback.classic.AsyncAppender">
|
|
|
|
- <discardingThreshold>0</discardingThreshold>
|
|
|
|
- <queueSize>256</queueSize>
|
|
|
|
- <includeCallerData>true</includeCallerData>
|
|
|
|
- <appender-ref ref="file.all" />
|
|
|
|
- </appender>
|
|
|
|
|
|
+ <logger name="org.springframework" level="ERROR"/>
|
|
|
|
+ <logger name="org.apache.commons" level="ERROR"/>
|
|
|
|
+ <logger name="com.alibaba.dubbo.monitor" level="ERROR"/>
|
|
|
|
+ <logger name="com.alibaba.dubbo.remoting" level="ERROR"/>
|
|
|
|
+ <logger name="com.apache.ibatis" level="${LOG_LEVEL}"/>
|
|
|
|
+ <logger name="java.sql.Connection" level="${LOG_LEVEL}"/>
|
|
|
|
+ <logger name="java.sql.Statement" level="${LOG_LEVEL}"/>
|
|
|
|
+ <logger name="java.sql.PreparedStatement" level="${LOG_LEVEL}"/>
|
|
|
|
+ <logger name="io.lettuce.core.protocol" level="ERROR"/>
|
|
|
|
+ <logger name="io.lettuce.core" level="ERROR"/>
|
|
|
|
|
|
- <!-- 日志输出级别 -->
|
|
|
|
- <!-- TRACE\DEBUG\INFO\WARN\ERROR\FATAL\OFF -->
|
|
|
|
|
|
+ <!-- ${LOG_ROOT_LEVEL} 日志级别 -->
|
|
<root level="INFO">
|
|
<root level="INFO">
|
|
- <appender-ref ref="console" />
|
|
|
|
- <appender-ref ref="file.async"/>
|
|
|
|
- <appender-ref ref="file.error" />
|
|
|
|
- <appender-ref ref="file.info" />
|
|
|
|
- <appender-ref ref="file.debug" />
|
|
|
|
- <appender-ref ref="file.warn" />
|
|
|
|
|
|
+
|
|
|
|
+ <!-- 标识这个"${STDOUT}"将会添加到这个logger -->
|
|
|
|
+ <appender-ref ref="STDOUT"/>
|
|
|
|
+
|
|
|
|
+ <!-- FILE_ALL 日志输出添加到 logger -->
|
|
|
|
+ <appender-ref ref="FILE_ALL"/>
|
|
|
|
+
|
|
|
|
+ <!-- FILE_INFO 日志输出添加到 logger -->
|
|
|
|
+ <appender-ref ref="FILE_INFO"/>
|
|
|
|
+
|
|
|
|
+ <!-- FILE_ERROR 日志输出添加到 logger -->
|
|
|
|
+ <appender-ref ref="FILE_ERROR"/>
|
|
</root>
|
|
</root>
|
|
|
|
|
|
-</configuration>
|
|
|
|
|
|
+</configuration>
|