1.说明

本文提供完整的log4j2.xml配置文件,

供开发中参考使用,可以作为模板,

配置对应实现如下常用的功能:

1.自动检测和重新加载配置,每10分钟(600s)检测一次

2.每个日志文件最大为100MB

3.每天备份一次日志文件

4.备份的日志文件压缩为gz格式

5.备份的文件放到以当前年月命名的目录

6.每天备份的日志文件个数最多为5个

7.最多保留6个月(180D)之内的日志文件

2.完整log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<!--status:Log4j2内部日志的输出级别,设置为TRACE对学习Log4j2非常有用 -->
<!--monitorInterval:定时检测配置文件的修改,有变化则自动重新加载配置,时间单位为秒,最小间隔为5s -->
<Configuration status="WARN" monitorInterval="600">
<!--properties:设置全局变量 -->
<properties>
<!--LOG_HOME:指定当前日志存放的目录 -->
<property name="LOG_HOME">logs</property>
<!--FILE_NAME:指定日志文件的名称 -->
<property name="FILE_NAME">test</property>
</properties>
<!--Appenders:定义日志输出目的地,内容和格式等 -->
<Appenders>
<!--Console:日志输出到控制台标准输出 -->
<Console name="Console" target="SYSTEM_OUT">
<!--pattern:日期,线程名,日志级别,日志名称,日志信息,换行 -->
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level [%L] - %msg%n" />
</Console>
<!--RollingFile:日志输出到文件,下面的文件都使用相对路径 -->
<!--fileName:当前日志输出的文件名称 -->
<!--filePattern:备份日志文件名称,备份目录为logs下面以年月命名的目录,备份时使用gz格式压缩 -->
<RollingFile name="RollingFile" fileName="${LOG_HOME}/${FILE_NAME}.log"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level [%L] - %msg%n" />
<!--Policies:触发策略决定何时执行备份 -->
<Policies>
<!--TimeBasedTriggeringPolicy:日志文件按照时间备份 -->
<!--interval:每1天生成一个新文件,时间单位需要结合filePattern时间%d{yyyy-MM-dd} -->
<!--同理,如果要每1小时生成一个新文件,则改成%d{yyyy-MM-ddHH} -->
<!--modulate:对备份日志的生成时间纠偏,纠偏以0为基准进行,"0+interval"决定启动后第一次备份时间 -->
<TimeBasedTriggeringPolicy interval="1" modulate="true" />
<!--SizeBasedTriggeringPolicy:日志文件按照大小备份 -->
<!--size:指定日志文件最大为100MB,单位可以为KB、MB或GB -->
<SizeBasedTriggeringPolicy size="100MB" />
</Policies>
<!--DefaultRolloverStrategy:翻转策略决定如何执行备份 -->
<!--max:最多保存5个备份文件,结合时间使用后,在每个时间段内最多有5个备份,多出来的会被覆盖 -->
<!--compressionLevel:配置日志压缩级别,范围0-9,0不压缩,1压缩速度最快,9压缩率最好,目前只对于zip压缩文件类型有效 -->
<DefaultRolloverStrategy max="5" compressionLevel="1">
<!--Delete:删除匹配到的过期备份文件 -->
<!--maxDepth:由于备份文件保存在${LOG_HOME}/$${date:yyyy-MM},所以目录深度设置为2 -->
<Delete basePath="${LOG_HOME}" maxDepth="2">
<!--IfFileName:匹配文件名称 -->
<!--glob:匹配2级目录深度下的以.log.gz结尾的备份文件 -->
<IfFileName glob="*/*.log.gz" />
<!--IfLastModified:匹配文件修改时间 -->
<!--age:匹配超过180天的文件,单位D、H、M、S分别表示天、小时、分钟、秒-->
<IfLastModified age="180D" />
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
</Appenders>
<!--Loggers:定义日志级别和使用的Appenders -->
<Loggers>
<!--name: 打印日志的类的包路径 -->
<!--additivity: true当前的Logger打印的日志附加到Root,false仅仅打印到RollingFile -->
<Logger name="org.apache.logging.log4j" level="ERROR" additivity="true">
<AppenderRef ref="RollingFile" />
</Logger>
<!--Root:日志默认打印到控制台 -->
<!--level日志级别: ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF -->
<Root level="ERROR">
<AppenderRef ref="Console" />
</Root>
</Loggers>
</Configuration>

3.参考文章

Log4j2基本使用入门
Log4j2进阶使用(按大小时间备份日志)
Log4j2进阶使用(Pattern Layout详细设置)

最新文章

  1. Hibernate 随记(数据库映射流程)
  2. Linux_arm驱动之按键模拟脉冲实现定时器的精确计时
  3. Sprint3(12.18)总结
  4. Python 集合set添加删除、交集、并集、集合操作符号
  5. [ASE][Daily Scrum]11.25
  6. struts2视频学习笔记 29-30(Struts 2常用标签,防止表单重复提交)
  7. FCLK PCLK HCLK
  8. jquery实现页面置顶功能代码
  9. WPF自定义Main函数
  10. 开发者需要了解的WebKit
  11. 在ubuntu16.04中再次体验.net core 2.0
  12. Rhel6.5 相关操作
  13. 求1!+2!+3!+......+n!的和 -----C++-----
  14. 《JavaScript-The Definitive Guide》读书笔记:函数定义和函数调用
  15. 项目总结之关于JQuery一些常用的函数
  16. es 配置文件
  17. Codeforces 807 C. Success Rate
  18. Python之查询美国护照状态
  19. Promise个人笔记---【Promise的前世今生】
  20. 问题:System.Guid.NewGuid();结果:C# System.Guid.NewGuid()

热门文章

  1. vue实现input输入框的模糊查询
  2. 【Matlab】运算符使用整理 * .* / \ .&#39;
  3. git push大文件失败(write error: Broken pipe)完美解决
  4. pipeline option指令
  5. ios http 同步异步请求处理
  6. Linux编译安装、压缩打包、定时任务管理
  7. 记一次AWD
  8. 扬我国威,来自清华的开源项目火爆Github
  9. 项目管理的基本概念(Project)
  10. 听听文档(视频)-Power Pivot