log4j配置方式

简介:

Log4j简介:

Log4j是用于管理信息日志的插件工具,Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIXSyslog守护进程Email邮箱等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些只需要通过一个配置文件来灵活地进行配置,而不需要修改工程的代码Log4j因为是在java中使用的,所以lo4j就是log for Java(java的日志)的简写。

 

Log4j下载:

Log4j可以在官网下载,然后将jar包导入到工程就可以使用了。

官网下载地址:

http://logging.apache.org/log4j/1.2/download.html

254a1a638b6501bffdbeed293163a4b7.png




log4j可以直接在Maven工程中通过pom文件配置下载,配置语法:

<!-- https://mvnrepository.com/artifact/log4j/log4j -->

<dependency>

     <groupId>log4j</groupId>

     <artifactId>log4j</artifactId>

     <version>1.2.17</version>

</dependency>

 

Lo4j设计结构:

Lo4j中最主要的四个结构:Logger、Appender、Layout、日志级别,Lo4j中最高父类是Logger类,然后就是Appender类,这个类是用来设置日志信息的输出方向的,使用Appender可以指定日信息输出到控制台、文件、邮箱等等。

Appender常用的日志信息输出方向:

org.apache.log4j.ConsoleAppender(控制台)

 

org.apache.log4j.FileAppender(文件)

 

org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)

 

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)

 

org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

 

接着就是Layout,Layout是用于布局日志信息的输出格式的,常用的Layout布局:

org.apache.log4j.HTMLLayout(以HTML表格形式布局)

 

org.apache.log4j.PatternLayout(可以灵活地指定布局模式)

 

org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)

org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

 

最后是日志级别,日志级别简单地说就是根据你代码中输出日志信息的严重程度来划分一个级别,常用的日志级别有以下几种:

DEBUG 指定细粒度信息事件是最有用的应用程序调试

INFO  指定能够突出在粗粒度级别的应用程序运行情况的信息的消息

WARN   指定具有潜在危害的情况

ERROR  错误事件可能仍然允许应用程序继续运行

FATAL  指定非常严重的错误事件,这可能导致应用程序中止

以上写的级别是做了一个排序的,为什么说是做了排序呢?是因为例如你指定DEBUG级别的话,包括DEBUG以内的以下四个级别的信息都会输出,指定INFO级别则只输出包括INFO内的以下三个级别的信息都会输出,然后以此类推的一个顺序。

例如:

DEBUG>>>DEBUG,INFO,WARN,ERROR,FATAL

INFO>>>INFO,WARN,ERROR,FATAL

WARN>>>WARN,ERROR,FATAL

ERROR>>>ERROR,FATAL

FATAL>>>FATAL

 

配置Lo4j:

Log4j的jar下载到工程后就可以开始进行log4j的配置了,首先创建log4j的属性文件,这个文件对于log4j来说相当于Maven的pom文件,与日志相关的东西都在这个文件里进行配置,要注意的是这个文件的名称必须为log4j.properties,使用其他名称会出错

  Maven工程:

7cecea3e205a7d736ed87565c5c58cbb.png


普通工程:

e915e4056127fdedb249e270d8382822.png


编写一个类,用Logger类的对象调用一些方法来输出日志信息:

2bd691766382078a7974a86f04691a40.png


配置属性文件:

061a3fd4496f2c8f8ef4f9928c25c3d8.png


配置属性文件意义详解:

b1350b30568804f5c1c50c983c3b88ad.png


第二行输出方向需要.layout的原因是因为setLayout方法:

9af355d862523bae83cef78d85fd8bc5.png


那行乱码般地自定义输出格式表示的意义如下:

         %m 输出的文本内容 

       %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL 

       %r 输出自应用启动到输出该log信息耗费的毫秒数 

       %c 输出所属的类目,通常就是所在类的全名 

       %t 输出产生该日志事件的线程名 

       %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n” 

       %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 :10:28,921

       %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

       %x Used to output the NDC (nested diagnostic context) associated with the thread that generated the logging event

%X Used to output the MDC (mapped diagnostic context) associated with the thread that generated the logging event for specified key

 

运行结果:

5b5fd7fb73210635fa4ac3927373303c.png


选择输出日志的级别:

a8d35f530333e9782050058f1764f782.png


运行结果:

3d4b5249c6b83a90044c2986b6d56db7.png


选择某个包的日志信息输出,在log4j.logger 后面加入一个包名就可以了

772727bb23fbbaf7aba76423add03f25.png


运行结果:

1748925cc1cac983a2625010436acc8b.png



还可以具体到选择某个类的日志信息输出:

4eb817ae58d1e6f1daf43df22333a448.png


运行结果:

6fbce5389e833e5419f0d43bba30770d.png




还可以在某个类里自定义别名,然后配置到属性文件后就会输出这个类的日志信息:

  代码示例:

d90055a5bf9a04a1204a1f10538307d0.png


配置属性文件:

545b597725a5114729b5e30b1180eaa2.png


运行结果:

5726bca79a718895baa5a87beb4e570c.png


日志方案可以配置多个,只需要名称不同即可:805517290a6c9eb4466781c81f107e08.png


运行结果:

76d6ec6a0bc6c1fc5e31c56da37f4a2f.png



Maven工程或者普通工程将工程打包成jar包时,注意要去除log4j日志的属性文件,这里以Maven工程做示例,普通工程移除文件即可,Maven工程需要在生命周期中插入一个插件来帮助去除,这样就不需要手动移除了:

配置语法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
< build >
     < plugins >
      < plugin >
        < groupId >org.apache.maven.plugins</ groupId >
        < artifactId >maven-jar-plugin</ artifactId >
        < version >2.4</ version >
        < configuration >
           < excludes >
           < exclude >**/*.properties</ exclude >
          </ excludes >
        </ configuration >
      </ plugin >
     </ plugins >
  </ build >



运行Maven的打包命令可以看到target文件夹和jar包里都没有这个log4j的属性文件:

06ab03edb1258e238a1d21df630b6f7a.png

b45a7259f053a6b91e2c985854b96c07.png


总结:

b459e73c5d8893e1c65e3a02d702c04f.png




本文转自 ZeroOne01 51CTO博客,原文链接:http://blog.51cto.com/zero01/1976703,如需转载请自行联系原作者

相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
相关文章
|
6月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
469 0
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
4601 31
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
7月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
1192 5
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
1171 0
|
安全 BI 网络安全
EventLog Analyzer 如何满足等保合规要求?密码有效期、产品日志保留、配置备份三大核心问题全面解答
EventLog Analyzer(ELA)助力企业满足网络安全等级保护要求,支持配置自动/手动备份、日志180天留存及密码策略管理,提升合规性与安全运营效率。
231 0
|
10月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
1100 4
|
9月前
|
JSON 安全 Go
Go语言项目工程化 —— 日志、配置、错误处理规范
本章详解Go语言项目工程化核心规范,涵盖日志、配置与错误处理三大关键领域。在日志方面,强调其在问题排查、性能优化和安全审计中的作用,推荐使用高性能结构化日志库zap,并介绍日志级别与结构化输出的最佳实践。配置管理部分讨论了配置分离的必要性,对比多种配置格式如JSON、YAML及环境变量,并提供viper库实现多环境配置的示例。错误处理部分阐述Go语言显式返回error的设计哲学,讲解标准处理方式、自定义错误类型、错误封装与堆栈追踪技巧,并提出按调用层级进行错误处理的建议。最后,总结各模块的工程化最佳实践,助力构建可维护、可观测且健壮的Go应用。
|
12月前
|
存储 监控 API
【Azure App Service】分享使用Python Code获取App Service的服务器日志记录管理配置信息
本文介绍了如何通过Python代码获取App Service中“Web服务器日志记录”的配置状态。借助`azure-mgmt-web` SDK,可通过初始化`WebSiteManagementClient`对象、调用`get_configuration`方法来查看`http_logging_enabled`的值,从而判断日志记录是否启用及存储方式(关闭、存储或文件系统)。示例代码详细展示了实现步骤,并附有执行结果与官方文档参考链接,帮助开发者快速定位和解决问题。
325 22
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
数据库连接 测试技术 Windows
【YashanDB知识库】windows配置ODBC跟踪日志, 使用日志定位问题
【YashanDB知识库】windows配置ODBC跟踪日志, 使用日志定位问题