log4j2插件使用

pom.xml配置依赖

<!-- log4j2日志 -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-api</artifactId>
			<version>${log4j2.version}</version>
		</dependency>
		<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-web</artifactId>
			<version>${log4j2.version}</version>
		</dependency>

log4j2.xml文件放到resources文件夹

<?xml version="1.0" encoding="UTF-8"?>
<!--
status : 这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,会看到log4j2内部各种详细输出
monitorInterval : Log4j能够自动检测修改配置文件和重新配置本身, 设置间隔秒数。此处表示每隔600秒重读一次配置文件
-->
<configuration status="OFF" monitorInterval="600">
	<!-- 日志级别:TRACE < DEBUG < INFO < WARN < ERROR < FATAL -->
    <!-- 如果设置为WARN,则低于WARN的信息都不会输出 -->
    
    <properties>
    	<!-- 配置日志文件输出目录,此处为项目根目录下的logs文件夹 -->
    	<property name="logPath">${sys:catalina.home}/logs/MyProject</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} : 日志生产时间,输出到毫秒的时间
				%-5level : 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0
				%c : logger的名称(%logger)
				%t : 输出当前线程名称
				%p : 日志输出格式
				%msg : 日志内容,即 logger.info("message")
				%n : 换行符
				%C : Java类名(%F)
				%L : 行号
				%M : 方法名
				%l : 输出语句所在的行数, 包括类名、方法名、文件名、行数
				hostName : 本地机器名
				hostAddress : 本地ip地址
			-->
			<PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %logger{36} %L %M - %msg%n" />
		</Console>
		
		<!-- 循环日志文件:日志文件大于阀值的时候,就开始写一个新的日志文件
			这个会打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档
			fileName    : 指定当前日志文件的位置和文件名称
			filePattern : 指定当发生Rolling时,文件的转移和重命名规则
			SizeBasedTriggeringPolicy : 指定当文件体积大于size指定的值时,触发Rolling
			DefaultRolloverStrategy : 指定最多保存的文件个数,如不设置,则默认为最多同一文件夹下7个文件,这里设置了20
			TimeBasedTriggeringPolicy : 这个配置需要和filePattern结合使用
			注意filePattern中配置的文件重命名规则是${FILE_NAME}_%d{yyyy-MM-dd}_%i,最小的时间粒度是dd,即天,
			TimeBasedTriggeringPolicy指定的size是1,结合起来就是每1天生成一个新文件
		-->
		<RollingFile name="RollingFile" fileName="${logPath}/app.log" 
		filePattern="${logPath}/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log">
			<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
			<SizeBasedTriggeringPolicy size="50MB"/>
			<DefaultRolloverStrategy max="20"/>
		</RollingFile>
	</appenders>
	<loggers>
		<!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
		<logger name="org.springframework" level="info"></logger>
		<logger name="com.alibaba" level="warn"></logger>
		<root level="debug">
			<appender-ref ref="Console" />
			<appender-ref ref="RollingFile" />
		</root>
	</loggers>
</configuration>

如何使用

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

/**
 * 日志对象
 */
protected static Logger logger = LogManager.getLogger(MyController.class);

logger.info("打印日志信息");

 

转载于:https://my.oschina.net/zhxm/blog/909852

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值