1.高级进阶说明

本文介绍Log4j2高级进阶使用,

基于Log4j2进阶使用(按大小时间备份日志)

介绍更多的高级特性,

本文基于上文给出的完整log4j2.xml,

修改对应的配置项,

演示高级特性的使用。

基本使用请参考Log4j2基本使用入门

2.调整日志备份时间

按时间备份日志文件的时候,

可以指定modulate为true:

<TimeBasedTriggeringPolicy interval="10" modulate="true"/>

表示对备份日志的生成时间纠偏,

纠偏以零点为基准进行,

即日志时间将以0点为边界进行偏移计算。

如果每4小时备份一次日志,

假设当前时间是凌晨3点,

那么下次生成日志时间是4点,8点,12点等等。

如果每10分钟备份一次日志,

假设当前时间是09:58,

那么下次生成日志时间是10:00, 10:10, 10:20等等。

具体效果就是不管当前的运行时间,

生成的备份日志时间是可以预期的,

有规律的,便于查看的。

运行测试程序效果如下:

logs/:
10月 10 10:30 2019-10/
10月 10 10:36 test.log logs/2019-10:
10月 10 09:59 test-2019-10-10-09-59-1.log
10月 10 10:09 test-2019-10-10-10-09-1.log
10月 10 10:19 test-2019-10-10-10-19-1.log

可以看到在09:59, 10:09, 10:19等时间生成了备份日志。

发现实际文件时间和预期的时间都差了1分钟,

查看Log4j2源码:

org.apache.logging.log4j.core.appender.rolling.PatternProcessor.getNextTime(long, int, boolean)
cal.set(Calendar.MINUTE, currentCal.get(Calendar.MINUTE));
if (frequency == RolloverFrequency.EVERY_MINUTE) {
increment(cal, Calendar.MINUTE, increment, modulus);
nextTime = cal.getTimeInMillis();
cal.add(Calendar.MINUTE, -1);
nextFileTime = cal.getTimeInMillis();
return debugGetNextTime(nextTime);
}

可以看到nextTime和nextFileTime确实差了1分钟,

也就是备份日志文件的时间比预期时间差1个单位,

因此如果每4小时备份一次日志,

那么下次生成的日志文件时间是3点,7点,11点等等,

实际比预期都差了1个小时。

按照时间备份日志文件,

时间单位可以是年,月,日,小时,分钟,秒,毫秒,星期,

生成的备份文件就是上一个时间单位的时间,

比如备份的就是去年,上个月,昨天的日志等等,

因此实际减去1个时间单位是合理的。

3.压缩日志

通过配置filePattern文件的后缀名,

可以实现在备份日志时对日志文件进行压缩。

支持的文件压缩格式:.gz, .zip, .bz2, .deflate, .pack200,.xz。

生成的归档文件将使用匹配后缀的压缩方案进行压缩。

<RollingFile name="RollingFile" fileName="${LOG_HOME}/${FILE_NAME}.log"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd-HH}-%i.log.zip">

上面的配置中filePattern以.zip结尾,

表示备份文件压缩为zip格式。

运行测试程序效果如下:

logs/:
2019-10/
test.log logs/2019-10:
test-2019-10-10-15-03-1.log.zip
test-2019-10-10-15-04-1.log.zip
test-2019-10-10-15-05-1.log.zip

可以看到备份的日志文件都压缩为zip格式,

而且文件占用硬盘空间更少了。

同时DefaultRolloverStrategy支持配置日志压缩级别,

设置compressionLevel属性,范围0-9,

压缩效果依次增大,

0不压缩,1压缩速度最快,9压缩率最好,

但是只对于压缩文件类型有效,

目前Log4j2只实现了zip压缩文件支持compressionLevel。

<DefaultRolloverStrategy compressionLevel="1">

如果不填写压缩级别,默认是DEFAULT_COMPRESSION(-1)。

查看Log4j2压缩代码实现,

调用的是jdk提供的zip压缩:

java.util.zip.ZipOutputStream.setLevel(int)
/**
* Sets the compression level for subsequent entries which are DEFLATED.
* The default setting is DEFAULT_COMPRESSION.
* @param level the compression level (0-9)
* @exception IllegalArgumentException if the compression level is invalid
*/
public void setLevel(int level) {
def.setLevel(level);
}

下面的配置表示备份文件压缩为gz格式:

filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd-HH}-%i.log.gz"

4.敏感日志设置

Layout支持replace功能,

可以通过正则表达式查找%msg的内容,

并且替换为想要输出的内容,

可以实现把敏感日志替换为其他字符。

下面replace把msg中的error全部替换为*****:

%replace{%msg}{error}{*****}

需要注意的这里replace只支持正常打印的内容,

不支持exception(即catch捕获的error会直接输出)。

log4j2.xml配置参考:

<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level [%L] - %replace{%msg}{error}{*****}%n" />

修改前打印日志:

2019-10-23 16:20:23.085 [main] ERROR [18] - error level log
2019-10-23 16:20:23.085 [main] FATAL [19] - fatal level log

修改后打印日志:

2019-10-23 16:20:25.073 [main] ERROR [18] - ***** level log
2019-10-23 16:20:25.083 [main] FATAL [19] - fatal level log

5.参考文章

Log4j2基本使用入门
Log4j2进阶使用(按大小时间备份日志)
Log4j2进阶使用(Pattern Layout详细设置)
Log4j2完整XML参考(详细注释说明)

Log4j2进阶使用(更多高级特性)的更多相关文章

  1. Python进阶:全面解读高级特性之切片!

    导读:切片系列文章连续写了三篇,本文是对它们做的汇总.为什么要把序列文章合并呢?在此说明一下,本文绝不是简单地将它们做了合并,主要是修正了一些严重的错误(如自定义序列切片的部分),还对行文结构与章节衔 ...

  2. Redis进阶实践之五Redis的高级特性(转载 5)

    Redis进阶实践之五Redis的高级特性 一.引言 上一篇文章写了Redis的特征,使用场景,同时也介绍了Redis的基本数据类型,redis的数据类型是操作redis的基础,这个必须好好的掌握.今 ...

  3. Redis进阶实践之五Redis的高级特性

    一.引言    上一篇文章写了Redis的特征,使用场景,同时也介绍了Redis的基本数据类型,redis的数据类型是操作redis的基础,这个必须好好的掌握.今天我们开始介绍一些Redis的高级特性 ...

  4. 你应该知道的Vue高级特性

    本文使用的Vue版本:2.6.10 Vue为我们提供了很多高级特性,学习和掌握它们有助于提高你的代码水平. 一.watch进阶 从我们刚开始学习Vue的时候,对于侦听属性,都是简单地如下面一般使用: ...

  5. Visual Studio 2015 速递(4)——高级特性之移动开发

    系列文章 Visual Studio 2015速递(1)——C#6.0新特性怎么用 Visual Studio 2015速递(2)——提升效率和质量(VS2015核心竞争力) Visual Studi ...

  6. mysql笔记04 MySQL高级特性

    MySQL高级特性 1. 分区表:分区表是一种粗粒度的.简易的索引策略,适用于大数据量的过滤场景.最适合的场景是,在没有合适的索引时,对几个分区进行全表扫描,或者是只有一个分区和索引是热点,而且这个分 ...

  7. (十二)boost库之多线程高级特性

    (十二)boost库之多线程高级特性 很多时候,线程不仅仅是执行一些耗时操作,可能我们还需要得到线程的返回值,一般的处理方法就是定义一个全局状态变量,不断轮训状态,就如我目前维护的一个项目,全局变量定 ...

  8. (升级版)Spark从入门到精通(Scala编程、案例实战、高级特性、Spark内核源码剖析、Hadoop高端)

    本课程主要讲解目前大数据领域最热门.最火爆.最有前景的技术——Spark.在本课程中,会从浅入深,基于大量案例实战,深度剖析和讲解Spark,并且会包含完全从企业真实复杂业务需求中抽取出的案例实战.课 ...

  9. 使用Mockito进行单元测试【2】—— stub 和 高级特性[转]

    一篇中介绍了Mockito的基本信息,现在接着介绍Mockito强大的stub功能 2. Mockito使用实例 5. 对连续的调用进行不同的返回 (iterator-style stubbing) ...

随机推荐

  1. YYYY-MM-DD引发的问题

    yyyy 和 YYYY 用YYYY格式化代码 2019-12-31 转 YYYY/MM/dd 格式: 2020/12/31 2020-01-01 转 YYYY/MM/dd 格式: 2020/01/01 ...

  2. mysql 5.7 压缩包安装教程

    前言 :  避免之前装的MySQL影响 首先进入dos窗口执行 sc delete mysql      删除已有的mysql服务 (一) 下载MySQL5.7 版本压缩包 网址 https://de ...

  3. 通过Shell统计PV和UV

    PV.UV是网站分析中最基础.最常见的指标.PV即PageView,网站浏览量,指页面的浏览次数,用以衡量网站用户访问的网页数量.用户没打开一个页面便记录1次PV,多次打开同一页面则浏览量累计:UV即 ...

  4. 11.Vue.js-事件处理器

    事件监听可以使用 v-on 指令: <div id="app"> <button v-on:click="counter += 1">增 ...

  5. 【React】组件书写记录

    时钟组件: 组件形式:数字时钟 https://blog.csdn.net/hahahahahahahaha__1/article/details/80688920 Javascript获取时间方法: ...

  6. B树和B+树原理图文解析

    B树与B+树不同的地方在于插入是从底向上进行(当然查找与二叉树相同,都是从上往下) 二者都通常用于数据库和操作系统的文件系统中,非关系型数据库索引如mongoDB用的B树,大部分关系型数据库索引使用的 ...

  7. KrakenD url匹配通配符 url_pattern wildcard

    KrakenD是一个高性能Api网关,  api转发的推荐做法是每个api一个配置项,也就是一个endpoint,其开发者认为api网关和纯粹的L7路由不一样(文章链接). 因此社区版并没有提供通配符 ...

  8. C++STL标准库学习笔记(四)multiset续

    自定义排序规则的multiset用法 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标记了出来,只不过这一次的笔记主要是我的补充 ...

  9. Redis cluster 集群部署和配置

    目录 一.集群简介 cluster介绍 cluster原理 cluster特点 应用场景 二.集群部署 环境介绍 节点部署 启动集群 三.集群测试 一.集群简介 cluster介绍 redis clu ...

  10. typescript接口---interface

    假如我现在需要批量生产一批对象,这些对象有相同的属性,并且对应属性值的数据类型一致.该怎么去做? 在ts中,因为要检验数据类型,所以必须对每个变量进行规范,自然也提供了一种批量规范的功能.这个功能就是 ...