首页 > 其他分享 >【log4j 2.x】【log4j日志升级漏洞修复】log4j2日志 [简单明了][一眼就会]

【log4j 2.x】【log4j日志升级漏洞修复】log4j2日志 [简单明了][一眼就会]

时间:2024-09-22 11:12:11浏览次数:8  
标签:info logging apache org 日志 log4j2 log4j

大多同学说的不是很全,写的不是很具体。

在此,本人出一篇简单明了的详细教程:

 

目录:

1、加载log4j 2包

2、配置xml文件

3、写测试并运行

4、log指定文件:自动打印info、error日志

5、整体code

正文:

1、加载log4j 2包
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.18.0</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.18.0</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>2.18.0</version>
</dependency>
2、配置xml文件:log4j2.xml

<?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="LOG_HOME">logs</Property>
<property name="FILE_NAME">you_Project</property>
</Properties>

<Appenders>
<!--这个输出控制台的配置-->
<Console name="Console" target="SYSTEM_OUT">
<!--控制台只输出level及其以上级别的信息(onMatch),其他的直接拒绝(onMismatch)-->
<ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>
<!--日志输出的格式-->
<!--
%d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间,输出到毫秒的时间
%-5level : 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0
%c : logger的名称(%logger)
%t : 输出当前线程名称
%p : 日志输出格式
%m : 日志内容,即 logger.info("message")
%n : 换行符
%C : Java类名(%F)
%L : 行号
%M : 方法名
%l : 输出语句所在的行数, 包括类名、方法名、文件名、行数
hostName : 本地机器名
hostAddress : 本地ip地址
-->
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</Console>

<!--
循环日志文件:日志文件大于阀值的时候,就开始写一个新的日志文件
这个会打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档
fileName : 指定当前日志文件的位置和文件名称
filePattern : 指定当发生Rolling时,文件的转移和重命名规则
SizeBasedTriggeringPolicy : 指定当文件体积大于size指定的值时,触发Rolling
DefaultRolloverStrategy : 指定最多保存的文件个数
TimeBasedTriggeringPolicy : 这个配置需要和filePattern结合使用
注意filePattern中配置的文件重命名规则是${FILE_NAME}_%d{yyyy-MM-dd}_%i,最小的时间粒度是dd,即天,
TimeBasedTriggeringPolicy指定的size是1,结合起来就是每1天生成一个新文件
-->

<RollingRandomAccessFile name="INFO" fileName="logs/${FILE_NAME}.log"
filePattern="log/${FILE_NAME}_%d{yyyy-MM-dd}_%i.log.gz">
<Filters>
<ThresholdFilter level="WARN" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="TRACE" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="1MB"/>
</Policies>
<DefaultRolloverStrategy max="20"/>
</RollingRandomAccessFile>

<!--错误信息记录-->
<RollingRandomAccessFile name="ERROR" fileName="logs/${FILE_NAME}-ERROR.log"
filePattern="log/${FILE_NAME}-ERROR_%d{yyyy-MM-dd}_%i.log.gz">
<Filters>
<ThresholdFilter level="FATAL" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="WARN" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="1MB"/>
</Policies>
<DefaultRolloverStrategy max="20"/>
</RollingRandomAccessFile>

<!--系统级别的错误信息-->
<RollingRandomAccessFile name="FATAL" fileName="logs/${FILE_NAME}-FATAL.log"
filePattern="log/${FILE_NAME}-FATAL%d{yyyy-MM-dd}_%i.log.gz">
<Filters>
<ThresholdFilter level="FATAL" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="1MB"/>
</Policies>
<DefaultRolloverStrategy max="20"/>
</RollingRandomAccessFile>

<!--全部日志信息:DEBUG及以上级别-->
<RollingRandomAccessFile name="ALL" fileName="logs/${FILE_NAME}-ALL.log"
filePattern="log/${FILE_NAME}-ALL%d{yyyy-MM-dd}_%i.log.gz">
<Filters>
<ThresholdFilter level="DEBUG" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="10MB"/>
</Policies>
<DefaultRolloverStrategy max="20"/>
</RollingRandomAccessFile>

<!--配置异步写日志-->
<Async name="Async">
<AppenderRef ref="ALL"/>
</Async>

<!--输出到MongoDB中-->
<NoSql name="databaseAppender">
<MongoDb databaseName="test" collectionName="errorlog" server="localhost" port="27017"/>
</NoSql>
</Appenders>

<!--然后定义logger,只有定义了logger并引入的appender,appender才会生效-->
<Loggers>
<!--监控系统信息-->
<Logger name="org.springframework" level="info" additivity="false">
<AppenderRef ref="Console"/>
</Logger>

<!--输出到NoSQL中-->
<Logger name="mongoLog" level="trace" additivity="false">
<AppenderRef ref="databaseAppender"/>
</Logger>

<Root level="debug">
<!-- 这儿为trace表示什么都可以打印出来了,其他几个级别分别为:TRACE、DEBUG、INFO、WARN、ERROR和FATAL -->
<Appender-Ref ref="Console"/>
<Appender-Ref ref="INFO"/>
<Appender-Ref ref="ERROR"/>
<Appender-Ref ref="FATAL"/>
</Root>
</Loggers>

</Configuration>

  


3、写测试并运行
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class Test {

private static Logger logger = LogManager.getLogger(Test.class);

public static void main(String[] args) {
logger.info("info:xxxxx......");
logger.error("error:xxxx......");
}
}
4、log指定文件:自动打印info、error日志


5、整体code:
https://gitlab.com/huaruizhi1/log4j2demo/-/tree/main

标签:info,logging,apache,org,日志,log4j2,log4j
From: https://www.cnblogs.com/liuguiqing/p/18425080

相关文章

  • Java日志框架混乱原因
    在Java开发中,有时会让人感觉日志框架比较混乱,主要有以下几个原因:一、历史发展原因Java日志框架在发展过程中经历了多个阶段,不同的框架在不同时期被开发出来以满足特定的需求。1.早期的Java应用可能只使用了简单的System.out.println进行输出,但随着应用的复杂度增......
  • 清理日志
    #!/bin/envbash#set-xclear_time=date+%Y%m%dLOG_FILELOG_FILE="/tmp/log_clean.{clear_time}.log"#savecleanlogwrite_log(){now_time='['(date+"%Y-%m-%d%H:%M:%S")']'echo{now_time}1|tee-a{LOG_FILELOG_FILE......
  • Wpf使用NLog将日志输出到LogViewer
    1LogViewerLogViewer是通过UDP传输的高性能实时log查看器。具有一下特性:通过UDP读取日志通过文件导入日志导出日志到一个文件中排序、过滤(日志树,日志等级)和查找突出显示搜索文本从UPD接收日志时忽略IP地址列表多接收器支持多种颜色主题项目地址:https://github.com/......
  • 痞子衡嵌入式:MCUBootUtility v6.3发布,支持获取与解析启动日志zi
    --痞子衡维护的NXP-MCUBootUtility工具距离上一个大版本(v5.3.0)发布过去一年了,期间痞子衡也做过三个版本更新,但不足以单独介绍。这一次痞子衡为大家带来了全新重要版本v6.3.x,这次更新主要是想和大家特别聊聊ROM启动日志这个特性的支持。一、v6.0-v6.3更新记录--v5.......
  • python中函数式编程与高阶函数,装饰器与生成器,异常处理与日志记录以及项目实战
    函数式编程是Python强大且灵活的编程范式之一,与此同时,Python也为开发者提供了高阶函数、装饰器、生成器等工具,极大提高了代码的可读性和复用性。此外,异常处理与日志记录是编写可靠、可维护的Python代码的重要组成部分。最后,通过一个项目实战来整合这些概念。我们将从......
  • MySQL数据库日志之WAL机制和Buffer Pool
    WAL机制(Write-Ahead-Logging)先磁盘之前先写入日志文件到磁盘,也就是redolog中的后台系统线程,每1秒进行一次对redologBuffer刷盘操作。标准的UndoLog这一步是靠WAL实现的,也就是要求Undo写入先于数据落盘。对于,undolog的WAL机制,只是相对于提交事务后的刷盘和......
  • 2024/9/20日 日志
    今天,进行了新的测试。题目为简单的学生管理系统,包含增删改查。点击查看代码//张一衡20234023importjava.util.ArrayList;importjava.util.Scanner;publicclassMoontest{publicstaticvoidmain(String[]args){StudentManagerstudentManager=new......
  • 2024/9/20日工作日志
    Java第二次测试代码:publicclassStudent{Stringstunumber;Stringname;intage;booleansex;doublescore;publicStudent(Stringstunumber,Stringname,intage,booleansex,doublescore){this.stunumber=stunumber;this.name=name;this.age......
  • grafana Loki 日志采集
    lokiLoki是受Prometheus启发的水平可扩展,高度可用的多租户日志聚合系统。它的设计具有很高的成本效益,并且易于操作。它不索引日志的内容,而是为每个日志流设置一组标签。日志对比ELKstack和Graylog,ELK目前很多公司都在使用,是一种很不错的分布式日志解决方案,但是需要的组件多......
  • Django4中的日志管理
    Django4中的日志管理参考:Django配置日志:https://www.cnblogs.com/Neeo/articles/17588553.htmlpython内置模块logging模块:https://www.cnblogs.com/Neeo/articles/10951734.html按照文件大小进行切割日志在你的settings.py中。LOGS_DIRS=os.path.join(BASE_DIR,'logs')if......