log4j2.xml 的配置文件放在classpath下就會被自動加載,其配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<!--
status : 這個用于設置log4j2自身內部的信息輸出,可以不設置,當設置成trace時,會看到log4j2內部各種詳細輸出
monitorInterval : Log4j能夠自動檢測修改配置文件和重新配置本身, 設置間隔秒數(shù)。
-->
<Configuration status="WARN" monitorInterval="600">
<Properties>
<!-- 配置日志文件輸出目錄 -->
<Property name="LOG_HOME">./logs</Property>
</Properties>
<Appenders>
<!--這個輸出控制臺的配置-->
<Console name="Console" target="SYSTEM_OUT">
<!-- 控制臺只輸出level及以上級別的信息(onMatch),其他的直接拒絕(onMismatch) -->
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
<!-- 輸出日志的格式 -->
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
</Console>
<!-- 設置日志格式并配置日志壓縮格式(sinfo.log.日期.gz) -->
<RollingRandomAccessFile name="sinfo_appender"
immediateFlush="false" fileName="${LOG_HOME}/sinfo.log"
filePattern="${LOG_HOME}/service.log.%d{yyyy-MM-dd}.log.gz">
<!--
%d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生產時間
%p : 日志輸出格式
%c : logger的名稱
%m : 日志內容,即 logger.info("message")
%n : 換行符
%C : Java類名
%L : 日志輸出所在行數(shù)
%M : 日志輸出所在方法名
hostName : 本地機器名
hostAddress : 本地ip地址
-->
<PatternLayout>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36} %L %M -- %msg%xEx%n</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1" modulate="true" />
</Policies>
</RollingRandomAccessFile>
<!-- DEBUG日志格式 -->
<RollingRandomAccessFile name="sinfo_debug_appender"
immediateFlush="false" fileName="${LOG_HOME}/sinfo.log"
filePattern="${LOG_HOME}/sinfo.log.%d{yyyy-MM-dd}.debug.gz">
<PatternLayout>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36} %L %M -- %msg%xEx%n</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1" modulate="true" />
</Policies>
</RollingRandomAccessFile>
</Appenders>
<Loggers>
<!-- 配置日志的根節(jié)點 -->
<root level="info">
<appender-ref ref="Console"/>
</root>
<!-- 第三方日志系統(tǒng) -->
<logger name="org.springframework.core" level="info"/>
<logger name="org.springframework.beans" level="info"/>
<logger name="org.springframework.context" level="info"/>
<logger name="org.springframework.web" level="info"/>
<logger name="org.jboss.netty" level="warn"/>
<logger name="org.apache.http" level="warn"/>
<!-- 日志實例(info),其中'service-log'繼承root,但是root將日志輸出控制臺,而'service-log'將日志輸出到文件,通過屬性'additivity="false"'將'service-log'的
的日志不再輸出到控制臺 -->
<logger name="sinfo_log" level="info" includeLocation="true" additivity="true">
<appender-ref ref="sinfo_appender"/>
</logger>
<!-- 日志實例(debug) -->
<logger name="sinfo_log" level="info" includeLocation="true" additivity="false">
<appender-ref ref="sinfo_debug_appender"/>
</logger>
</Loggers>
</Configuration>