logback TimeBasedRollingPolicy的fileNamePattern和file配置详解

2023-10-27

本文主要介绍 fileNamePattern和file两个配置项

1. file配置项

  1. file配置项是作为RollingFileAppender的一个配置项而被定义,即继承于RollingFileAppender的其他子类都可以使用file配置项。
  2. file主要是用来指定日志输出的文件名

2. fileNamePattern配置项

  1. fileNamePattern配置项是作为TimeBasedRollingPolicy的一个配置项被定义。
  2. 该配置项主要是用来定制化一个日志的流转策略

TimeBasedRollingPolicy类的定义

在这里插入图片描述

可以看出来,TimeBasedRollingPolicy继承了RollingPolicyBase且实现了TriggeringPolicy接口。根据我们上文所说的,这样的policy可以同时实现流转策略和触发策略两种功能。那么在实现这两种功能的过程中,fileNamePattern这个配置项就完成了很大的一部分工作

fileNamePattern的格式

  1. string类型,必选。
  2. 定义了归档之后的文件名。
  3. 设置的值必须包含一个固定文件名和一个放在适当位置的%d的约定标识符。
    1. %d包括日期和时间的格式(被java.text.SimpleDateFormat定义)。
    2. %d的默认值yyyy-MM-dd。
    3. 日志文件滚动归档的周期也是根据%d推断出来的
    4. 注意:如果其中包含了\或者是/都会被当做是文件分隔符

3. fileNamePattern和file的搭配使用(解耦)

因为在TimeBasedRollingPolicy中,fileNamePattern是必选配置项,file是可选配置项,所以需要考虑下面两种情况:

  1. 同时设置了fileNamePattern和file:
    file设置的值决定了实时输出的日志文件名,因为file是一个固定字符串。所以也就意味着当前生效的日志文件名是不会随着时间而发生变化的。例如,设置file的值为a.log。那么日志的直接输出文件永远是a.log
    fileNamePattern设置的值决定了归档日志文件名,根据%d的不同,归档文件的文件名也会有所差异,且归档的触发策略也会因%d的不同而有所不同
  2. 只设置了fileNamePattern,没有设置file:
    不管是实时生效日志文件名还是归档文件名都是通过fileNamePattern计算出来的,会随着时间的变化而发生日志文件名的差异

4. fileNamePattern的不同%d配置举例说明

4.1 /Wombat/foo.% d (天级更新)

  1. 当没有指定具体的格式的时候 ,那么就使用默认格式yyyy-MM-dd。
  2. 每天0点进行日志滚动
  3. 因为没有设置file配置项,那么在2006年12月23日,日志会输出到文件/wombat/foo.2006-12-23。
    在24号0点的时候,日志会定向输出到/wombat/foo.2006-12-24
  4. 如果设置了file配置项的值为 /wombat/foo.txt,那么在2006年12月23号的时候,会输出日志到 /wombat/foo.txt。在24号零点的时候 /wombat/foo.txt会被重命名为 /wombat/foo.txt.2006-12-23。一个新的文件 /wombat/foo.txt将会被创建,用来接收24号输出的日志

4.2 /wombat/%d{yyyy/MM}/foo.txt (月级更新)

  1. 在每个月月初的时候,进行日志滚动
  2. 如果没有设置file配置项,那么在2006年12月的时候,日志会输出到/wombat/2006/12/foo.txt,等到过了12月,到达2007年1月的时候,日志会被重定向到/wombat/2007/01/foo.txt
  3. 如果设置了file配置项的值为/wombat/foo.txt,那么实时日志将总是输出到/wombat/foo.txt。且在2006年12月的时候,日志会输出到/wombat/foo.txt,等到过了12月,到达2007年1月的时候,/wombat/foo.txt会被重命名为/wombat/2006/12/foo.txt,并且会创建一个/wombat/foo.txt用来接收2007年1月份的日志。等到1月31号结束到达2月1号的时候,/wombat/foo.txt会被重命名为/wombat/2007/01/foo.txt,依次类推

4.3 wombat/foo.%d{yyyy-ww}.log (周级更新)

  1. 每周的第一天进行日志的滚动,注意这里每周的第一天的判断是依赖于本地的日历系统
    关于file配置项设置与否的差异和上述描述类似

4.4 /wombat/foo%d{yyyy-MM-dd_HH}.log (小时级更新)

  1. 每一个小时滚动一次日志
  2. 关于file配置项设置与否的差异和上述描述类似

4.5 wombat/foo%d{yyyy-MM-dd_HH-mm}.log (分钟级更新)

  1. 每一分钟滚动一次日志
  2. 关于file配置项设置与否的差异和上述描述类似

4.6 wombat/foo%d{yyyy-MM-dd_HH-mm, UTC}.log (指定时区)

  1. 每一分钟滚动一次日志,在UTC时区下
  2. 关于file配置项设置与否的差异和上述描述类似

4.7 foo/%d{yyyy-MM,aux}/%d.log (aux 主从使用)

  1. 可以看到有两个%d标识符,其中第一个有aux修饰,另一个没有,那么就说明,没有aux修饰的日期为主,有aux修饰的为辅。也可以理解为没有aux修饰的格式为实时写入日志的格式,有aux修改的为归档日志的存储格式
    那么在这个例子中,归档日志被存储在/foo/2006-12/这个文件夹中。因为主%d没有指明具体的日期时间格式,所以默认为是YYYY-MM-dd。所以日志的文件名为2006-12-01.log

注:
任何一个正斜杠或者是反斜杠都会被当做是目录分隔符。而且当目录不存在的时候也会自动创建,所以我们可以很容易的就把日志放在我们的目标目录

4.8 wombat/foo.%d.gz (压缩使用)

  1. TimeBasedRollingPolicy 也是支持日志的自动压缩的,如果日志文件名是以 .gz 或者.zip结尾的话, 那么就会触发这一操作
  2. 因为没有指定具体的日期时间格式,所以也是天级滚动日志
  3. 如果没有设置file配置项,那么在2006年12月23日的时候,日志会输出到/wombat/foo.2006-12-23,等到2006年12月24日的时候,日志会被重定向到/wombat/foo.2006-12-24。而且/wombat/foo.2006-12-23会被压缩到/wombat/foo.2006-12-23.gz
  4. 如果设置了file配置项的值为/wombat/foo.txt,那么实时日志将总是输出到/wombat/foo.txt。么在2006年12月23日的时候,日志会输出到/wombat/foo.txt,等到2006年12月24日的时候,/wombat/foo.txt会被重命名为/wombat/foo.2006-12-23.gz,并且会创建一个/wombat/foo.txt用来接收2006年12月24日的日志

5. fileNamePattern 主要作用

  1. 计算出日志滚动的周期
  2. 计算出每一个归档日志文件的文件名。

两个不同的pattern可能决定的是同样的滚动周期,比如说是yyyy-MM和yyyy@MM,都是指定了月级别的滚动,但是区别在于他们计算出来的归档日志文件的文件名不同

6. 日志滚动的驱动因素

由于技术原因,日志滚动并不是受时间驱动,而是受event输出的驱动。例如在2002年3月8日。fileNamePattern 被设置为fileNamePattern ,那么就由3.9号0点之后的第一个event来触发滚动操作。如果在0点到20分之间都没有日志,21分的时候才有第一个event到达,那么日志的滚动就是在21分的时候触发,而不是0分。因此,根据event的到达率,可能会有一些延迟。但是不管是怎么延迟,滚动算法是不会发生变化的。因为在某一时间段内的日志输出在该时间段内正确的日志文件中

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

logback TimeBasedRollingPolicy的fileNamePattern和file配置详解 的相关文章

随机推荐

  • Java猫和狗(继承,多态,抽象,接口版)上

    Java的继承 抽象 多态 接口的简单应用 我们利用 猫和狗都是动物类 然后猫会抓鱼 狗会看门的这些方法来简单应用一下继承 抽象 多态 接口 简单思路就是 1 定义动物类 2 定义猫 狗类 让他们成为动物的子类 3 编写测试类 继承 使子类
  • PTA L1-016:查验身份证 (python)

    一 题目要求 二 参考代码 sheet 0 1 1 0 2 X 3 9 4 8 5 7 6 6 7 5 8 4 9 3 10 2 w 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 n int input c 0 f
  • ARM单片机FATFS文件系统的移植

    ARM单片机FATFS文件系统的移植 测试效果 前提条件 下载所需源码 FATFS 文件系统 SFUD万能驱动 加入工程 接口驱动 测试代码 FreeRTOS10 0 1 FATFS FF14A SFUD V1 1 0 STM32F103Z
  • 超过2t硬盘分区_大于2T的磁盘怎么分区呢?

    由于购买了磁盘柜专门用作存储 后来考虑到磁盘容量的动态管理 准备采用LVM进行动态扩容管理了 首先让前端挂载机器能够识别到磁盘柜的逻辑卷组 比如 dev sdb 先介绍2种分区表 MBR分区表 MBR含义 主引导记录 所支持的最大卷 2T
  • 6.8过程纹理

    过程纹理也称为自定义纹理 根据计算得出 这个例子使用了位置和原点的距离作为输入参数 并加入了动画 但是和目前的纹理没任何关系 纯手工计算 因为位置是三维的 所以在涉及到纹理的几个地方都要改为三维的 struct RENDEROBJECT D
  • Java中的&、&&、

    关于这几个的运算符我一代码的实例来介绍 如下 1 首先它们都是逻辑运算符 但是 和 是短路运算符 也就是只判断运算符左边的即可 就可以确定整个表达式的结果了 所以它的执行效率高于 和 因为这两个运算符需要将表达式中所有的boolean值都判
  • JAVA开发(行业现状与未来)

    JAVA开发行业经过了这么多年的发展 曾经从一个机顶盒程序起家 到超过3亿台以上设备都在运行JAVA程序 JAVA语言见证了整个互联网化的工业化过程 许许多多的东西从从传统模式搬到了线上 特别是电子商务和网络社交的发展 大量的资金投入的这个
  • 【算法系列篇】前缀和

    文章目录 前言 什么是前缀和算法 1 模板 前缀和 1 1 题目要求 1 2 做题思路 1 3 Java代码实现 2 模板 二维前缀和 2 1 题目要求 2 2 做题思路 2 3 Java代码实现 3 寻找数组的中心下标 3 1 题目要求
  • 【MATLAB第67期】# 源码分享

    MATLAB第67期 源码分享 基于MATLAB的morris全局敏感性分析 一 代码展示 clear all npoint 100 在分位数超空间中要采样的点数 计算次数iter npoint nfac 1 nfac 20 研究函数的不确
  • 浏览器跨域问题

    1 同源策略 同源策略是一种约定 是浏览器最核心也是最基本的安全功能 可以说Web是构建在同源策略基础之上的 浏览器之上针对同源策略的一种实现 同源 协议 域名 端口号都相同的才称为 同源 同源策略用于限制一个origin的文档或者它加载的
  • 随机选择一个三位以内的数字作为答案。用户输入一个数字,程序会提示大了或是小了,直到用户猜中。

    import random b random randint 0 999 A input input a 0 999 number a int A 用户输入 while a b if a gt b A input input a less
  • vue+图片上传+预览

    学习记录 实现本地图片上传和预览 切记使用 accept image 可以指定文件类型
  • 逐步解读HTTP报文的组成及含义

    如果说HTTP是因特网的信使 那么HTTP报文就是运送的包裹 所有的HTTP程序都是通过互相发送报文来完成工作的 本文将介绍HTTP报文的流动方式 报文的组成部分 请求和响应报文之间的区别等 报文流 HTTP报文是在HTTP应用程序之间发送
  • Java并发编程详解:实现高效并发应用的关键技术

    文章目录 引言 一 线程安全性 二 并发集合 结论 引言 在当前的计算机领域 高效的并发编程对于Java开发人员而言变得越发重要 作为流行的编程语言 Java提供了强大的并发编程支持 使开发人员能够充分发挥多核处理器和线程的潜力 构建高性能
  • 限制input框只能输入0~100的正整数

    法一 复杂
  • 【Gazebo安装教程】2023年最新安装全流程详解!

    安装 实验环境 ubuntu22 04LTS 安装 Gazebo 首先我们需要安装必须的工具 sudo apt get update sudo apt get install lsb release wget gnupg 之后修改源 并 u
  • 爬虫异常处理实战:应对请求频率限制和数据格式异常

    目录 一 请求频率限制的处理 1 设置请求间隔时间 2 使用随机化延迟 3 添加爬虫IP和用户代理 二 数据格式异常的处理 1 异常数据的过滤 2 错误信息的记录 3 动态调整解析规则 总结 在爬虫编程中 我们经常会遇到各种异常情况 比如请
  • 确定Mac\Linux系统的架构类型是 x86-64(amd64),还是 arm64 架构

    我们在下载软件或镜像时会有很多版本 那需要根据我们的系统架构选择正确的软件或镜像版本 要确定你的系统使用的是 x86 64 amd64 还是 arm64 架构 可以使用以下方法之一 使用 uname 命令 打开终端 并运行以下命令 unam
  • 【Java核心技术 卷I】第一章 Java程序设计概述 笔记

    是自学和看书的笔记 有的地方感觉了解一下就行了 就没记笔记 1 2 Java的11个关键术语 简单性 面向对象 分布式 健壮性 安全性 体系结构中立 可移植性 解释性 高性能 多线程 动态性 简单性 Java语法是C 语法的一个 纯净 版本
  • logback TimeBasedRollingPolicy的fileNamePattern和file配置详解

    文章目录 1 file配置项 2 fileNamePattern配置项 3 fileNamePattern和file的搭配使用 解耦 4 fileNamePattern的不同 d配置举例说明 4 1 Wombat foo d 天级更新 4