首页 > 其他分享 >通用 log4j2 日志模板

通用 log4j2 日志模板

时间:2023-11-22 20:11:06浏览次数:47  
标签:m% 通用 log 日志 log4j2 模板

通用 log4j2 日志模板

 

<?xml version="1.0" encoding="UTF-8" ?>
<!--
    配置项集
    属性 status 指明全局的最低日志级别。
    属性 monitorInterval 指明监控日志变化的时间间隔。
    这里指明了日志级别为 debug,监控日志文件变化的周期是 30 毫秒

    格式:%m 输出的信息;%p 日志级别;%t 线程名;%d 日期;%c 类的全名。
    级别从高到低依次为:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、ALL。
-->
<Configuration status="debug" monitorInterval="30">

    <!--
        全局共享变量集
        全局共享属性组
    -->
    <Properties>
        <Property name="systemName">logForJava2</Property>      <!-- 系统名称 -->
        <Property name="fileDirectory">/log</Property>   <!-- 文件目录,这里使用的是绝对路径。-->
        <Property name="timeInterval">1</Property>  <!-- 时间间隔 -->
        <Property name="limitSize">5KB</Property>   <!-- 临界大小 -->
        <Property name="rollingFileName">rollingFilePerMinute</Property>
        <Property name="hapdayPatternLayout">
<!--            %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n-->
            %d %p [%t] %c (%line\)- %m%n
        </Property>
    </Properties>

    <!--
        输出目的地集
    -->
    <Appenders>
        <!--
            输出到控制台
         -->
        <Console name="hapdayConsoleAppender" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
        </Console>

        <!--
            输出到文件,这是个普通的文件,随着日志的递增,文件会逐渐增大;当非常大时不便于快速读取,通常不采用此方式,这里只为演示用。
        -->
        <File name="hapdayFileAppender"
              fileName="${fileDirectory}/${systemName}/hapdayFile.log"
        >
            <PatternLayout>
                <!--
                    【匹配】可以以属性的方式出现,也可以以元素的形式呈现。
                    这里采用的是以元素的形式呈现。
                -->
                <Pattern>${hapdayPatternLayout}</Pattern>
            </PatternLayout>

            <!--
                临界值过滤器,可以按级别、正则表达式、键值对、特定结构进行过滤。
                level 指定日志级别,匹配到高于或等于此级别的日志。
                onMatch 指定匹配的规则。
                onMismatch 指定不匹配的规则。
                匹配策略有:拒绝(DENY)、中立(NEUTRAL)、接收(ACCEPT)三种。
                这里指定了高于或等于警告(warn)级别的日志会输出。
            -->
            <ThresholdFilter level="WARN" onMatch="ACCEPT" onMismatch="DENY" />
        </File>

        <!--
            滚动输入到文件
            将备份的日志文件使用 gzip 进行压缩后保存,从而节省硬盘空间,进而降低运营成本。
            压缩格式可以指定为 *.gz,也可以指定为 *.zip。
            Linux 系统推荐压缩为 .gz 格式。
        -->
        <RollingFile name="hapdayRollingFileAppender"
             fileName="${fileDirectory}/${systemName}/${rollingFileName}.log"
             filePattern="${fileDirectory}/${systemName}/${rollingFileName}-%d{yyyy-MM-dd HH-mm}-%i.log.zip">
            <PatternLayout pattern="%d %p %C{1.} [%t] %m%n" />

            <!--
                触发策略,即匹配了如下一条规则就触发日志文件的变化,比如创建新的日志文件,再比如覆盖已存在的文件等。
                内部的每条策略的关系是或,即只要满足一条就会创建新的日志文件。
                当每种轮换策略都未达到时或无新的日志内容出现时则不创建新的日志文件。
            -->
            <Policies>
                <!--
                    基于时间触发文件轮换的策略,每间隔设定的最小时间粒度就创建新的日志文件。
                    没有新的日志内容的话即便到了时间间隔也不会创建新的日志文件。
                -->
                <TimeBasedTriggeringPolicy interval="${timeInterval}" />
                <!--
                    基于大小触发文件轮换的策略,超过设定的大小即创建新的日志文件。
                    size 常用的单位有千字节(KB)、兆字节(MB)、吉字节(GB)等,单个文件不易过大,否则读取会很慢。
                    没有新的日志内容的话即超过了设定的文件大小也不会创建新的日志文件。
                -->
                <SizeBasedTriggeringPolicy size="${limitSize}" />
            </Policies>

            <DefaultRolloverStrategy max="100" />    <!-- 指定最多的文件轮换次数,即最多保存多少个日志文件,这里设定的是 100 个。 -->
        </RollingFile>

        <!--
            布局,具体来讲就是日志的格式。
        -->
        <Layouts>
            <HtmlLayout title="hapday html log layout">
                <PatternLayout pattern="${hapdayPatternLayout}"></PatternLayout>
            </HtmlLayout>
        </Layouts>

    </Appenders>

    <!--
        日志记录器集
    -->
    <Loggers>
        <!--
            拦截包名为 com.joyupx 下的全部文件
            不发送到父日志记录器中。
        -->
        <Logger name="com.joyupx" level="debug" additivity="false">
            <AppenderRef ref="hapdayFileAppender" />
            <AppenderRef ref="hapdayRollingFileAppender" />
        </Logger>

        <!--
            根日志记录器
            所有未明确指定名称的【日志记录器】都被记录到【根日志记录器】中。
        -->
        <Root level="debug">
            <AppenderRef ref="hapdayConsoleAppender" />
        </Root>
    </Loggers>
</Configuration>

  

标签:m%,通用,log,日志,log4j2,模板
From: https://www.cnblogs.com/hapday/p/17850184.html

相关文章

  • Golang Gin 模板基本使用
    一,模板定义,模板变量,条件判断,模板函数,模板命名1{{define"default/index.html"}}2<!DOCTYPEhtml>3<htmllang="en">45<head>6<metacharset="UTF-8">7<metaname="viewport"conte......
  • 通用的 logback.xml 日志模版
    通用的logback.xml日志模版 <?xmlversion="1.0"encoding="UTF-8"?><configuration> <!--定义日志输出目录--> <substitutionPropertyname="log.base"value="/log/joyupx/trade/"/> <!--<jmxConfig......
  • Aspose.Words使用word模板中的书签/域插入信息并导出
    首先我大概叙述一下我对这个东西的理解毕竟我也只是记录一下,确保下次自己在看的时候可以看懂,所以写的比较详细且傻瓜首先这个word文档不是凭空生成的,是你事先就把文档创建好的,里边的内容,格式都是实现创建好的只留下一些需要插入数据的地方,当然这些需要插入数据的地方也不是空着的......
  • 【模板】最小度限制生成树 题解
    其他的题解感觉都好高级,分享一种好想且好实现的方法。我们可以先把点\(s\)和与其相连的边都删除,我们发现剩下的部分变成了一些连通块。我们不难发现,当要求与\(s\)点相连的边的个数为\(k\)时,我们的连通块个数显然是\(k\)的。接下来这个问题就转化成了:\(n-1\)个点中生......
  • redis中查看慢日志以及返回参数值的解释
    1、问题描述 业务反馈,出现很多连接redis的readtimedout的报错  2、问题分析及解决 由于redis是单线程处理的,所有redis接收到命令,都会进入到队列中,等待执行。 当客户端,由于等待时间过长,没有接收到server端返回的数据,就是出现超时的报错。 程序里,jedis客户端,默......
  • Walrus 入门教程:如何创建模板以沉淀可复用的团队最佳实践
    模板是Walrus的核心功能之一,模板创建完成后用户可以重复使用,并在使用过程中逐渐沉淀研发和运维团队的最佳实践,进一步简化服务及资源的部署。用户可以使用HCL语言自定义创建模板,也可以一键复用Terraform社区中上万个成熟的Module。在本文中,我们将以阿里云EC2为例,介绍如何......
  • webpack的html模板中插入变量写法
    vue-cli文档中的描述如下Index文件#public/index.html 文件是一个会被 html-webpack-plugin 处理的模板。在构建过程中,资源链接会被自动注入。另外,VueCLI也会自动注入resourcehint(preload/prefetch、manifest和图标链接(当用到PWA插件时)以及构建过程中处理的Ja......
  • 【模板】链式前向星
    /*https://blog.csdn.net/sugarbliss/article/details/86495945?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522169977002316800215045285%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=169977002316800215045285&biz_id......
  • 【模板】并查集 (洛谷P3367)
    1#include<bits/stdc++.h>2usingnamespacestd;3template<classT>4inlinevoidread(T&s)5{6s=0;7intw=1;8charch=getchar();9while(ch<'0'||ch>'9')10{11......
  • 【模板】线段树1(洛谷P3372)
    1#include<iostream>2#include<cstdio>34usingnamespacestd;56template<classT>7inlinevoidread(T&s)8{9s=0;10intw=1;11charch=getchar();12while(ch<'0�......