log4j2 在java web中的使用

 1、log4j2.xml的配置

<?xml version="1.0" encoding="UTF-8"?>
<!--
    status : 这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,会看到log4j2内部各种详细输出
    monitorInterval : Log4j能够自动检测修改配置文件和重新配置本身, 设置间隔秒数。
-->
<!-- <configuration status="warn" monitorInterval="600" > -->
<configuration status="warn">
    <appenders>
    	<!--输出控制台的配置-->
        <console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="[%d{yyyy-MM-dd HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
        </console>
		
		<!-- 设置日志格式并配置日志压缩格式(eg: info-2017-02-12-1.log.gz) -->
        <RollingFile name="RollingFileInfo" fileName="${sys:catalina.home}/local/config_info.log"
                     filePattern="${sys:catalina.home}/local/hpaasvc/$${date:yyyy-MM}/config_info-%d{yyyy-MM-dd}-%i.log.gz">
            <Filters>
                <ThresholdFilter level="INFO"/>
                <ThresholdFilter level="WARN" onMatch="DENY" onMismatch="NEUTRAL"/>
            </Filters>
            <!--
                %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="[%d{yyyy-MM-dd HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy/>
                <SizeBasedTriggeringPolicy size="20 MB"/>
            </Policies>
        </RollingFile>

        <RollingFile name="RollingFileError" fileName="${sys:catalina.home}/local/config_error.log"
                     filePattern="${sys:catalina.home}/local/hpaasvc/$${date:yyyy-MM}/error-%d{yyyy-MM-dd}-%i.log.gz">
            <ThresholdFilter level="ERROR"/>
            <PatternLayout pattern="[%d{yyyy-MM-dd HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy/>
                <SizeBasedTriggeringPolicy size="20 MB"/>
            </Policies>
        </RollingFile>
    </appenders>

    <loggers>
        <!-- 第三方日志系统 -->
        <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.apache.http" level="warn"/>
        
        <!-- 服务info级别日志设置 -->
        <logger name="com.johnfnash.learn.pro.config">
			<appender-ref ref="RollingFileInfo"/>
        </logger>
        
        <!-- 服务error级别日志设置 -->
        <logger name="com.johnfnash.learn.pro.config">
			<appender-ref ref="RollingFileError"/>
        </logger>
        
        <!-- 配置日志的根节点 -->
        <root level="all">
            <appender-ref ref="Console"/>
        </root>
    </loggers>

</configuration>
2. Log4j2 maven配置

<!-- log4j2 -->
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-core</artifactId>
	<version>2.1</version>
</dependency>
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-api</artifactId>
	<version>2.1</version>
</dependency>
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-web</artifactId>
	<version>2.1</version>
</dependency>
3. web.xml文件中添加Log4j2相关配置信息

<!-- log4j2设置 -->
<context-param>
	<param-name>log4jConfigLocation</param-name>
	<param-value>classpath:log4j2.xml</param-value>
</context-param>
<listener>
	<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>
</listener>
4. java代码中的使用

private static final Logger logger = LogManager.getLogger(实际类名.class.getName());

本文参考:

http://www.cnblogs.com/huige-you/p/4283379.html

http://www.cnblogs.com/guogangj/p/4031571.html

http://www.cnblogs.com/hanfight/p/5721855.html

http://blog.csdn.net/honghailiang888/article/details/50370252

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值