热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

log4j配置详解!看完必懂!

日志是应用软件中不可缺少的部分,Apache的开源项目log4j是一个功能强大的日志组件,提供方便的日志记录。在apache网站:jakarta.apa

日志是应用软件中不可缺少的部分,Apache的开源项目log4j是一个功能强大的日志组件,提供方便的日志记录。在apache网站:jakarta.apache.org/log4j 可以免费下载到Log4j最新版本的软件包。


一、入门实例

1、 新建一个Java工程,导入Log4j包,pom文件中对应的配置代码如下:


<dependency><groupId>log4jgroupId><artifactId>log4jartifactId><version>1.2.17version>
dependency>

2、 resources目录下创建log4j.properties文件

### 设置###
log4j.rootLogger &#61; debug,stdout,D,E### 输出信息到控制抬 ###
log4j.appender.stdout &#61; org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target &#61; System.out
log4j.appender.stdout.layout &#61; org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern &#61; [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n### 输出DEBUG 级别以上的日志到&#61;/home/duqi/logs/debug.log ###
log4j.appender.D &#61; org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File &#61; /home/duqi/logs/debug.log
log4j.appender.D.Append &#61; true
log4j.appender.D.Threshold &#61; DEBUG
log4j.appender.D.layout &#61; org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern &#61; %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n### 输出ERROR 级别以上的日志到&#61;/home/admin/logs/error.log ###
log4j.appender.E &#61; org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File &#61;/home/admin/logs/error.log
log4j.appender.E.Append &#61; true
log4j.appender.E.Threshold &#61; ERROR
log4j.appender.E.layout &#61; org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern &#61; %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n

3、输出日志的例子如下

package com.javadu.log;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;public class Log4JTest {private static final Logger logger &#61; LoggerFactory.getLogger(Log4JTest.class);public static void main(String[] args) {// 记录debug级别的信息logger.debug("This is debug message.");// 记录info级别的信息logger.info("This is info message.");// 记录error级别的信息logger.error("This is error message.");}
}

4、输出结果
首先&#xff0c;控制台输入如下图所示&#xff1a;

img

控制台输出结果

然后&#xff0c;查看*/Users/duqi/logs*目录下的debug.log和error.log文件&#xff0c;内容分别如下&#xff0c;可以看出&#xff0c;&#xff1a;


  • debug.log

img

debug.log


  • error.log

img

屏幕快照 2016-02-03 下午3.49.23.png


二、Log4J基本使用方法

Log4j由三个重要的组件构成&#xff1a;日志信息的优先级&#xff0c;日志信息的输出目的地&#xff0c;日志信息的输出格式。日志信息的优先级从高到低有ERROR、WARN、 INFO、DEBUG&#xff0c;分别用来指定这条日志信息的重要程度&#xff1b;日志信息的输出目的地指定了日志将打印到控制台还是文件中&#xff1b;而输出格式则控制了日志信息的显 示内容


2.1 定义配置文件

其实您也可以完全不使用配置文件&#xff0c;而是在代码中配置Log4j环境。但是&#xff0c;使用配置文件将使您的应用程序更加灵活。Log4j支持两种配置文件格式&#xff0c;一种是XML格式的文件&#xff0c;一种是Java特性文件&#xff08;键&#61;值&#xff09;。下面我们介绍使用Java特性文件做为配置文件的方法&#xff1a;


  1. 配置根Logger&#xff0c;其语法为&#xff1a;

log4j.rootLogger &#61; [ level ] , appenderName, appenderName, …

其中&#xff0c;level 是日志记录的优先级&#xff0c;分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。Log4j建议只使用四个级别&#xff0c;优 先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别&#xff0c;您可以控制到应用程序中相应级别的日志信息的开关。比如在这里定 义了INFO级别&#xff0c;则应用程序中所有DEBUG级别的日志信息将不被打印出来。 appenderName就是指把日志信息输出到哪个地方。您可以同时指定多个输出目的地&#xff0c;例如上述例子我们制定了stdout、D和E这三个地方。


  1. 配置文件的输出目的地Appender&#xff0c;一般&#xff0c;配置代码的格式如下

log4j.appender.appenderName &#61; fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 &#61; value1

log4j.appender.appenderName.option &#61; valueN

其中&#xff0c;Log4j提供的appender有以下几种&#xff1a;


  • org.apache.log4j.ConsoleAppender&#xff08;控制台&#xff09;&#xff0c;
  • org.apache.log4j.FileAppender&#xff08;文件&#xff09;&#xff0c;
  • org.apache.log4j.DailyRollingFileAppender&#xff08;每天产生一个日志文件&#xff09;&#xff0c;
  • org.apache.log4j.RollingFileAppender&#xff08;文件大小到达指定尺寸的时候产生一个新的文件&#xff09;&#xff0c;
  • org.apache.log4j.WriterAppender&#xff08;将日志信息以流格式发送到任意指定的地方&#xff09;

  1. 配置日志信息的格式&#xff08;布局&#xff09;&#xff0c;其语法为&#xff1a;

log4j.appender.appenderName.layout &#61; fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 &#61; value1

log4j.appender.appenderName.layout.option &#61; valueN

其中&#xff0c;Log4j提供的layout有以下几种&#xff1a;


  • org.apache.log4j.HTMLLayout&#xff08;以HTML表格形式布局&#xff09;&#xff0c;
  • org.apache.log4j.PatternLayout&#xff08;可以灵活地指定布局模式&#xff09;&#xff0c;
  • org.apache.log4j.SimpleLayout&#xff08;包含日志信息的级别和信息字符串&#xff09;&#xff0c;
  • org.apache.log4j.TTCCLayout&#xff08;包含日志产生的时间、线程、类别等等信息&#xff09;

Log4J采用类似C语言中的printf函数的打印格式格式化日志信息&#xff0c;打印参数如下&#xff1a;


  • %m 输出代码中指定的消息
  • %p 输出优先级&#xff0c;即DEBUG&#xff0c;INFO&#xff0c;WARN&#xff0c;ERROR&#xff0c;FATAL
  • %r 输出自应用启动到输出该log信息耗费的毫秒数
  • %c 输出所属的类目&#xff0c;通常就是所在类的全名
  • %t 输出产生该日志事件的线程名
  • %n 输出一个回车换行符&#xff0c;Windows平台为“rn”&#xff0c;Unix平台为“n”
  • %d 输出日志时间点的日期或时间&#xff0c;默认格式为ISO8601&#xff0c;也可以在其后指定格式&#xff0c;比如&#xff1a;%d{yyy MMM dd HH:mm:ss,SSS}&#xff0c;输出类似&#xff1a;2002年10月18日 22&#xff1a;10&#xff1a;28&#xff0c;921
  • %l 输出日志事件的发生位置&#xff0c;包括类目名、发生的线程&#xff0c;以及在代码中的行数。举例&#xff1a;Testlog4.main(TestLog4.java:10)

2.2 在代码中使用Log4j


  1. 获取记录器
    使用Log4j&#xff0c;第一步就是获取日志记录器&#xff0c;这个记录器将负责控制日志信息。其语法为&#xff1a;public static Logger getLogger( String name)&#xff1b;通过指定的名字获得记录器&#xff0c;如果必要的话&#xff0c;则为这个名字创建一个新的记录器。Name一般取本类的名字&#xff0c;比如&#xff1a;static Logger logger &#61; Logger.getLogger ( ServerWithLog4j.class.getName () )
  2. 读取配置文件
    当获得了日志记录器之后&#xff0c;第二步将配置Log4j环境&#xff0c;其语法为&#xff1a;

BasicConfigurator.configure ()&#xff1a; 自动快速地使用缺省Log4j环境。
PropertyConfigurator.configure ( String configFilename) &#xff1a;读取使用Java的特性文件编写的配置文件。
DOMConfigurator.configure ( String filename ) &#xff1a;读取XML形式的配置文件。

  1. 插入记录信息&#xff08;格式化日志信息&#xff09;
    当上两个必要步骤执行完毕&#xff0c;您就可以轻松地使用不同优先级别的日志记录语句插入到您想记录日志的任何地方&#xff0c;其语法如下&#xff1a;

Logger.debug ( Object message ) ;
Logger.info ( Object message ) ;
Logger.warn ( Object message ) ;
Logger.error ( Object message ) ;

2.3 日志级别

每个Logger都被了一个日志级别&#xff08;log level&#xff09;&#xff0c;用来控制日志信息的输出。日志级别从高到低分为&#xff1a;
A&#xff1a;off 最高等级&#xff0c;用于关闭所有日志记录。
B&#xff1a;fatal 指出每个严重的错误事件将会导致应用程序的退出。
C&#xff1a;error 指出虽然发生错误事件&#xff0c;但仍然不影响系统的继续运行。
D&#xff1a;warm 表明会出现潜在的错误情形。
E&#xff1a;info 一般和在粗粒度级别上&#xff0c;强调应用程序的运行全程。
F&#xff1a;debug 一般用于细粒度级别上&#xff0c;对调试应用程序非常有帮助。
G&#xff1a;all 最低等级&#xff0c;用于打开所有日志记录。

上面这些级别是定义在org.apache.log4j.Level类中。Log4j只建议使用4个级别&#xff0c;优先级从高到低分别是error,warn,info和debug。通过使用日志级别&#xff0c;可以控制应用程序中相应级别日志信息的输出。例如&#xff0c;如果使用b了info级别&#xff0c;则应用程序中所有低于info级别的日志信息(如debug)将不会被打印出来。


三、Spring中使用Log4J

一般是在web.xml配置文件中配置Log4j监听器和log4j.properties文件&#xff0c;代码如下&#xff1a;

<context-param><param-name>log4jConfigLocationparam-name><param-value>classpath:/config/log4j.propertiesparam-value>
context-param>
<context-param><param-name>log4jRefreshIntervalparam-name><param-value>60000param-value>
context-param>
<listener><listener-class>org.springframework.web.util.Log4jConfigListenerlistener-class>
listener>

在之前的Spring In Action系列文章中&#xff0c;我都是以Java Config文件为例进行总结&#xff0c;则对应的Log4J的配置如下&#xff1a;

//todo

四、实战经验总结

在商业项目中&#xff0c;日志可用于数据化运营&#xff0c;需要记录关键的业务数据&#xff1b;开发过程中必须准确记录业务日志&#xff0c;如果丢失业务数据则是很严重的故障。

日志信息的打印会影响到服务的性能&#xff08;吞吐量和响应时间&#xff09;&#xff0c;在业务逻辑简单的服务中更加明显。举个例子&#xff0c;我最近负责的一个会话管理的模块&#xff0c;在性能压测的时候发现TPS只能达到250左右&#xff0c;被这个问题困扰了很久。首先找出性能的瓶颈&#xff1a;缓存操作和数据库操作


  • 发现在缓存操作中有一行打印日志的语句使用了JSON库&#xff0c;例如JSON.toJsonString(obj)&#xff0c;这个对象非常复杂&#xff0c;导致一个读取缓存的操作可以达到300ms左右&#xff0c;而实际上应该在10ms左右&#xff1b;
  • 发现数据库操作非常耗时&#xff0c;但是经过分析&#xff0c;在系统稳定后&#xff0c;压力并不是很大时&#xff0c;数据库操作也比较正常&#xff1b;但是一旦并发数增高&#xff0c;则RT迅速增大&#xff0c;通过链路分析工具&#xff0c;查看在系统负载变高的过程中的指标发现*CallAppenders()*方法占据了将近40%以上的CPU时间&#xff0c;因此我才考虑到需要将日志级别调整为ERROR级别——不打印DEBUG级别的日志&#xff0c;至此&#xff0c;这个问题算是解决了。

作者&#xff1a;javaadu
链接&#xff1a;https://www.jianshu.com/p/c6c543e4975e
来源&#xff1a;简书
常耗时&#xff0c;但是经过分析&#xff0c;在系统稳定后&#xff0c;压力并不是很大时&#xff0c;数据库操作也比较正常&#xff1b;但是一旦并发数增高&#xff0c;则RT迅速增大&#xff0c;通过链路分析工具&#xff0c;查看在系统负载变高的过程中的指标发现*CallAppenders()*方法占据了将近40%以上的CPU时间&#xff0c;因此我才考虑到需要将日志级别调整为ERROR级别——不打印DEBUG级别的日志&#xff0c;至此&#xff0c;这个问题算是解决了。

作者&#xff1a;javaadu
链接&#xff1a;https://www.jianshu.com/p/c6c543e4975e
来源&#xff1a;简书
著作权归作者所有。商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处。


推荐阅读
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • MVC下Log4Net的配置和使用
    MVC下Log4Net的配置和使用对于网站来讲,我们不能将异常信息显示给用户,Log4Net用来记录日志,可以将程序运行过程中的信息输出到文件,数据库中等地方,可以通过日志查看系统的运行过程,发现系 ... [详细]
  • 学习mybatis的基础知识:mybatis入门教程(二)
    2019独角兽企业重金招聘Python工程师标准2.3MyBatisprintsql在log4j.properties配置文件中添加如下配置,让mybatis打 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • FeatureRequestIsyourfeaturerequestrelatedtoaproblem?Please ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 当我在doWork方法中运行代码时,通过单击button1,进度条按预期工作.但是,当我从其他方法(即btn2,btn3)将列表传递给doWork方法时,进度条在启动后会跳转到10 ... [详细]
author-avatar
手机用户2502896641
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有