`
tyvincent
  • 浏览: 7591 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

Log4j日志的使用及配置文件

阅读更多

其实日志的使用很简单,1.导入log4j包,2.定义配置文件,3.使用。使用的大致步骤:定义日志对象→读取配置文件→输出到日志。that all .

一、log4j的三个组成部分

    Log4j由三个重要的组件构成:日志信息的优先级 priority,日志信息的输出目的地Appender,日志信息的输出格式(布局)layout。

 1、日志的优先级

 从低到高,依次有:DEBUG,INFO,WARN,ERROR,分别用来指定这条日志信息的重要程度;如果定义了了输入的级别为INFO,则只有等于及高于这个级别的才进行处理,此时将输入INFO,WARN,ERROR。值得注意的是,级别中还有两个关键字,

 ALL:打印所有的日志,

 OFF:关闭所有的日志输出。

 

 2、输出端 Appender

 log4j提供了以下几种常用的输出目的地:

 org.apache.log4j.ConsoleAppender,将日志信息输出到控制台

 org.apache.log4j.FileAppender,将日志信息输出到一个文件

 org.apache.log4j.DailyRollingFileAppender,将日志信息输出到一个,并且每天输出到一个新的日志文件,

按照不同的配置可以定义每月一个日志文件,或者每周,每天,每小时,每分钟等输出一个新的日志文件。

 org.apache.log4j.RollingFileAppender,将日志信息输出到一个文件,通过指定文件的的尺寸,当文件大小

到达指定尺寸的时候会自动把文件改名,如名为example.log的文件会改名为example.log.1,同时产生一个新的

example.log文件。如果新的文件再次达到指定尺寸,又会自动把文件改名为example.log.2,同时产生一个example.log

文件。依此类推,直到example.log. MaxBackupIndex,MaxBackupIndex的值可在配置文件中定义。

 org.apache.log4j.WriterAppender,将日志信息以流格式发送到任意指定的地方。

 org.apache.log4j.jdbc.JDBCAppender,通过JDBC把日志信息输出到数据库中。

 org.apache.log4j.net.SMTPAppender,将日志信息以邮件的方式发送到指定的邮箱。

 

3、输出格式(布局)layout

 通过appender可以控制输出的目的地,而如果要控制输出的格式,就可通过log4j的layout组件来实现。通过配

置文件定义一个appender的输出格式,Log4j提供的布局模式有以下几种:

 org.apache.log4j.ConsoleAppender,输出到控制台

 org.apache.log4j.HTMLLayout,以HTML表格形式布局

 org.apache.log4j.PatternLayout,可以灵活地指定布局模式

 org.apache.log4j.SimpleLayout,包含日志信息的级别和信息字符串

 值得一提的是org.apache.log4j.PatternLayout 以Pattern方式的布局,使用Pattern的方式来指定布局。

pattern 的参数如下:ConversionPattern参数的格式含义

 格式名 含义

 %c 输出日志信息所属的类的全名

 %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd

HH:mm:ss },输出类似:2002-10-18- 22:10:28 ;比如 %d{HH:mm:ss,SSS} 或 %d{dd MMM yyyy HH:mm:ss,SSS}.

格式可以参考 java类 SimpleDateFormat,不过 按照此类的设置会影响速度。你可以选择更快的方式 %d{ISO8601},

%d{ABSOLUTE}, %d{RELATIVE}.或者使用log4j的ISO8601DateFormat, AbsoluteTimeDateFormat,

RelativeTimeDateFormat 和 DateTimeDateFormat 方式.

 %f 输出日志信息所属的类的类名

 %l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行

 %m 输出代码中指定的信息,如log(message)中的message

 %M 输出日志信息中所发生的方法名。

 %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”

 %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推

 %r 输出自应用启动到输出该日志信息所耗费的毫秒数

 %t 输出产生该日志事件的线程名

 

 

二、配置文件

log4j支持两种方式的配置方式,.properties 二进制文件和xml文件的方式。

1 .以.properties文件的格式定义两种输出方式,一种是输出到文件中,另一种是输出到数据库中。

 

 首先定义test.properties文件,文件定义如下:

 

 #定义了两个输出端

 log4j.rootLogger = INFO,f,db

 # 定义f输出到文件,并且文件是随着大小而增加的

 log4j.appender.f = org.apache.log4j.RollingFileAppender 

 log4j.appender.f.File = F:\\nepalon\\classes\\test.log 

 log4j.appender.f.MaxFileSize = 512KB 

 log4j.appender.f.MaxBackupIndex = 3 

 log4j.appender.f.layout = org.apache.log4j.PatternLayout

 

 log4j.appender.f.layout.ConversionPattern = %d{yyyy-MM-dd hh:mm:ss}:%p %t %c - %m%n

 #定义db输出到数据库

 log4j.appender.db = org.apache.log4j.jdbc.JDBCAppender

 log4j.appender.db.BufferSize = 40

 log4j.appender.db.Driver = com.microsoft.jdbc.sqlserver.SQLServerDriver

 log4j.appender.db.URL = jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=test

 log4j.appender.db.User = sa

 log4j.appender.db.Password =

 log4j.appender.db.layout = org.apache.log4j.PatternLayout

 log4j.appender.db.layout.ConversionPattern = INSERT INTO log4j (createDate, thread, priority,

category, message) values('%d{ISO8601}', '%t', '%-5p', '%c', '%m')

 然后程序中将引用这配置文件。定义如下:

 import org.apache.log4j.Logger;

import org.apache.log4j.PropertyConfigurator;

 public class Test {

 

     static Logger logger = Logger.getLogger(Test.class.getName());//定义日志对象

     public static void main(String args[]) {

           

         PropertyConfigurator.configure ( "test.properties" ) ; //以property方式读到配置文件。

         

         logger.debug("DEBUG");//输出日志信息到日志

         logger.info("INFO");

         logger.warn("WARN");

         logger.error(" ERROR");

         logger.fatal(" FATAL");

     }

 }

2 .以xml配置

 程序如下:

 import org.apache.log4j.Logger;

 import org.apache.log4j.xml.DOMConfigurator;

 public class Test {

 

     static Logger logger = Logger.getLogger(Test.class.getName());//定义日志对象

     public static void main(String args[]) {

            

         DOMConfigurator.configure("log4jconfig.xml");//以XML方式读到配置文件。

 

         logger.debug(" DEBUG");//输出日志信息到日志

         logger.info(" INFO");

         logger.warn(" WARN");

         logger.error(" ERROR");

         logger.fatal(" FATAL");

     }

 }

log4jconfig.xml 如下:

 <?xml version="1.0" encoding="UTF-8" ?>

 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

 <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

       

   <appender name="appender" class="org.apache.log4j.FileAppender">

      <param name="File" value="Log.txt"/>

      <param name="Append" value="false"/>

      <layout class="org.apache.log4j.PatternLayout">

         <param name="ConversionPattern" value="%d [%t] %p - %m%n"/>

      </layout>

   </appender>

   <root>

      <priority value ="debug"/>

      <appender-ref ref="appender"/>

   </root>

 </log4j:configuration>

 对比properties方式和xml方式,可以看出他们程序中,除了定义读取配置文件的方式不同外,其它的根本就没

有区别了,这也就是log4j的魅力所在了,不需要改变程序,只需要通过改变定义的配置文件,我们就可以控制日志的输出方式,是否输出,输出格式。我们可以通过定义不同的xml文件来控制输出方式.

 

三、应用中的使用步骤

 

1.在工程中导入log4j-1.2.14.jar包

2.在src包下面新建log4j的配置文件,.properties或者.xml文件。

3.使用步骤

 

     3.1.在应用程序中的使用方法:

    a.获取Logger实例:static Logger logger = Logger.getLogger(TestLog4j.class);

    b.读取配置文件:

        PropertyConfigurator.configure ( "test.properties" ) ; //以property方式读到配置文件。

        DOMConfigurator.configure("log4jconfig.xml");//以XML方式读到配置文件。

    c.写日至:

         logger.debug(" DEBUG");//输出日志信息到日志

         logger.info(" INFO");

         logger.warn(" WARN");

         logger.error(" ERROR");

         logger.fatal(" FATAL");

 

 

3.2.在web应用中的使用方法

 

    应该在哪儿对Log4J进行配置呢?首先要明确,Log4J必须在应用的其它代码执行前完成初始化。因为Servlet是在Web服务器启动时立即装入的,所以,在Web应用中一般使用一个专门的Servlet来完成Log4J的配置,并保证在web.xml的配置中,这个Servlet位于其它Servlet之前。下面是一个例子,代码如下:

A、初始化配置的servlet

package com.foo;

 

import org.apache.log4j.PropertyConfigurator;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.PrintWriter;

import java.io.IOException;

 

public class Log4jInit extends HttpServlet {

  public void init() {

    String prefix =  getServletContext().getRealPath("/");

    String file = getInitParameter("log4j-init-file");

    // if the log4j-init-file is not set, then no point in trying

    if(file != null) {

      PropertyConfigurator.configure(prefix+file);

    }

  }

 

  public void doGet(HttpServletRequest req, HttpServletResponse res) {

  }

}

 

B、在你的web应用程序的web.xml文件中定义下面servlet

<servlet>

    <servlet-name>log4j-init</servlet-name>

    <servlet-class>com.foo.Log4jInit</servlet-class>

    <init-param>

      <param-name>log4j-init-file</param-name>

      <param-value>WEB-INF/classes/log4j.properties</param-value>

    </init-param>

    <load-on-startup>1</load-on-startup>

  </servlet>

 

C、在需要使用log4j的地方获取Logger实例

    static Logger log = Logger.getLogger(TestLog4j.class);

 

D、写日至:

         logger.debug(" DEBUG");//输出日志信息到日志

         logger.info(" INFO");

         logger.warn(" WARN");

         logger.error(" ERROR");

         logger.fatal(" FATAL");

 

分享到:
评论

相关推荐

    log4j日志配置以及配置文件详解

    这是log4j框架的配置文件,使用Java Properties格式,用于定义日志输出的行为。主要包括以下几个核心部分: 1. **Logger**: 定义日志级别,例如DEBUG、INFO、WARN、ERROR和FATAL。日志级别决定了哪些信息会被记录。...

    SSM整合中的Log4j日志的配置详情

    在 SSM 整合项目中,需要在 web.xml 文件中指定 Log4j 配置文件的位置,以便 Spring 可以加载 Log4j 配置文件。下面是一个基本的 web.xml 配置: ``` &lt;listener-class&gt;org.springframework.web.util.Log4...

    tomcat下的log4j日志配置

    ### Tomcat 下的 Log4j 日志配置详解 在日常的 Web 开发中,日志记录对于调试问题、监控系统状态以及后期维护来说至关重要。在使用 Apache Tomcat 作为服务器时,合理配置日志框架(如 Log4j)能够极大地提高开发...

    logstash 采集log4j日志配置文件

    logstash采集log4j日志发送到es配置文件,可以把日志根据日志级别区分开,一个级别一条日志是es中的一条数据

    tomcat6.0 配log4j日志的必须文件及配置过程

    tomcat6.0 配log4j日志的必须文件及配置过程 tomcat6-------lib | |--------tomcat-juli-adapters.jar | |--------log4j.jar | |--------log4j.properites | |----bin |--------tomcat-juli.jar 最后把log4...

    log4j.properties配置文件

    ### log4j.properties配置文件详解 #### 一、概述 `log4j.properties`是Apache Log4j框架中用于配置日志记录行为的核心文件之一。通过这个文件,开发者可以定义日志消息的输出方式(例如控制台或文件)、日志级别...

    Log4j日志配置说明,Log4j日志配置说明

    ### Log4j日志配置详解 #### 一、概述 Log4j 是一个基于 Java 的开源日志记录框架,由 Apache 软件基金会维护。它允许开发人员根据等级记录日志信息,使得用户能够控制日志信息的记录级别及去向。本文将通过一份...

    log4j使用手册和配置文件示例

    总结来说,这个压缩包提供了log4j的使用教程、配置示例、API文档、Java代码示例以及配置文件的解释,是一个全面学习和使用log4j的资源集合。通过深入研究这些文件,开发者可以掌握如何在自己的Java应用中有效地利用...

    log4j使用jar包和log4j.properties配置文件

    本文将详细探讨Log4j的使用,主要关注1.2.17版本的jar包以及配置文件`log4j.properties`。 ### 1. Log4j简介 Log4j是一个开源的日志组件,支持多种输出格式,如控制台、文件、数据库等。它的核心概念包括Logger、...

    log4j及配置文件

    本文将详细探讨Log4j的基本概念、配置文件的使用以及如何通过配置文件定制日志输出。 一、Log4j概述 Log4j是一个灵活且功能强大的日志记录工具,它允许程序员以可控制的方式记录应用程序的运行信息。Log4j的核心...

    log4j中配置日志文件相对路径方法(PDF)

    除了使用`log4j.properties`文件外,还可以通过XML文件来配置日志文件的路径。与`properties`文件类似,XML文件也支持变量的使用。 ##### 示例配置 ```xml &lt;appender name="logfile" class="org.apache.log4j....

    log4j自定义日志文件名及日志输出格式

    配置文件(log4j.properties)中,你需要将这个自定义的Appender和Layout加入: ```properties log4j.appender.customAppender=your.package.CustomLogAppender log4j.appender.customAppender.layout=your.package...

    log4j使用手册和配置文件实例

    Log4j支持动态改变日志配置,比如在运行时调整日志级别,这在系统维护和调试时非常有用。可以使用`PropertyConfigurator`或`DOMConfigurator`类来重新加载配置。 **5. 日志性能优化** - 使用合适的日志级别:避免...

    log4j.jar包,和log4j.properties配置文件下载

    Log4j是一个广泛使用的Java日志记录框架,它允许开发者在应用程序中插入日志语句,以便跟踪程序的运行情况、调试错误、监控性能等。这个框架由Apache软件基金会开发,是许多Java项目的首选日志解决方案,因为它具有...

    log4j2配置文件,按照文件大小划分日志,保存日期天数内的日志等

    log4j2配置文件,按照文件大小划分日志,保存日期天数内的日志,指纹日志命名规则,日志输出等级等功能

    Log4J_全能配置文件.pdf

    本文将详细介绍一个Log4J的全能配置文件,包括如何配置日志级别、日志输出目的地以及格式化日志输出等。 #### 二、配置文件结构解析 ##### 2.1 日志根类别设置 ```properties log4j.rootLogger=DEBUG,CONSOLE,A1,...

    log4j日志文件的JAR包及配置文件

    log4j日志文件的JAR包及配置文件。 使用log4j日志文件的步骤: Step1:添加日志文件所需要的JAR包; Step2:添加日志的配置文件; Step3:创建日志对象,使用日志对象的方法记录日志。

    log4j2的日志xml配置文件

    log4j2的配置文件

    log4j 写多个日志文件,按照日期每天都记

    `log4j`是一个广泛使用的Java日志框架,它提供了灵活的日志配置,能够帮助开发者记录程序运行过程中的各种信息。本文将深入探讨如何利用`log4j`实现按照日期每天写入不同日志文件的功能,以及涉及到的相关知识点。 ...

    log4j使用与java中log4j记录日志如何写入数据库

    1. **配置文件**:Log4j的配置文件通常是`log4j.properties`或`log4j.xml`,它定义了日志的级别(如DEBUG、INFO、WARN、ERROR、FATAL)、输出目的地(控制台、文件、数据库等)以及布局格式。 2. **日志类**:在...

Global site tag (gtag.js) - Google Analytics