Log4j2+Maven的配置⽂件⽰例详解
⼀、配置Maven:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<log4j2.version>2.6.2</log4j2.version>
</properties>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j2.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j2.version}</version>
</dependency>
⼆、配置l⽂件:
将配置⽂件放到classpath⽬录下(/root/workspace/lucenedemo/src/main/l
)。
⽂件名:l
<?xml version="1.0" encoding="UTF-8"?>
<!-- status : 指定log4j本⾝的打印⽇志的级别.ALL< Trace < DEBUG < INFO < WARN < ERROR
log4j2不打印日志< FATAL < OFF。 monitorInterval : ⽤于指定log4j⾃动重新配置的监测间隔时间,单位是s,最⼩是5s. -->
<Configuration status="WARN" monitorInterval="30">
<Properties>
<!-- 配置⽇志⽂件输出⽬录 ${sys:user.home} -->
<Property name="LOG_HOME">/root/workspace/lucenedemo/logs</Property>
<property name="ERROR_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/error</property>
<property name="WARN_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/warn</property>
<property name="PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} [%t-%L] %-5level %logger{36} - %msg%n</property>
</Properties>
<Appenders>
<!--这个输出控制台的配置 -->
<Console name="Console" target="SYSTEM_OUT">
<!-- 控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
<ThresholdFilter level="trace" onMatch="ACCEPT"
onMismatch="DENY"/>
<!-- 输出⽇志的格式 -->
<!--
%d{yyyy-MM-dd HH:mm:ss, SSS} : ⽇志⽣产时间
%p : ⽇志输出格式
%c : logger的名称
%m : ⽇志内容,即 logger.info("message")
%n : 换⾏符
%C : Java类名
%L : ⽇志输出所在⾏数
%M : ⽇志输出所在⽅法名
hostName : 本地机器名
hostAddress : 本地ip地址 -->
<PatternLayout
pattern="${PATTERN}"/>
</Console>
<!--⽂件会打印出所有信息,这个log每次运⾏程序会⾃动清空,由append属性决定,这个也挺有⽤的,适合临时测试⽤ -->
<!--append为TRUE表⽰消息增加到指定⽂件中,false表⽰消息覆盖指定的⽂件内容,默认值是true -->
<File name="log" fileName="logs/test.log" append="false">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</File>
<!-- 这个会打印出所有的info及以下级别的信息,每次⼤⼩超过size,
则这size⼤⼩的⽇志会⾃动存⼊按年份-⽉份建⽴的⽂件夹下⾯并进⾏压缩,作为存档 -->
<RollingFile name="RollingFileInfo" fileName="${LOG_HOME}/info.log"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
<!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
<ThresholdFilter level="info" onMatch="ACCEPT"
onMismatch="DENY"/>
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
<Policies>
<!-- 基于时间的滚动策略,interval属性⽤来指定多久滚动⼀次,默认是1 hour。 modulate=true⽤来调整时间:⽐如现在是早上3am,interval是4,那么第⼀次滚动是在4am,接着是8am,⽽不是7am. --> <!-- 关键点在于 filePattern后的⽇期格式,以及TimeBasedTriggeringPolicy的interval,
⽇期格式精确到哪⼀位,interval也精确到哪⼀个单位 -->
<!-- log4j2的按天分⽇志⽂件 : info-%d{yyyy-MM-dd}-%i.log-->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!-- SizeBasedTriggeringPolicy:Policies⼦节点,基于指定⽂件⼤⼩的滚动策略,size属性⽤来定义每个⽇志⽂件的⼤⼩. -->
<!-- <SizeBasedTriggeringPolicy size="2 kB" /> -->
</Policies>
</RollingFile>
<RollingFile name="RollingFileWarn" fileName="${WARN_LOG_FILE_NAME}/warn.log"
filePattern="${WARN_LOG_FILE_NAME}/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log">
<ThresholdFilter level="warn" onMatch="ACCEPT"
onMismatch="DENY"/>
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="2 kB"/>
</Policies>
<!-- DefaultRolloverStrategy属性如不设置,则默认为最多同⼀⽂件夹下7个⽂件,这⾥设置了20 -->
<DefaultRolloverStrategy max="20"/>
</RollingFile>
<RollingFile name="RollingFileError" fileName="${ERROR_LOG_FILE_NAME}/error.log" filePattern="${ERROR_LOG_FILE_NAME}/$${date:yyyy-MM}/error-%d{yyyy-MM-dd-HH-mm}-%i.log"> <ThresholdFilter level="error" onMatch="ACCEPT"
onMismatch="DENY"/>
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> <Policies>
<!-- log4j2的按分钟分⽇志⽂件 : warn-%d{yyyy-MM-dd-HH-mm}-%i.log-->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!-- <SizeBasedTriggeringPolicy size="10 MB" /> -->
</Policies>
</RollingFile>
</Appenders>
<!--然后定义logger,只有定义了logger并引⼊的appender,appender才会⽣效-->
<Loggers>
<!--过滤掉spring和mybatis的⼀些⽆⽤的DEBUG信息-->
<logger name="org.springframework" level="INFO"></logger>
<logger name="batis" level="INFO"></logger>
<!-- 第三⽅⽇志系统 -->
<logger name="" level="info"/>
<logger name="org.springframework.beans" level="info"/>
<logger name="t" level="info"/>
<logger name="org.springframework.web" level="info"/>
<logger name="org.jbossty" level="warn"/>
<logger name="org.apache.http" level="warn"/>
<!-- 配置⽇志的根节点 -->
<root level="all">
<appender-ref ref="Console"/>
<appender-ref ref="RollingFileInfo"/>
<appender-ref ref="RollingFileWarn"/>
<appender-ref ref="RollingFileError"/>
</root>
</Loggers>
</Configuration>
三、使⽤⽰例:
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
private static Logger logger_ = Logger(DateUtils2Joda.class);
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论