Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以
控制日志信息输送的目的地:控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;
控制每一条日志的输出格式;
通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。
最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。
通过Log4j其他语言接口,您可以在C、C++、.Net、PL/SQL程序中使用Log4j,其语法和用法与在Java程序中一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通过使用各种第三方扩展,您可以很方便地将Log4j集成到J2EE、JINI甚至是SNMP应用中。
Log4j应用:
第一步
第二步
if (log.isFatalEnabled()){log.fatal("555");}
第二步详解:
格式化日志信息
定义及获取不同层次的记录器:
1) 在配置文件中定义相应的记录器。
定义根记录器的格式:log4j.rootLogger = [ level ], appendName1, appendName2, …appendNameN
定义一个非根记录器的格式:log4j.logger.loggerName1 = [ level ], appendName1,…appendNameN
可以定义任意个非根记录器
2) 在代码中调用Logger类的取得记录器方法取得相应的记录器对象。
取得根记录器对象可通过Logger.getRootLogger()函数,要取得非根记录器可通过Logger.getLogger()函数
例子:
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.apache.log4j.Priority;
import TestLog4j.TestLog4j2.TestLog4j2;
public class TestLog4j {
static Logger logger = Logger.getLogger(TestLog4j.class.getName());
public TestLog4j(){}
public static void main(String[] args) {
//同时输出到控制台和一个文件的实例并实现了Logger的继承
PropertyConfigurator.configure("F:\\nepalon\\log4j2.properties");
logger.debug("Start of the main() in TestLog4j");
logger.info("Just testing a log message with priority set to INFO");
logger.warn("Just testing a log message with priority set to WARN");
logger.error("Just testing a log message with priority set to ERROR");
logger.fatal("Just testing a log message with priority set to FATAL");
logger.log(Priority.WARN, "Testing a log message use a alternate form");
logger.debug(TestLog4j.class.getName());
TestLog4j2 testLog4j2 = new TestLog4j2(); //(1)
testLog4j2.testLog();
}
}
在类TestLog4j中我们调用了另一个类TestLog4j2,下面看一下类TestLog4j2的代码。
例4-b:
package TestLog4j.TestLog4j2;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.apache.log4j.Priority;
public class TestLog4j2 {
static Logger logger = Logger.getLogger(TestLog4j2.class.getName()); //(1)
public TestLog4j2(){}
public void testLog() {
//同时输出到控制台和一个文件的实例
PropertyConfigurator.configure("F:\\nepalon\\log4j2.properties");
logger.debug("2Start of the main()");
logger.info("2Just testing a log message with priority set to INFO");
logger.warn("2Just testing a log message with priority set to WARN");
logger.error("2Just testing a log message with priority set to ERROR");
logger.fatal("2Just testing a log message with priority set to FATAL");
logger.log(Priority.DEBUG, "Testing a log message use a alternate form");
logger.debug("2End of the main()");
}
}
#1区
#### Use two appenders, one to log to console, another to log to a file
log4j.rootLogger = debug, stdout,R
#2区
#Print only messages of priority WARN or higher for your category
log4j.logger.TestLog4j= , R
log4j.logger.TestLog4j.TestLog4j2=WARN
#3区
#### First appender writes to console
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
#4区
#### Second appender writes to a file
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=F:\\nepalon\\classes\\TestLog4j\\example.log
# Control the maximum log file size
log4j.appender.R.MaxFileSize=100KB
# Archive log files (one backup file here)
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd hh:mm:ss}:%p %t %c - %m%n
运行结果:
在控制台中的结果为:
DEBUG [main] (?:?) - Start of the main() in TestLog4j
INFO [main] (?:?) - Just testing a log message with priority set to INFO
WARN [main] (?:?) - Just testing a log message with priority set to WARN
ERROR [main] (?:?) - Just testing a log message with priority set to ERROR
FATAL [main] (?:?) - Just testing a log message with priority set to FATAL
WARN [main] (?:?) - Testing a log message use a alternate form
DEBUG [main] (?:?) - TestLog4j.TestLog4j
WARN [main] (?:?) - 2Just testing a log message with priority set to WARN
ERROR [main] (?:?) - 2Just testing a log message with priority set to ERROR
FATAL [main] (?:?) - 2Just testing a log message with priority set to FATAL
输出文件的结果为:
2003-12-19 04:19:44:DEBUG main TestLog4j.TestLog4j - Start of the main() in TestLog4j
2003-12-19 04:19:44:INFO main TestLog4j.TestLog4j - Just testing a log message with priority set to INFO
2003-12-19 04:19:44:WARN main TestLog4j.TestLog4j - Just testing a log message with priority set to WARN
2003-12-19 04:19:44:ERROR main TestLog4j.TestLog4j - Just testing a log message with priority set to ERROR
2003-12-19 04:19:44:FATAL main TestLog4j.TestLog4j - Just testing a log message with priority set to FATAL
2003-12-19 04:19:44:WARN main TestLog4j.TestLog4j - Testing a log message use a alternate form
2003-12-19 04:19:44:DEBUG main TestLog4j.TestLog4j - TestLog4j.TestLog4j
2003-12-19 04:19:44:WARN main TestLog4j.TestLog4j2.TestLog4j2 - 2Just testing a log message with priority set to WARN
2003-12-19 04:19:44:ERROR main TestLog4j.TestLog4j2.TestLog4j2 - 2Just testing a log message with priority set to ERROR
2003-12-19 04:19:44:FATAL main TestLog4j.TestLog4j2.TestLog4j2 - 2Just testing a log message with priority set to FATAL
2) 2区中的内容是这一节的重点,也是应用到记录器层次的地方,但其实也只有两句,充分体现了log4j的简单性。在这里,我们定义了两个名称分别为TestLog4j和TestLog4j.TestLog4j2设计器。
? 在定义TestLog4j记录器时没有指定级别,所以它的级别继承自它的父记录器,即根记录器,所以它的级别也为DEBUG。在定义TestLog4j记录器时又定义了一个名称为R的输出端,所以它的输出端有两个,一个从根记录器继承而来的名为stdout的输出端,另一个为在此定义的名为R的输出端。在此需要注意的是,在定义记录器时必须先定义记录器的级别,然后才是记录器的输出端。如果只想定义输出端而不定义级别,则虽然级别可以为空,但逗号分隔符不能省略。如定义TestLog4j记录器的做法。
? 在定义TestLog4j.TestLog4j2记录器时又指定了它的级别,由于一个记录器的级别只能有一个,所以新指定的级别将覆写掉它的父记录器的级别(这就象Java中的多态)。我们没有定义TestLog4j.TestLog4j2记录器的输出端,所以它的输出端将从它的父记录器中继承而来。它的父记录器为estLog4j记录器,所以它和estLog4j记录器一样具有两个名称分别为 stdout和R的输出端。
3) 剩下的3区和4区分别设置了两个输出端的参数值。
接下来,回到我们的代码,看一下是如何取得记录器,在取记录器时又发生了什么。
1) 例4-a中的代码(2)中,语句Logger.getLogger()中的参数TestLog4j.class.getName()的值为 TestLog4j. TestLog4j,所以此语句的结果是取得一个名为TestLog4j. TestLog4j的记录器的对象。但在配置文件中并没有定义这样的记录器,所以最终将返回与所需的名称TestLog4j. TestLog4j最接近的记录器对象,即名为TestLog4j的记录器的对象。
2) 例4-b中的代码(1)的原理与例4-a中的代码(2)相似,期望取得的是名为TestLog4j.TestLog4j2. TestLog4j2的记录器对象,但最终返回的是TestLog4j.TestLog4j2记录器的对象
Log4j的web应用:
Web application与在application中应用log4j不同之处就是要在所有应用log4j的代码之前对log4j进行初始化。所以,我们在web application中就要把log4j的初始化工作独立出来,把它放在Servlet中
例子:
第一步:定义Servlet类进行初始化Log4j配置文件
import org.apache.log4j.PropertyConfigurator;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* log4j.jar的初始化类,参考web.xml
*/
public class Log4jInit extends HttpServlet{
public void init(){
//通过web.xml来动态取得配置文件
String prefix = getServletContext().getRealPath("/");
String file = getInitParameter("log4j-init-file");
// 如果没有给出相应的配置文件,则不进行初始化
if(file != null){
PropertyConfigurator.configure(prefix+file); //(1)
}
}
public void doGet(HttpServletRequest req, HttpServletResponse res){}
}
第二步:web.xml中配置servlet类
<servlet>
<servlet-name>log4j-init</servlet-name>
<servlet-class>TestLog4j.Log4jInit</servlet-class>
<init-param>
<param-name>log4j-init-file</param-name>
<param-value>sort.properties</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
因为log4j的初始化要在所有的log4j调用之前完成,所以在web.xml文件中,我们一定要把对应的Servlet定义的load-on-startup应设为1,以便在Web容器启动时即装入该Servlet。
第三步:可以像以上的application应用中操作的那样运用Log4j
import org.apache.log4j.Logger;
public class InfoForm{
static Logger logger = Logger.getLogger(InfoForm.class);
protected String title;
protected String content;
public InfoForm() {}
public void setTitle(Object value){
logger.debug("nepalon:title = " + title);
title = value;
}
public String getTitle(){
logger.debug("nepalon:title = " + title);
return title;
}
public void setContent(String value){
content = value;
logger.debug("nepalon: content() = " + content);
}
public String getContent(){
logger.debug("nepalon: content = \n" + content);
return content;
}
}
相关推荐
至于WSAD(WebSphere Application Developer)5.1配置log4j的步骤,可以通过编辑服务器的类加载器配置,将log4j的相关JAR文件添加到服务器的类路径,并确保`log4j.properties`文件在正确的位置。`WSAD5.1配置log4j....
另外,Log4j可以方便地集成到J2EE、JINI和SNMP应用中,提供更广泛的日志管理解决方案。 总的来说,Log4j是一个强大且灵活的日志框架,通过配置文件可以轻松定制日志行为,适应不同项目的需求,对于任何Java开发者来...
在现代Java Web应用开发中,Spring Boot以其便捷的起步配置和强大的依赖管理赢得了广大开发者喜爱。而Mybatis作为轻量级的持久层框架,搭配Spring Boot可以实现灵活且高效的数据库操作。本文将深入探讨如何在...
整合Log4j2到Spring Boot项目中,能够使开发者更好地跟踪和分析应用程序的行为,从而进行问题排查和性能优化。 **集成步骤** 1. **添加依赖**: 在`pom.xml`文件中,我们需要引入Spring Boot的Starter Web依赖以及...
这是一个基于Java技术栈的Web应用示例项目,主要采用了Spring、SpringMVC、MyBatis、Log4j和SpringTest等组件。以下是这些技术及其在项目中的应用详解: 1. **Spring**:Spring是一个全面的Java企业级应用开发框架...
这样,Tomcat在启动时会自动加载这些库,使得log4j可以为所有部署在Tomcat上的Web应用提供日志服务。 接下来,我们将深入讨论如何配置log4j。在log4j的配置中,最重要的文件是`log4j.properties`或`log4j.xml`,它...
1. **配置文件**:通常会在Web应用程序中放置一个`log4j.properties`文件,用于配置Logger、Appender和Layout。 2. **部署**:将配置文件放在Web应用程序的`WEB-INF/classes`目录下,这样Log4j就可以自动读取并应用...
log4net的配置通常在应用程序的配置文件(如web.config)中进行。添加以下配置段来设置日志输出的目标和格式: ```xml <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log...
例如,在ASP.NET Web应用中,可以在Global.asax.cs的Application_Start方法中初始化log4net,然后在代码中使用`log4net.ILog`接口记录日志。 ```csharp using log4net; private static readonly ILog log = ...
常用的日志框架包括 Java.Util.Logging、Log4j、Logback 和 Log4j2。其中,Log4j2 是 Log4j 的一个升级版本,具有更好的性能和可配置性。 SLF4J SLF4J(Simple Logging Facade for Java)是一个抽象层,它允许...
6. **日志**:Spring Boot 默认集成了 Logback 或 Log4j2 作为日志系统,提供了方便的日志级别控制和输出格式。 7. **运行独立的应用**:Spring Boot 生成的应用程序可以直接运行,无需额外的服务器部署步骤,这...
它最初是基于Java的log4j项目,由Apache软件基金会开发,后来被移植到.NET平台上。在.NET世界里,log4net因其强大的功能和易用性而备受推崇。 ### log4net配置 配置log4net是使用它的关键步骤。log4net的配置可以...
log4net的设计理念与它的Java版本log4j类似,都是为了实现可配置、高性能的日志记录,使得开发者能够在各种环境中方便地管理和调试应用日志。 在.NET环境中,使用log4net主要涉及以下几个步骤: 1. **引入log4net...
Log4Net能够帮助开发者在.NET应用程序中方便地进行日志记录操作。其主要特性包括:强大的可配置性、高灵活性以及广泛的应用场景等。 #### 二、Log4Net的基本组件 Log4Net主要由以下几部分组成: 1. **Logger**:...
SpringBoot、Maven、MyBatis与Log4j是Java开发...对于初学者来说,这个项目提供了一个快速上手SpringBoot的平台,通过实际操作可以深入理解SpringBoot、Maven、MyBatis和Log4j的集成使用,有助于提升Java Web开发能力。
在构建现代化的Java Web应用程序时,使用Spring Boot、Maven、MyBatis和Log4j2等技术可以极大地提升开发效率和应用性能。本篇文章将详细介绍如何利用这些工具搭建一个框架,并实现对多个数据库的集成。 首先,让...
在本项目中,我们主要探讨的是如何在Spring Boot 2框架下实现多数据源配置,同时结合MyBatis、MySQL数据库、Log4j2日志系统以及Swagger2 API文档工具进行应用开发。以下是对这些技术栈的详细说明: **Spring Boot 2...
Spring Boot允许我们在应用的属性文件`application.properties`或`application.yml`中设置Log4j2的相关属性。例如: ```properties logging.level.root=info logging.file.name=logs/app.log ``` 或者使用YAML格式...
7. **日志系统**:SpringBoot 默认使用 Logback 或者 Log4j2 作为日志系统,可以通过 `logging.config` 属性指定日志配置文件的位置。 8. **应用打包**:SpringBoot 应用可以被打包为可执行的 JAR 或 WAR 文件,...
在.NET开发环境中,日志记录是一项非常重要的任务,它能够帮助开发者追踪程序运行时的问题,进行...熟练掌握log4net的配置和使用,能够帮助你更好地管理和分析应用程序的运行情况,从而提升开发效率和问题排查能力。