在日常的开发中经常需要通过输出一些信息进行程序的调试,如果到处都用system.out.println()则在项目发布之后要逐一删除,而log4j提供了一种新的调试输出机制以解决输出的问题。log4j的原理是使用一个配置文件log4j.properties进行管理,在调试的时候可以把输出级别调低,项目正式发布之后把级别调高,这样以前的一些输出就可以屏蔽了,不用到程序当中再进行逐一删除。我们可以结合了commons-logging和log4j来进行日常的输出调试信息和记录系统运行的信息日志
在spring的项目中,spring为我们提供了管理log4j的类,
如果项目中使用了spring我一般都会通过spring提供的类来管理日志信息
一,首先我们来看看非spring环境中使用log4j
使用步骤。
1.添加必须jar包
a。commons-logging.jar
b. log4j-1.2.14.jar
2.在web目录的src目录下面添加两个文件:commons-logging.properties和 log4j.properties
a.commons-logging.properties(文件名必须是此指定文件名),通用日志接口从此属性文件中获取实现日志添加内容如下:
#通过Log4J日志器来实现日志记录功能
org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger
b.log4j.properties ,为log4j指定相应的属性
#指定日志的级别为DEBUG,log4j共有OFF(关闭),FATAL(严重的错误),ERROR(一般性错误),WARN(警告),INFO(信息),DEBUG(调试信息),TRACE(追踪)和ALL等8个基本
#并配置了两个输出目的地为e1(输出在控制台上),e2(输出在日志文件中)
log4j.rootLogger=DEBUG,e1,e2
#指定e1日志信息输出在控制台
log4j.appender.e1=org.apache.log4j.ConsoleAppender
#指定e1日志信息输出格式为简单格式,它打印级别 Level,然后跟着一个破折号“-“ ,最后是日志消息。也可以自己定义格式
log4j.appender.e1.layout=org.apache.log4j.SimpleLayout
#指定e2日志信息输出在指定文件中
log4j.appender.e2=org.apache.log4j.FileAppender
log4j.appender.e2.layout=org.apache.log4j.SimpleLayout
#指定e2日志信息输出在logging.txt文件中,默认生成的logging.txt文件在tomcat的bin目录下
log4j.appender.e2.File=logging.txt
如果自己定义输出的日志,如下
log4j.rootLogger=DEBUG,e1,e2
log4j.appender.e1=org.apache.log4j.ConsoleAppender
#log4j.appender.e1.layout=org.apache.log4j.SimpleLayout
#指定布局模式格式
log4j.appender.e1.layout=org.apache.log4j.PatternLayout
#定义自己的输出格式
log4j.appender.e1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%-5p][%c] - %m%n
log4j.appender.e2=org.apache.log4j.FileAppender
log4j.appender.e2.layout=org.apache.log4j.PatternLayout
log4j.appender.e2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%-5p][%c] - %m%n
log4j.appender.e2.File=logging.txt
详细配置信息
配置Appender组件
配置日志消息输出目的地Appender,有以下几种
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小达到指定尺寸的时候产生一个新文件)
org.apache.log4j.WriterAppender(将日志信息以流个格式发送到任意指定的地方)
例如以下代码定义了一个名了file的Appender,它把日志信息输出到log.txt文件
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=log.txt
配置Layout组件
Log4j提供下面几种Layout
org.apache.log4j.HTMLLayout(以html表格形式布局)
org.apache.log4j.PatterLayout(可以灵活的指定布局模式)
org.apache.log4j.SimpleLayout(包含日志消息的级别和信息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间线程和类别)
Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下: %m 输出代码中指定的消息
Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
二、在spring的项目中使用log4j
首先需要在web.xml进行声明:
<!--如果不定义webAppRootKey参数,那么webAppRootKey就是缺省的"webapp.root"-->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>ssh.root</param-value>
</context-param>
这里的ssh是http://localhost:8080/ssh/
而root是系统开发目录中ssh/root
这样配置文件以及日志文件可以在spring的帮助下,放到开发环境中的任意位置
<!--由Sprng载入的Log4j配置文件位置-->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log4j.properties</param-value>
</context-param>
在这里定位配置文件,需要的是从root开始的绝对路径
<!--Spring默认刷新Log4j配置文件的间隔,单位为millisecond-->
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>60000</param-value>
</context-param>
设置监听器
<!--Spring log4j Config loader-->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
之后我们就可以配置log4j配置文件了,内容如上的log4j.properties
我找了一个格式,copy如下
#先设置级别
log4j.rootLogger=INFO, file
log4j.appender.file=org.apache.log4j.RollingFileAppender
#在这里设置日志需要存放的位置,这里的变量就是我们在web.xml里设置的
log4j.appender.file.File=${ssh.root}/WEB-INF/logs/subject.log
log4j.appender.file.MaxFileSize=100KB
log4j.appender.file.MaxBackupIndex=0
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[ssh] %p %t %c - %m%n
相关推荐
该项目是一个基于C++的仿Log4j日志处理系统设计源码,共包含64个文件,涵盖28个头文件(hh)、26个源文件(cpp)、3个Markdown文档(md)、1个许可证文件(LICENSE)、1个GIF图片文件、1个Unix平台的Makefile(test/Makefile_...
Log4j是Java编程语言中广泛使用的...总的来说,Log4j作为Java日志处理的首选工具,提供了强大的日志管理能力,帮助开发者更好地理解和控制他们的应用程序。通过合理的配置和使用,可以极大地提升开发效率和系统稳定性。
总的来说,处理Log4j的初始化警告,关键在于正确配置和引入Log4j依赖,以及在需要使用日志的地方正确初始化logger。确保配置文件可用且路径正确,以及在代码中正确调用logger,通常可以消除这些警告。
### Log4j日志配置详解 #### 一、概述 Log4j 是一个基于 Java 的开源日志记录框架,由 Apache 软件基金会维护。它允许开发人员根据等级记录日志信息,使得用户能够控制日志信息的记录级别及去向。本文将通过一份...
在Java开发中,日志记录是一项至关重要的任务,它帮助我们追踪程序运行状态,定位问题,以及进行性能...在项目中使用自定义的日志处理方式,能够极大地提高日志的管理和分析效率,为问题排查和性能优化提供有力支持。
《深入理解Log4j日志打印》 在Java开发领域,日志打印是不可或缺的一环,它对于系统调试、性能监控、故障排查等都起着至关重要的作用。Log4j作为Java中最常用的日志框架之一,深受广大开发者喜爱。本文将深入探讨...
《深入理解Log4j日志框架》 在Java开发领域,日志系统是不可或缺的工具,它用于记录程序运行过程中的各种信息,帮助开发者在问题出现时定位和解决问题。Log4j作为Apache软件基金会的一个开源项目,是Java世界中最...
本文将详细讨论如何解决Log4j日志文件出现的乱码问题。 首先,我们要理解Log4j的工作原理。Log4j允许开发者自定义日志输出的方式,包括输出到控制台、文件、数据库等。它使用了`QuietWriter`类来写入日志,`...
在Log4j2中,可以通过实现Filter接口创建自定义过滤器,用于在日志事件被记录之前进行处理。在这个过滤器中,我们可以识别并替换敏感信息。例如,识别到用户名字段,可以将其替换为“[MASKED]”。 3. **配置过滤器...
当我们遇到“无法打出log4j日志的问题”,这通常是由于配置、环境或代码实现中的某些错误导致的。这篇长文将深入探讨如何排查和解决这类问题。 首先,我们要理解Log4j的基本工作原理。Log4j通过配置文件(通常是log...
要实现动态设置Log4j日志级别,通常有以下几种方法: 1. **通过配置文件**:最常见的方式是通过修改log4j.properties或log4j.xml配置文件。例如,你可以将某个类或整个包的日志级别设置为WARN: ```xml ```...
Log4j2是一款广泛使用的日志框架,它提供了灵活且高效的日志记录功能。本示例将详细介绍如何配置并使用Log4j2将日志信息记录到MySQL数据库中。 首先,我们要理解Log4j2的核心概念。Log4j2主要包括以下几个组件: 1...
Log4j是一个广泛使用的Java日志框架,它提供了强大的日志处理功能,包括日志级别控制、自定义日志格式、多路复用等。然而,由于Android系统对第三方库的限制,直接在Android工程中使用Log4j需要一些额外的步骤。本文...
在"Log4J日志代码"这个主题中,我们将深入探讨Log4J的核心概念、配置以及如何在Java项目中使用。 1. **核心组件**: - **Logger**: 是日志记录的主要接口,通过它来创建和发送日志消息。开发者可以根据类名或模块...
Log4j是Apache组织开发的一款强大的Java日志框架,它为开发者提供了灵活的日志记录功能。在Java应用程序中,日志...通过阅读提供的Log4j日志文档和使用包中的示例,你可以深入了解如何配置和利用这个强大的日志工具。
- **异步日志处理**:Log4j2通过其异步日志处理机制,能够显著减少日志记录对应用性能的影响。特别是在高并发场景下,这种优势更为明显。 - **内存占用**:Log4j2在内存使用方面也表现出色,尤其是在开启异步模式...
通过阅读和分析这些代码,你可以更深入地理解Log4j的使用方法,以及DailyRollingFileAppender如何处理日志文件的滚动和删除。 总之,Log4j的DailyRollingFileAppender结合`maxBackupIndex`参数,可以很好地满足对...
Log4j2是一款广泛使用的Java日志框架,它提供了丰富的日志记录功能和高度的可配置性。在大型系统中,日志记录是至关重要的,因为它可以帮助开发者追踪系统行为、定位错误以及进行性能分析。而Log4j2的一个显著特性是...
此外,随着Java社区的发展,Log4j也经历了多次版本更新,最新的Log4j 2.x引入了更多新特性,如异步日志处理、更灵活的配置语法和强大的日志分析能力。 总之,Log4j作为一款强大的日志工具,为企业级应用提供了一套...
通过以上介绍,我们可以看出Log4j日志框架在Java开发中的重要地位,它不仅简化了日志处理,还为故障排查、性能分析和系统监控提供了有力支持。正确使用和配置Log4j,将有助于提升软件质量和维护效率。