log4j2 的应用

来源:互联网 发布:七龙珠人物战斗力数据 编辑:程序博客网 时间:2024/05/14 01:43

继上一篇maven创建SpringMVC项目。

首先,在pom文件中加入log4j2需要jar的配置:

<dependency>
   <groupId>org.apache.logging.log4j</groupId>
   <artifactId>log4j-api</artifactId>
   <version>2.3</version>
</dependency>
<dependency>
   <groupId>org.apache.logging.log4j</groupId>
   <artifactId>log4j-core</artifactId>
   <version>2.3</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要-->  
        <dependency>  
            <groupId>org.apache.logging.log4j</groupId>  
            <artifactId>log4j-web</artifactId>  
            <version>2.3</version>  
        </dependency>


在resources下创建log4j2.xml,配置信息如下:

<?xml version="1.0" encoding="UTF-8"?>  
<!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
<!--Configuration后面的status,这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,你会看到log4j2内部各种详细输出-->
<!--monitorInterval:Log4j能够自动检测修改配置 文件和重新配置本身,设置间隔秒数-->
<Configuration status="info" monitorInterval="60">  
<!--定义了两个常量方便后面复用 -->
<properties>  
<!--生成的日志文件目录地址  -->
        <property name="LOG_HOME">/data/logs/tomcat/test/springMVC</property>
        <!--日志文件名称 -->
        <property name="FILE_NAME">springMVC</property>  
    </properties> 
<!--先定义所有的appender-->
    <Appenders>  
    <!-- 定义控制台输出 -->  
        <Console name="Console" target="SYSTEM_OUT">  
        <!--输出日志的格式-->
            <PatternLayout pattern="%d{yyyy/MM/dd HH:mm:ss.SSS} [%t] %-5level %l - %msg%n" />  
        </Console>  
        <!--满足一定条件后,就重命名原日志文件用于备份,并从新生成一个新的日志文件 -->
        <!--fileName:指定当前日志文件的位置和文件名称   filePattern:指定当发生Rolling时,文件的转移和重命名规则-->
        <RollingFile name="fxMyCenterLogFile"  
            fileName="${LOG_HOME}/${FILE_NAME}.log"  
            filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd}-%i.log">  
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %l - %msg%n" />  
            <Policies>  
            <!--TimeBasedTriggeringPolicy这个配置需要和filePattern结合使用,
            注意filePattern中配置的文件重命名规则是${FILE_NAME}-%d{yyyy-MM-dd HH-mm}-%i,
            最小的时间粒度是mm,即分钟,TimeBasedTriggeringPolicy指定的size是1,结合起来就是每1分钟生成一个新文件。
            如果改成%d{yyyy-MM-dd HH},最小粒度为小时,则每一个小时生成一个文件。  -->
                <TimeBasedTriggeringPolicy interval="1" />  
                <!--SizeBasedTriggeringPolicy  指定当文件体积大于size指定的值时,触发Rolling-->
                <SizeBasedTriggeringPolicy size="2048 MB" />  
            </Policies>  
            <DefaultRolloverStrategy max="20" />  
        </RollingFile> 
    </Appenders>  
    <Loggers>  
        <Root level="info">  
            <AppenderRef ref="Console" />
            <AppenderRef ref="fxMyCenterLogFile" />   
        </Root>  
    </Loggers>  
</Configuration> 


配置web.xml:

<context-param>  
   <param-name>log4jConfiguration</param-name>  
   <param-value>classpath:log4j2.xml</param-value>  
</context-param>  
<!-- 加载log4j配置文件 -->
<listener>  
   <listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>  
</listener>


获取日志工具类:

public static Logger logger  = LogManager.getLogger(TestController.class);


在hello中加入日志:

@RequestMapping(value = "/hello")
public String hello() {
logger.info("hello log");
return "hello";
}


启动项目