前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >log4j配置方式

log4j配置方式

作者头像
端碗吹水
发布2020-09-23 10:33:49
1.1K0
发布2020-09-23 10:33:49
举报
文章被收录于专栏:程序猿的大杂烩

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
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
7cecea3e205a7d736ed87565c5c58cbb.png

普通工程:

e915e4056127fdedb249e270d8382822.png
e915e4056127fdedb249e270d8382822.png

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

2bd691766382078a7974a86f04691a40.png
2bd691766382078a7974a86f04691a40.png

配置属性文件:

061a3fd4496f2c8f8ef4f9928c25c3d8.png
061a3fd4496f2c8f8ef4f9928c25c3d8.png

配置属性文件意义详解:

b1350b30568804f5c1c50c983c3b88ad.png
b1350b30568804f5c1c50c983c3b88ad.png

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

9af355d862523bae83cef78d85fd8bc5.png
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
5b5fd7fb73210635fa4ac3927373303c.png

选择输出日志的级别:

a8d35f530333e9782050058f1764f782.png
a8d35f530333e9782050058f1764f782.png

运行结果:

3d4b5249c6b83a90044c2986b6d56db7.png
3d4b5249c6b83a90044c2986b6d56db7.png

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

772727bb23fbbaf7aba76423add03f25.png
772727bb23fbbaf7aba76423add03f25.png

运行结果:

1748925cc1cac983a2625010436acc8b.png
1748925cc1cac983a2625010436acc8b.png

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

4eb817ae58d1e6f1daf43df22333a448.png
4eb817ae58d1e6f1daf43df22333a448.png

运行结果:

6fbce5389e833e5419f0d43bba30770d.png
6fbce5389e833e5419f0d43bba30770d.png

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

  代码示例:

d90055a5bf9a04a1204a1f10538307d0.png
d90055a5bf9a04a1204a1f10538307d0.png

配置属性文件:

545b597725a5114729b5e30b1180eaa2.png
545b597725a5114729b5e30b1180eaa2.png

运行结果:

5726bca79a718895baa5a87beb4e570c.png
5726bca79a718895baa5a87beb4e570c.png

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

805517290a6c9eb4466781c81f107e08.png
805517290a6c9eb4466781c81f107e08.png

运行结果:

76d6ec6a0bc6c1fc5e31c56da37f4a2f.png
76d6ec6a0bc6c1fc5e31c56da37f4a2f.png

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

配置语法:

代码语言:javascript
复制
<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
06ab03edb1258e238a1d21df630b6f7a.png
b45a7259f053a6b91e2c985854b96c07.png
b45a7259f053a6b91e2c985854b96c07.png

总结:

b459e73c5d8893e1c65e3a02d702c04f.png
b459e73c5d8893e1c65e3a02d702c04f.png
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017/10/27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档