`
l4432848
  • 浏览: 255385 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

-Java-log4j

阅读更多

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

Log4j下载: Log4j可以在官网下载,然后将jar包导入到工程就可以使用了。 官网下载地址:http://logging.apache.org/log4j/1.2/download.html

image

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文件,与日志相关的东西都在这个文件里进行配置: Maven工程:

image

普通工程:

image

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

image

配置属性文件:

image

配置属性文件意义详解:

image

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

image

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

%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},输出类似:20021018日 :1028921       %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

运行结果:

image

选择输出日志的级别:

image

运行结果:

image

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

image

运行结果:

image

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

image

运行结果:

image

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

image

配置属性文件:

image

运行结果:

image

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

image

运行结果:

image

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

<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的属性文件:

image

image

总结:

image

0
0
分享到:
评论

相关推荐

    log4j-core-2.15.0.jar log4j-2.15.0-rc2

    Apache log4j2零日漏洞,根据 log4j-2.15.0-rc2 版本编译生成log4j-api-2.15.0.jar 1.解压你的jar jar xvf XXX.jar 2. 删除旧版本jar cd ./BOOT-INF/lib rm -rf log4j-api-*.jar 3. 上传新版本log4j-api-2.15.0....

    log4j.jar各个版本

    log4j-java1.1.jar, log4j-jcl-2.0.2-javadoc.jar, log4j-jcl-2.0.2-sources.jar, log4j-jcl-2.0.2.jar, log4j-jmx-gui-2.0.2-javadoc.jar, log4j-jmx-gui-2.0.2-sources.jar, log4j-jmx-gui-2.0.2.jar, log4j-nosql...

    log4j-api-2.15.0.jar log4j-2.15.0-rc2

    Apache log4j2零日漏洞,根据 log4j-2.15.0-rc2 版本编译生成log4j-api-2.15.0.jar 1.解压你的jar jar xvf XXX.jar 2. 删除旧版本jar cd ./BOOT-INF/lib rm -rf log4j-api-*.jar 3. 上传新版本log4j-api-...

    log4j-api-2.17.1.jar和log4j-core-2.17.1.jar

    《深入理解log4j-api-2.17.1.jar与log4j-core-2.17.1.jar》 在Java开发中,日志管理是不可或缺的一部分,它帮助我们跟踪程序运行状态、定位错误和调试问题。Log4j作为一款广泛使用的日志框架,历经多次迭代,现在...

    log4j-API-最新稳定版本log4j-1.2.17

    Log4j是Apache软件基金会开发的一个用于Java应用程序的日志记录工具,它提供了灵活的日志记录功能,有助于调试、性能分析和系统监控。"API"(Application Programming Interface)通常指的是开发者用来与库或框架...

    log4j-api-2.12.4.ja和log4j-core-2.12.4.jar

    Log4j是Java编程语言中最常用的日志记录框架之一,由Apache软件基金会开发。它提供了灵活的日志记录功能,使得开发者能够轻松地控制日志信息的输出格式、输出位置以及输出级别。此次提及的`log4j-api-2.12.4.jar`和`...

    log4j-to-slf4j-2.17.1-API文档-中文版.zip

    标签:apache、slf4j、logging、log4j、jar包、java、中文文档; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准...

    log4j-2.15.0-rc2.zip

    内含log4j-api-2.15.0.jar和log4j-core-2.15.0.jar Apache log4j2零日漏洞,根据 log4j-2.15.0-rc2 版本编译生成 1.解压你的jar jar xvf XXX.jar 2. 删除旧版本jar cd ./BOOT-INF/lib rm -rf log4j-api-*.jar 3....

    spring-boot-starter-log4j2

    四、Log4j2配置详解 1. 日志级别:Log4j2支持TRACE、DEBUG、INFO、WARN、ERROR、FATAL和OFF七个级别。通过配置文件,可以设置全局日志级别,也可以针对特定类或包设置不同级别。 2. Appenders:Appender是日志输出...

    apache-log4j-2.17.0 核心jar包

    Log4j 是一个日志记录框架,Log4j 2 是对 Log4j 的升级,提供了重大改进,超越其前身 Log4j 1.x,并提供...Log4j 团队已获悉一个安全漏洞 CVE-2021-45105,该漏洞已在 Java 8 及更高版本的 Log4j 2.17.0 中得到解决。

    log4j-to-slf4j-2.17.1-API文档-中英对照版.zip

    标签:apache、slf4j、logging、log4j、jar包、java、中英对照文档; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明...

    log4j-api-2.12.1-API文档-中文版.zip

    标签:apache、logging、log4j、api、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译...

    log4j-over-slf4j-1.7.33-API文档-中文版.zip

    标签:over、slf4j、log4j、jar包、java、中文文档; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心...

    实用6个java库-Mysql-Java_Mail-log4j_1.2.17-Slf4j_Api-Slf4j_Log4j

    实用java库-Mysql-Java_Mail-log4j_1.2.17-Slf4j_Api-Slf4j_Log4j mysql-connector-java-5.1.47 mail log4j-1.2.17 activation slf4j-api-1.7.25 slf4j-log4j12-1.7.25

    log4j-slf4j-impl-2.12.1-API文档-中文版.zip

    标签:apache、logging、log4j、slf4j、impl、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明...

    log4j-slf4j-impl-2.12.1-API文档-中英对照版.zip

    标签:apache、logging、log4j、slf4j、impl、中英对照文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和...

    log4j-to-slf4j-2.12.1-API文档-中文版.zip

    标签:apache、logging、log4j、slf4j、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准...

    log4j-2.18.0

    然而,这次的2.0及以上版本的log4j2中发现的安全漏洞,使得恶意用户能够通过精心构造的输入,触发JNDI(Java Naming and Directory Interface)查找,进而执行任意远程代码。 Log4Shell漏洞的核心在于log4j2的...

    log4j-java1.1.jar

    log4j-java1.1.jar

    修复log4j漏洞log4j2下载最新log4j2.16.0下载 log4j-api-2.16.0.jar

    apache下载太慢,特搬到国内下载。修复log4j漏洞log4j2下载最新log4j2.16.0下载

Global site tag (gtag.js) - Google Analytics