<?xml version="1.0" encoding="UTF-8"?>
<!-- status : 指定log4j本身的打印日志的级别.ALL< Trace < DEBUG < INFO < WARN < ERROR
< FATAL < OFF。 monitorInterval : 用于指定log4j自动重新配置的监测间隔时间,单位是s,最小是5s. -->
<Configuration status="ALL" monitorInterval="30">
<Properties>
<!-- 配置日志文件输出目录 ${sys:user.home} -->
<!--共有8个级别,按照从低到高为:All < Trace < Debug < Info < Warn < Error < Fatal < OFF.
All:最低等级的,用于打开所有日志记录.
Trace:是追踪,就是程序推进以下,你就可以写个trace输出,所以trace应该会特别多,不过没关系,我们可以设置最低日志级别不让他输出.
Debug:指出细粒度信息事件对调试应用程序是非常有帮助的.
Info:消息在粗粒度级别上突出强调应用程序的运行过程.
Warn:输出警告及warn以下级别的日志.
Error:输出错误信息日志.
Fatal:输出每个严重的错误事件将会导致应用程序的退出的日志.
OFF:最高等级的,用于关闭所有日志记录-->
<Property name="LOG_HOME"><!--/home/liuhua/gongzuokongjian1/idea/TestDataCom/-->logs112</Property>
<property name="ERROR_LOG_FILE_NAME"><!--/home/liuhua/gongzuokongjian1/idea/TestDataCom/logs-->${LOG_HOME}/error</property>
<property name="WARN_LOG_FILE_NAME"><!--/home/liuhua/gongzuokongjian1/idea/TestDataCom/logs-->${LOG_HOME}/warn</property>
<property name="INFO_LOG_FILE_NAME"><!--/home/liuhua/gongzuokongjian1/idea/TestDataCom/logs-->${LOG_HOME}/info</property>
<property name="DEBUG_LOG_FILE_NAME"><!--/home/liuhua/gongzuokongjian1/idea/TestDataCom/logs-->${LOG_HOME}/debug</property>
<property name="PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} [%M-%L-%t] %-5level %logger{36} - %msg%n
</property>
<!-- <property name="PATTERN">%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%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="${LOG_HOME}/test.log" append="false">
<PatternLayout
pattern="${PATTERN}"/>
</File>
<!-- 这个会打印出所有的info及以下级别的信息,每次大小超过size,
则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档 -->
<RollingFile name="RollingFileDebug" fileName="${DEBUG_LOG_FILE_NAME}/debug.log"
filePattern="${DEBUG_LOG_FILE_NAME}/$${date:yyyy-MM}/debug-%d{yyyy-MM-dd}-%i.log">
<Filters>
<!--设置只输出级别为debug的日志-->
<ThresholdFilter level="debug"/>
<ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL"/>
</Filters>
<!-- <ThresholdFilter level="debug" onMatch="ACCEPT"
onMismatch="DENY"/>-->
<PatternLayout
pattern="${PATTERN}"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="2 kB"/>
</Policies>
<!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,这里设置了20 -->
<!--<DefaultRolloverStrategy max="20"/>-->
<DefaultRolloverStrategy max="100">
<Delete basePath="${DEBUG_LOG_FILE_NAME}" maxDepth="2">
<IfFileName glob="*/debug-*.log">
<IfLastModified age="7d">
<IfAny>
<IfAccumulatedFileSize exceeds="100 GB" />
<IfAccumulatedFileCount exceeds="10" />
</IfAny>
</IfLastModified>
</IfFileName>
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
<RollingFile name="RollingFileInfo" fileName="${INFO_LOG_FILE_NAME}/info.log"
filePattern="${INFO_LOG_FILE_NAME}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
<Filters>
<!--设置只输出级别为info的日志-->
<ThresholdFilter level="info"/>
<ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL"/>
</Filters>
<!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
<!--<ThresholdFilter level="info" onMatch="ACCEPT"
onMismatch="DENY"/>-->
<PatternLayout
pattern="${PATTERN}"/>
<Policies>
<!-- 基于时间的滚动策略,interval属性用来指定多久滚动一次,默认是1 hour。 modulate=true用来调整时间:比如现在是早上3am,interval是4,那么第一次滚动是在4am,接着是8am,12am...而不是7am. -->
<!-- 关键点在于 filePattern后的日期格式,以及TimeBasedTriggeringPolicy的interval,
日期格式精确到哪一位,interval也精确到哪一个单位 -->
<!-- log4j2的按天分日志文件 : info-%d{yyyy-MM-dd}-%i.log-->
<!--<TimeBasedTriggeringPolicy interval="1" modulate="true"/>-->
<TimeBasedTriggeringPolicy/>
<!-- SizeBasedTriggeringPolicy:Policies子节点, 基于指定文件大小的滚动策略,size属性用来定义每个日志文件的大小. -->
<SizeBasedTriggeringPolicy size="2 kB" />
</Policies>
<DefaultRolloverStrategy max="100">
<Delete basePath="${INFO_LOG_FILE_NAME}" maxDepth="2">
<IfFileName glob="*/info-*.log">
<IfLastModified age="7d">
<IfAny>
<IfAccumulatedFileSize exceeds="100 GB" />
<IfAccumulatedFileCount exceeds="10" />
</IfAny>
</IfLastModified>
</IfFileName>
</Delete>
</DefaultRolloverStrategy>
</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">
<Filters>
<!--设置只输出级别为WARN的日志-->
<ThresholdFilter level="warn"/>
<ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
</Filters>
<!--<ThresholdFilter level="warn" onMatch="ACCEPT"
onMismatch="DENY"/>-->
<PatternLayout
pattern="${PATTERN}"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="2 kB"/>
</Policies>
<!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,这里设置了20 -->
<DefaultRolloverStrategy max="100">
<Delete basePath="${WARN_LOG_FILE_NAME}" maxDepth="2">
<IfFileName glob="*/warn-*.log">
<IfLastModified age="7d">
<IfAny>
<IfAccumulatedFileSize exceeds="100 GB" />
<IfAccumulatedFileCount exceeds="10" />
</IfAny>
</IfLastModified>
</IfFileName>
</Delete>
</DefaultRolloverStrategy>
</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">
<Filters>
<!--设置只输出级别为error的日志-->
<ThresholdFilter level="error"/>
<!--<ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>-->
</Filters>
<!--<ThresholdFilter level="error" onMatch="ACCEPT"
onMismatch="DENY"/>-->
<PatternLayout
pattern="${PATTERN}"/>
<Policies>
<!-- log4j2的按分钟 分日志文件 : warn-%d{yyyy-MM-dd-HH-mm}-%i.log-->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!-- <SizeBasedTriggeringPolicy size="10 MB" /> -->
</Policies>
<DefaultRolloverStrategy max="100">
<Delete basePath="${ERROR_LOG_FILE_NAME}" maxDepth="2">
<IfFileName glob="*/error-*.log">
<IfLastModified age="7d">
<IfAny>
<IfAccumulatedFileSize exceeds="100 GB" />
<IfAccumulatedFileCount exceeds="10" />
</IfAny>
</IfLastModified>
</IfFileName>
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
<!-- log4j2 分线程写日志 -->
<Routing name="thread">
<!-- log4j2 写那个线程的日志 写这个线程 ThreadContext.put("userId120231", uuid1); -->
<Routes pattern="$${ctx:userId120231}">
<Route>
<RollingFile name="RollingFile-${ctx:userId120231}" fileName="${LOG_HOME}/${ctx:userId120231}.log"
filePattern="${LOG_HOME}/${ctx:userId120231}-%d{HH-mm-ss}.log" append="false">
<!--%X{userId120231} 将ThreadContext.put("userId120231", uuid1);中的内容写出来-->
<PatternLayout pattern="%X{userId120231} ${PATTERN}"/>
<Policies>
<SizeBasedTriggeringPolicy size="100M"/>
</Policies>
<DefaultRolloverStrategy max="100"/>
<Filters>
<!--此处可添加过滤,被我删掉了,可以根据等级过滤-->
</Filters>
</RollingFile>
</Route>
<Route ref="STDOUT" key="${ctx:userId120231}"/>
</Routes>
</Routing>
</Appenders>
<!--然后定义logger,只有定义了logger并引入的appender,appender才会生效-->
<Loggers>
<!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
<!-- <logger name="org.springframework" level="INFO"></logger>
<logger name="org.mybatis" level="INFO"></logger>-->
<!-- 第三方日志系统 -->
<!-- <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"/>-->
<!-- 配置日志的根节点 -->
<root level="all">
<appender-ref ref="Console"/>
<appender-ref ref="RollingFileDebug"/>
<appender-ref ref="RollingFileInfo"/>
<appender-ref ref="RollingFileWarn"/>
<appender-ref ref="RollingFileError"/>
<appender-ref ref="thread"/>
</root>
</Loggers>
</Configuration>
package test.data.com.main;
import org.apache.logging.log4j.*;
import java.util.*;
/**
* @param
* @param
* @param
* @author HUAZAI
* @title:
* @description:
* @return 返回类型 :
* <ul>
* <li></li>
* <li></li>
* <ul>
* @throws
* @date 18-4-2 上午11:42
*/
public class MainTest {
private static final org.apache.logging.log4j.Logger logger1 = org.apache.logging.log4j.LogManager.getLogger(MainTest.class);
// private static final org.apache.log4j.Logger logger1 = org.apache.log4j.Logger.getLogger(MainTest.class);
private static void testLogger(){
int i = 1;
String uuid1 = UUID.randomUUID().toString();
String uuid2 = UUID.randomUUID().toString();
while (true) {
ThreadContext.put("userId120231", uuid1);//log4j2日志的MDC分线程写日志
ThreadContext.put("userId132018", uuid2);
logger1.info("log4j2 info");
logger1.info("这是第 " + ((i-1) * 2) + " 秒");
logger1.debug("log4j2 debug");
logger1.warn("log4j2 warn");
// logger1.error("log4j2 error");
logger1.trace("log4j2 trace");
logger1.fatal("log4j2 fatal");
i++;
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
// int i = 0;
// try {
// i /= i;
// } catch (Exception e) {
// e.printStackTrace();
// logger1.error("出现异常", e);
// }
}
public static void main(String[] args) {
testLogger();
}
}
---------------------
作者:山若万丈-云自萦绕
来源:CSDN
原文:https://blog.csdn.net/chushoutaizhong/article/details/79865551
版权声明:本文为博主原创文章,转载请附上博文链接!