Log4J基础

原创 2004年10月26日 09:12:00
Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数见表1如下:

%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)
  
基本应用

Log4J的配置
现在来看log4j.properties配置文件的意义。第一行指定了根Logger的级别是DEBUG,并将此指定输出到A1。A1就是第二行定义的org.apache.log4j.ConsoleAppender,此行表示将A1输出到控制台。第三行规定了输出到A1的格式为org.apache.log4j.PatternLayout。第四行规定了输出到A1格式的转换模式为org.javaresearch.log4j.TestLog4J。
很多成熟的服务器类的软件日志信息会输出到控制台,同时输出到日志文件备查。使用Log4J可以在不改变任何代码的情况下,仅通过修改配置文件就可以轻松地完成这项功能。相关配置文件如下:
#### Use two appenders, one to log to console, another to log to a file
log4j.rootCategory=debug, stdout, R
# Print only messages of priority WARN or higher for your category
log4j.category.your.category.name=WARN
#### 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
#### Second appender writes to a file
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=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=%p %t %c - %m%n
 
这个配置文件指定了两个输出源stdout和R。前者把日志信息输出到控制台,后者是一个轮转日志文件。最大的文件是100KB,当一个日志文件达到最大尺寸时,Log4J会自动把example.log重命名为example.log.1,然后重建一个新的example.log文件,依次轮转。
在Web应用中使用
在Web应用中,应该在哪儿对Log4J进行配置呢?首先要明确,Log4J必须在应用的其它代码执行前完成初始化。因为Servlet是在Web服务器启动时立即装入的,所以,在Web应用中一般使用一个专门的Servlet来完成Log4J的配置,并保证在web.xml的配置中,这个Servlet位于其它Servlet之前。下面是一个例子,代码如下:
package org.javaresearch.log4j;
import java.io.*;
import javax.servlet.*;
import org.apache.log4j.*;
public class Log4JInit extends HttpServlet {
public void init() throws ServletException {
String prefix = getServletContext().getRealPath("/");
String file = getServletConfig().getInitParameter("log4j-config-file");
// 从Servlet参数读取log4j的配置文件
if (file != null) {
PropertyConfigurator.configure(prefix + file);
}
}
public void doGet(HttpServletRequest request,HttpServletResponse response)throws
IOException, ServletException {}
public void doPost(HttpServletRequest request,HttpServletResponse response)throws
IOException, ServletException {}
}
 
<servlet>
<servlet-name>log4jinit</servlet-name>
<servlet-class>org.javaresearch. log4j.Log4JInit</servlet-class>
<init-param>
<param-name> log4j-config-file </param-name>
<param-value>/properties/log4j.properties</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
 
注意:上面的load-on-startup应设为1,以便在Web容器启动时即装入该Servlet。log4j.properties文件放在根的properties子目录中,也可以把它放在其它目录中。应该把.properties文件集中存放,这样方便管理。

Log4j详细使用教程

日志是应用软件中不可缺少的部分,Apache的开源项目Log4j是一个功能强大的日志组件,提供方便的日志记录。在apache网站:jakarta.apache.org/log4j 可以免费下载到Log...
  • Evankaka
  • Evankaka
  • 2015年05月18日 11:07
  • 15546

log4j基础

log4j配置文件位置详解
  • hothead007
  • hothead007
  • 2014年09月27日 21:44
  • 241

Log4j基础

Log4j下载: 日志级别: 日志输出控制文件:
  • sinat_27115575
  • sinat_27115575
  • 2017年04月17日 11:37
  • 314

黑马程序员_我的Linux基础整理笔记

Linux Linux文件目录和分区 文件目录: /:根目录 /root:存放root用户的相关文件 /home:存放普通用户的相关文件 /bin:存放普通用户的可执行命令 /sbin:...
  • zhengzhongjie1990
  • zhengzhongjie1990
  • 2014年07月05日 17:08
  • 1699

slf4j+log4j2基础教程(拿来即用教程)

log4j2是apache著名日志框架log4j的升级,参考logback架构,并且修复了logback固有的一些问题。是一个很好的日志框架。我看了网上一些关于log4j2的教程,要么是光讲概念,要么...
  • lianjunzongsiling
  • lianjunzongsiling
  • 2017年12月20日 00:37
  • 250

zookeeper 入门指南(译)

zookeeper 入门指南原文地址: http://zookeeper.apache.org/doc/r3.4.8/zookeeperStarted.html使用zookeeper进行分布式协调应用...
  • jia281460530
  • jia281460530
  • 2016年08月24日 21:07
  • 597

cassandra学习笔记一

最近尝试搭建一个云存储平台,在不断的对比之后,决定采用cassandra作为底层数据库。这里记录cassandra的学习过程。     Cassandra是一个混合型的非关系的数据库,主要特性是分布...
  • fykhlp
  • fykhlp
  • 2012年03月02日 14:45
  • 7682

【javaee基础】Log4j日志级别:

Log4j日志级别:   Debug:调试级别 Info:信息级别 Warn:j警告级别 Error:错误级别 Fatal:崩溃级别   Log4j日志输出格式: %M-jav...
  • Generalissimo_Hu
  • Generalissimo_Hu
  • 2016年08月15日 11:30
  • 121

Log4j基础讲解

一、 Log4j的架构   Log4j系统的三大板块:日志写入器、日志输出终端、日志布局模式。       Logger类是日志包的核心,Logger的名称是大小写敏感的,并且名称之间有继...
  • luoyan35714
  • luoyan35714
  • 2013年04月05日 08:54
  • 588

log4j基础与使用

一 概念1.1 背景     在应用程序中添加日志记录的目的:    1:  调试器,向文件或控制台打印代码的调试信息,因为可以通过配置文件设置是否输出打印信息,所以比通过 System.out打出调...
  • zhoumin008
  • zhoumin008
  • 2006年09月06日 00:11
  • 612
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Log4J基础
举报原因:
原因补充:

(最多只允许输入30个字)