`

log4j的日志

阅读更多

在日常的开发中经常需要通过输出一些信息进行程序的调试,如果到处都用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

 

分享到:
评论

相关推荐

    tomcat下的log4j日志配置

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

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

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

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

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

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

    四、在 Maven 项目中引入 Log4j 依赖 在 Maven 项目中,需要引入 Log4j 依赖项,以便使用 Log4j。下面是一个基本的 Maven 依赖项配置: ``` &lt;groupId&gt;log4j &lt;artifactId&gt;log4j &lt;version&gt;1.2.16 ``` 这个配置...

    log4j 日志打印

    《深入理解Log4j日志打印》 在Java开发领域,日志打印是不可或缺的一环,它对于系统调试、性能监控、故障排查等都起着至关重要的作用。Log4j作为Java中最常用的日志框架之一,深受广大开发者喜爱。本文将深入探讨...

    log4J日志.zip

    在“log4j日志.zip”压缩包中,包含的可能是Log4j的配置文件(如log4j.properties或log4j.xml)。这个文件定义了日志的级别、输出位置和格式。例如: ```properties # log4j.properties 示例 log4j.rootLogger=...

    log4j日志jar包

    《深入理解Log4j日志框架》 在Java开发领域,日志系统是不可或缺的工具,它用于记录程序运行过程中的各种信息,帮助开发者在问题出现时定位和解决问题。Log4j作为Apache软件基金会的一个开源项目,是Java世界中最...

    log4j日志报错解决办法

    Log4j 是一款广泛使用的Java日志记录框架,它提供了灵活的日志配置和丰富的日志级别,便于开发者调试和监控应用程序。在Java开发过程中,如果遇到"log4j:WARN Please initialize the log4j system properly"这样的...

    logstash 采集log4j日志配置文件

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

    log4j日志文件乱码解决方法

    本文将详细讨论如何解决Log4j日志文件出现的乱码问题。 首先,我们要理解Log4j的工作原理。Log4j允许开发者自定义日志输出的方式,包括输出到控制台、文件、数据库等。它使用了`QuietWriter`类来写入日志,`...

    log4j日志管理

    ### Log4j日志管理详解 #### 一、Log4j概述 Log4j是一款流行的开源日志框架,由Apache软件基金会提供。它允许开发者在应用程序中加入日志功能,以便于跟踪程序运行过程中的各种状态信息。Log4j的核心设计理念在于...

    无法打出log4j日志的问题排查

    当我们遇到“无法打出log4j日志的问题”,这通常是由于配置、环境或代码实现中的某些错误导致的。这篇长文将深入探讨如何排查和解决这类问题。 首先,我们要理解Log4j的基本工作原理。Log4j通过配置文件(通常是log...

    log4j日志包日志包

    通过`log4j.properties`或`log4j.xml`配置文件,可以定制日志输出的级别、目的地和格式,从而满足不同项目的需求。在实际开发中,正确地使用和配置`log4j`能显著提升问题排查和系统监控的效率。

    Flume-ng在windows环境搭建并测试+log4j日志通过Flume输出到HDFS.docx

    Flume-ng 在 Windows 环境搭建并测试 + Log4j 日志通过 Flume 输出到 HDFS Flume-ng 是一个高可用、可靠、分布式的日志聚合系统,可以实时地从各种数据源(如日志文件、网络 socket、数据库等)中收集数据,并将其...

    [SSH+Maven+Bootstrap视频教程]_18. 测试 log4j 日志框架.zip

    【SSH+Maven+Bootstrap视频教程】第18章主要讲解了如何测试并应用Log4j日志框架,这是Java开发中的一个关键组件,尤其在系统监控、调试和错误跟踪方面发挥着重要作用。Log4j是Apache软件基金会的一个开放源代码项目...

    log4j日志jar包.rar

    **日志库Log4j详解** 日志在软件开发中起着至关重要的作用,它能够帮助开发者追踪程序运行状态,定位错误,优化性能,并且在生产环境中为运维人员提供宝贵的诊断信息。Log4j,由Apache软件基金会开发,是Java编程...

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

    Log4j作为Java领域广泛应用的日志框架,提供了强大的日志记录功能和灵活的配置。本文将深入探讨log4j的配置以及配置文件的详解。** 首先,我们要理解什么是`log4j.properties`文件。这是log4j框架的配置文件,使用...

    log4j日志详细讲解

    以下是对Log4j日志的详细讲解: 首先,要在项目中启用Log4j,需要创建一个名为`log4j.properties`的配置文件,将其放在`classes`目录下。这个文件用于定义Log4j的行为,包括日志的级别、输出目的地、格式等。 1. *...

    Log4j日志等级,具体说明了log4j中的日志记录等级,对于自己写日志有很大帮助。

    在深入探讨Log4j日志等级之前,我们首先需要了解Log4j是什么。Log4j是Apache的一个开源项目,用于Java应用程序的日志记录。它提供了一种高度灵活且功能强大的日志解决方案,允许开发者和系统管理员自定义日志级别、...

    动态设置log4j的日志级别

    要实现动态设置Log4j日志级别,通常有以下几种方法: 1. **通过配置文件**:最常见的方式是通过修改log4j.properties或log4j.xml配置文件。例如,你可以将某个类或整个包的日志级别设置为WARN: ```xml ```...

Global site tag (gtag.js) - Google Analytics