`
2277259257
  • 浏览: 515415 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Log4j-----application应用和web应用的操作

 
阅读更多

Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以

控制日志信息输送的目的地控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;

控制每一条日志的输出格式

通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程

最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

 

通过Log4j其他语言接口,您可以在CC++.NetPL/SQL程序中使用Log4j,其语法和用法与在Java程序中一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通过使用各种第三方扩展,您可以很方便地将Log4j集成到J2EEJINI甚至是SNMP应用中。

 

Log4j应用:

第一步

加入log4j-1.2.8.jar(可以选择log4j的更高版本)到lib下。

第二步

在CLASSPATH下建立log4j.properties内容如下(数字为行号):
1 log4j.rootCategory=INFO, stdout , R
2
3 log4j.appender.stdout=org.apache.log4j.ConsoleAppender
4 log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
5 log4j.appender.stdout.layout.ConversionPattern=[QC] %p [%t] %C.%M(%L) | %m%n
6
7 log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
8 log4j.appender.R.File=D:\\Tomcat 5.5\\logs\\qc.log
9 log4j.appender.R.layout=org.apache.log4j.PatternLayout
10 log4j.appender.R.layout.ConversionPattern=%d-[TS] %p %t %c - %m%n
11
12 log4j.logger.com.neusoft=DEBUG
13 log4j.logger.com.opensymphony.oscache=ERROR
14 log4j.logger.net.sf.navigator=ERROR
15 log4j.logger.org.apache.commons=ERROR
16 log4j.logger.org.apache.struts=WARN
17 log4j.logger.org.displaytag=ERROR
18 log4j.logger.org.springframework=DEBUG
19 log4j.logger.com.ibatis.db=WARN
20 log4j.logger.org.apache.velocity=FATAL
21
22 log4j.logger.com.canoo.webtest=WARN
23
24 log4j.logger.org.hibernate.ps.PreparedStatementCache=WARN
25 log4j.logger.org.hibernate=DEBUG
26 log4j.logger.org.logicalcobwebs=WARN

第三步

在要输出日志的类中加入相关语句:
1、导入所有需的commons-logging类:
     import org.apache.commons.logging.Log;
     import org.apache.commons.logging.LogFactory;
2、在自己的类中定义一个org.apache.commons.logging.Log类的私有静态类成员:
定义属性:static Logger logger = Logger.getLogger(LogDemo.class); //LogDemo为相关的类
                 或 private final Log log = LogFactory.getLog(getClass());
3、使用org.apache.commons.logging.Log类的成员方法输出日志信息:
     if (logger.isDebugEnabled()){  logger.debug(“111.”);}
     if (log.isInfoEnabled()){log.info("222");}
     if (log.isWarnEnabled()){log.warn("333");}
     if (log.isErrorEnabled()){log.error("444");}

     if (log.isFatalEnabled()){log.fatal("555");}

 第二步详解:

Log4j支持两种配置文件格式,一种是XML标准通用标记语言下的一个应用)格式的文件,一种是Java特性文件log4j.properties(键=值)。下面将介绍使用log4j.properties文件作为配置文件的方法:

 

①、配置根Logger
Logger 负责处理日志记录的大部分操作。
其语法为:log4j.rootLogger = [ level ] , appenderName, appenderName, …
其中,level 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者自定义的级别。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。比如在这里定义了INFO级别,只有等于及高于这个级别的才进行处理,则应用程序中所有DEBUG级别的日志信息将不被打印出来。ALL:打印所有的日志,OFF:关闭所有的日志输出。 appenderName就是指定日志信息输出到哪个地方。可同时指定多个输出目的地。
②、配置日志信息输出目的地 Appender
Appender 负责控制日志记录操作的输出。
其语法为:
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
log4j.appender.appenderName.optionN = valueN
这里的appenderName为在①里定义的,可任意起名。
其中,Log4j提供的appender有以下几种
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),可通过log4j.appender.R.MaxFileSize=100KB设置文件大小,还可通过log4j.appender.R.MaxBackupIndex=1设置为保存一个备份文件
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方
例如:log4j.appender.stdout=org.apache.log4j.ConsoleAppender
定义一个名为stdout的输出目的地,ConsoleAppender为控制台。

 

③、配置日志信息的格式(布局)Layout
Layout 负责格式化Appender的输出。
其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
log4j.appender.appenderName.layout.optionN = valueN
其中,Log4j提供的layout有以下几种
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息

格式化日志信息

Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:
%m 输出代码中指定的消息
%M 输出打印该条日志的方法名
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL;
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为"rn”,Unix平台为"n”;
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss,SSS},输出类似:2002-10-18 22:10:28,921;
%l 输出日志事件的发生位置,及在代码中的行数

 

 定义及获取不同层次的记录器:

1) 在配置文件中定义相应的记录器。

  定义根记录器的格式:log4j.rootLogger = [ level ], appendName1, appendName2, …appendNameN

  定义一个非根记录器的格式:log4j.logger.loggerName1 = [ level ], appendName1,…appendNameN

  可以定义任意个非根记录器

2) 在代码中调用Logger类的取得记录器方法取得相应的记录器对象

  取得根记录器对象可通过Logger.getRootLogger()函数,要取得非根记录器可通过Logger.getLogger()函数

 

例子:

package TestLog4j;
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()");
}
}
配置文件log4j2.properties:
#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
1) 在1区中定义了一个根记录器。这个根记录器具有DEBUG级别并有一个名称为stdout的输出端appender。
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;
}
}

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    WebSphere V5 配置log4j

    至于WSAD(WebSphere Application Developer)5.1配置log4j的步骤,可以通过编辑服务器的类加载器配置,将log4j的相关JAR文件添加到服务器的类路径,并确保`log4j.properties`文件在正确的位置。`WSAD5.1配置log4j....

    log4j使用

    另外,Log4j可以方便地集成到J2EE、JINI和SNMP应用中,提供更广泛的日志管理解决方案。 总的来说,Log4j是一个强大且灵活的日志框架,通过配置文件可以轻松定制日志行为,适应不同项目的需求,对于任何Java开发者来...

    SpringBoot2.X整合Mybatis代码示例2-使用配置文件方式+Log4j

    在现代Java Web应用开发中,Spring Boot以其便捷的起步配置和强大的依赖管理赢得了广大开发者喜爱。而Mybatis作为轻量级的持久层框架,搭配Spring Boot可以实现灵活且高效的数据库操作。本文将深入探讨如何在...

    SpringBoot整合log4j223

    整合Log4j2到Spring Boot项目中,能够使开发者更好地跟踪和分析应用程序的行为,从而进行问题排查和性能优化。 **集成步骤** 1. **添加依赖**: 在`pom.xml`文件中,我们需要引入Spring Boot的Starter Web依赖以及...

    spring+springmvc+mybatis+log4j+springtest的demo

    这是一个基于Java技术栈的Web应用示例项目,主要采用了Spring、SpringMVC、MyBatis、Log4j和SpringTest等组件。以下是这些技术及其在项目中的应用详解: 1. **Spring**:Spring是一个全面的Java企业级应用开发框架...

    Tomcat5.5日志管理log4j包文件

    这样,Tomcat在启动时会自动加载这些库,使得log4j可以为所有部署在Tomcat上的Web应用提供日志服务。 接下来,我们将深入讨论如何配置log4j。在log4j的配置中,最重要的文件是`log4j.properties`或`log4j.xml`,它...

    log4j使用教程

    1. **配置文件**:通常会在Web应用程序中放置一个`log4j.properties`文件,用于配置Logger、Appender和Layout。 2. **部署**:将配置文件放在Web应用程序的`WEB-INF/classes`目录下,这样Log4j就可以自动读取并应用...

    log4net网站项目应用实例

    log4net的配置通常在应用程序的配置文件(如web.config)中进行。添加以下配置段来设置日志输出的目标和格式: ```xml &lt;section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log...

    log4net。log4net

    例如,在ASP.NET Web应用中,可以在Global.asax.cs的Application_Start方法中初始化log4net,然后在代码中使用`log4net.ILog`接口记录日志。 ```csharp using log4net; private static readonly ILog log = ...

    Springboot整合log4j2日志全解总结

    常用的日志框架包括 Java.Util.Logging、Log4j、Logback 和 Log4j2。其中,Log4j2 是 Log4j 的一个升级版本,具有更好的性能和可配置性。 SLF4J SLF4J(Simple Logging Facade for Java)是一个抽象层,它允许...

    springboot-web-dome

    6. **日志**:Spring Boot 默认集成了 Logback 或 Log4j2 作为日志系统,提供了方便的日志级别控制和输出格式。 7. **运行独立的应用**:Spring Boot 生成的应用程序可以直接运行,无需额外的服务器部署步骤,这...

    log4net demo

    它最初是基于Java的log4j项目,由Apache软件基金会开发,后来被移植到.NET平台上。在.NET世界里,log4net因其强大的功能和易用性而备受推崇。 ### log4net配置 配置log4net是使用它的关键步骤。log4net的配置可以...

    log4net 配置与应用

    log4net的设计理念与它的Java版本log4j类似,都是为了实现可配置、高性能的日志记录,使得开发者能够在各种环境中方便地管理和调试应用日志。 在.NET环境中,使用log4net主要涉及以下几个步骤: 1. **引入log4net...

    Log4Net配置步骤

    Log4Net能够帮助开发者在.NET应用程序中方便地进行日志记录操作。其主要特性包括:强大的可配置性、高灵活性以及广泛的应用场景等。 #### 二、Log4Net的基本组件 Log4Net主要由以下几部分组成: 1. **Logger**:...

    springboot+mvn+mybaits + log4j

    SpringBoot、Maven、MyBatis与Log4j是Java开发...对于初学者来说,这个项目提供了一个快速上手SpringBoot的平台,通过实际操作可以深入理解SpringBoot、Maven、MyBatis和Log4j的集成使用,有助于提升Java Web开发能力。

    springboot+maven+mybatis+log4j2+idea的框架搭建与多数据库的集成

    在构建现代化的Java Web应用程序时,使用Spring Boot、Maven、MyBatis和Log4j2等技术可以极大地提升开发效率和应用性能。本篇文章将详细介绍如何利用这些工具搭建一个框架,并实现对多个数据库的集成。 首先,让...

    springboot2 多数据源配置 mybatis log4j2 完整示例

    在本项目中,我们主要探讨的是如何在Spring Boot 2框架下实现多数据源配置,同时结合MyBatis、MySQL数据库、Log4j2日志系统以及Swagger2 API文档工具进行应用开发。以下是对这些技术栈的详细说明: **Spring Boot 2...

    spring-boot-log4j2-example

    Spring Boot允许我们在应用的属性文件`application.properties`或`application.yml`中设置Log4j2的相关属性。例如: ```properties logging.level.root=info logging.file.name=logs/app.log ``` 或者使用YAML格式...

    springboot-web-demo

    7. **日志系统**:SpringBoot 默认使用 Logback 或者 Log4j2 作为日志系统,可以通过 `logging.config` 属性指定日志配置文件的位置。 8. **应用打包**:SpringBoot 应用可以被打包为可执行的 JAR 或 WAR 文件,...

    C#使用log4net记录日志

    在.NET开发环境中,日志记录是一项非常重要的任务,它能够帮助开发者追踪程序运行时的问题,进行...熟练掌握log4net的配置和使用,能够帮助你更好地管理和分析应用程序的运行情况,从而提升开发效率和问题排查能力。

Global site tag (gtag.js) - Google Analytics