Log4j的使用总结(转载)

原创 2007年09月20日 14:27:00
内容:  
一,Log4J配置文件的学习  
二,Log4J数据库  
三,Log4J封装  
一,Log4J配置文件学习:  
Log4j支持两种配置文件格式,一种是XML格式的文件,一种是Java特性文件(键=值). 
下面我们首先介绍使用Java特性文件做为配置文件的方法:  
分析一个配置文件log4j.properties  
log4j.rootCategory=debug, stdout, R  
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   bitsCN_net中国网管博客
log4j.appender.R=org.apache.log4j.RollingFileAppender  
log4j.appender.R.File=example.log  
log4j.appender.R.MaxFileSize=100KB  
# Keep one backup file  
log4j.appender.R.MaxBackupIndex=1  
log4j.appender.R.layout=org.apache.log4j.PatternLayout  
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n  
说明:  
①log4j.rootCategory = [ level ] , appenderName, appenderName,  
其中,level 是日志记录的优先级,分为OFF,FATAL,ERROR,WA R N,INFO,DEBUG, 
ALL或者您定义的级别.Log4j建议只使用四个级别,优先级从高到低分别是ERROR, 
WA R N,INFO,DEBUG.通过在这里定义的级别,您可以控制到应用程序中相应级别的日 
志信息的开关.比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息 
将不被打印出来.appenderName就是指定日志信息输出到哪个地方.您可以同时指定多个 
输出目的地.   bitsCN.com中国网管联盟
②配置日志信息输出目的地Appender,其语法为  
log4j.appender.appenderName = fully.qualified.name.of.appender.class  
log4j.appender.appenderName.option1 = value1  

log4j.appender.appenderName.option = valueN  
其中,Log4j提供的appender有以下几种:  
org.apache.log4j.ConsoleAppender(控制台),  
org.apache.log4j.FileAppender(文件),  
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), 
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),  
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)  
③配置日志信息的格式(布局),其语法为:  
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class  
log4j.appender.appenderName.layout.option1 = value1  

log4j.appender.appenderName.layout.option = valueN  
其中,Log4j提供的layout有以下几种:   www.bitsCN.net网管博客等你来搏
org.apache.log4j.HTMLLayout(以HTML表格形式布局),  
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),  
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),  
org.apache.log4j.TTCCLayout(包含日志产生的时间,线程,类别等等信息)  
④Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:  
%m 输出代码中指定的消息  
%p 输出优先级,即DEBUG,INFO,WA R N,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 输出日志事件的发生位置,包括类目名,发生的线程,以及在代码中的行数.   feedom.net国内最早的网管网站
对上面log4j.properties配置文件的一个应用;  
 

 package log4j;  
import org.apache.log4j.*;  
// How to use log4j  
public class TestLogging {  
// Initialize a logging category. Here, we get THE ROOT CATEGORY  
//static Category cat = Category.getRoot();  
// Or, get a custom category  
static Category cat = Category.getInstance(TestLogging.class.getName());  
// From here on, log away! Methods are: cat.debug(your_message_string),  
// cat.info(...), cat.warn(...), cat.error(...), cat.fatal(...)  
public static void main(String args[]) {  
// Try a few logging methods   play.bitsCN.com累了吗玩一下吧
PropertyConfigurator.configure ( "log4j.properties" ) ;  
cat.debug("Start of main()");  
cat.info("Just testing a log message with priority set to INFO");  
cat.warn("Just testing a log message with priority set to WARN");  
cat.error("Just testing a log message with priority set to ERROR");  
cat.fatal("Just testing a log message with priority set to FATAL");  
// Alternate but INCONVENIENT form  
cat.log(Priority.DEBUG, "Calling init()");  
new TestLogging().init();  
}  
public void init() {  
java.util.Properties prop = System.getProperties();  
java.util.Enumeration enum = prop.propertyNames();  
cat.info("***System Environment As Seen By Java***");  
cat.debug("***Format: PROPERTY = VALUE***");  
while (enum.hasMoreElements()) {  
String key = (String) enum.nextElement();  
cat.info(key + " = " + System.getProperty(key));  
}  
}  
}  
xml格式的log4j配置文件概述  
xml格式的log4j配置文件需要使用org.apache.log4j.html.DOMConfigurator.configure()方法来 
读入.对xml文件的语法定义可以在log4j的发布包中找到:org/apache/log4j/xml/log4j.dtd.  
Xml的一个配置文件:sample1.xml  
说明:  
①xml配置文件的头部包括两个部分:xml声明和dtd声明.头部的格式如下:  
②log4j:configuration (root element)  
xmlns:log4j [#FIXED attribute]: 定义log4j的名字空间,取定值"http://jakarta.apache.org/log4j/"  
appender [* child] : 一个appender子元素定义一个日志输出目的地  
logger [* child] : 一个logger子元素定义一个日志写出器  
root [ child] : root子元素定义了root logger  


源代码:  
package exampleslog4j.xml;  
import org.apache.log4j.xml.DOMConfigurator;  
import org.apache.log4j.Category;  
import java.net.*;  
public class XMLSample {  
static Category cat = Category.getInstance(XMLSample.class.getName());  
public  
static  
void main(String argv[]) {  
if(argv.length == 1)  
init(argv[0]);  
else  
Usage("Wrong number of arguments.");  
sample();  
}  
static  
void Usage(String msg) {  
System.err.println(msg);  
System.err.println( "Usage: java " + XMLSample.class.getName() +   www.bitsCN.net网管博客等你来搏
"configFile");  
System.exit(1);  
}  
static  
void init(String configFile) {  
DOMConfigurator.configure(configFile);  
}  
static  
void sample() {  
int i = -1;  
Category root = Category.getRoot();  
cat.debug("Message " + ++i);  
cat.warn ("Message " + ++i);  
cat.error("Message " + ++i);  
Exception e = new Exception("Just testing");  
cat.debug("Message " + ++i, e);  
}  
}  
执行后的效果:  
2004-05-24 22:07:28,352 DEBUG [main] xml.XMLSample (XMLSample.java:55) - Message 0  
2004-05-24 22:07:28,352 WARN [main] xml.XMLSample (XMLSample.java:56) - Message 1   
 2004-05-24 22:07:28,362 ERROR [main] xml.XMLSample (XMLSample.java:57) - Message 2  
2004-05-24 22:07:28,362 DEBUG [main] xml.XMLSample (XMLSample.java:59) - Message 3  
java.lang.Exception: Just testing  
at exampleslog4j.xml.XMLSample.sample(XMLSample.java:58)  
at exampleslog4j.xml.XMLSample.main(XMLSample.java:36)  


二,Log4J对数据库的操作:  
其目的就是把日志信息写入数据库以方便开发人员和测试人员查询.  
下面是写入数据库的配置文件:log4j.properties  
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender  
log4j.appender.DATABASE.URL=jdbc:oracle:thin:@192.168.0.1:1521:siemen  
log4j.appender.DATABASE.driver= oracle.jdbc.driver.OracleDriver  
log4j.appender.DATABASE.user=system   bitsCN_com关注网管是我们的使命
log4j.appender.DATABASE.password=css12345  
log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d  
- %c -%-4r [%t] %-5p %c %x - %m%n')  
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout  
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t]  
%-5p %c %x - %m%n  
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender  
log4j.appender.A1.File=SampleMessages.log4j  
log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'  
log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout  


对其应用的源文件:  
package database.servlet;  
import java.io.File;  
import java.io.LineNumberReader;  
import java.io.FileReader;  
import java.io.FileNotFoundException;  
import java.io.IOException;  
import java.util.Vector;  
import java.sql.Driver;  
import java.sql.DriverManager;  
// import servlet packages  
import javax.servlet.http.HttpServlet;  
import javax.servlet.ServletConfig;  
import javax.servlet.ServletException;  
// import log4j packages  
import org.apache.log4j.Logger;  
import org.apache.log4j.PropertyConfigurator;  
public class SetupServlet extends HttpServlet{  
public void init(ServletConfig config) throws ServletException{  
super.init(config);  
// first thing to do, is to set up the Driver that we might be using  
// in case of JDBCAppender   play.bitsCN.com累了吗玩一下吧
try{  
//Driver d =(Driver)(Class.forName("org.gjt.mm.mysql.Driver").newInstance());  
Driver d = (Driver)(Class.forName("oracle.jdbc.driver.OracleDriver").newInstance());  
DriverManager.registerDriver(d);  
//加载JDBC驱动程序,当准备将日志记录到数据库的时候可以使用  
}catch(Exception e){ System.err.println(e); }  
// next load up the properties  
//启动时从web.xml中获得配置文件的信息  
String props = config.getInitParameter("props");  
if(props == null || props.length() == 0 ||  
!(new File(props)).isFile()){  
System.err.println(  
"ERROR: Cannot read the configuration file. " +  
"Please check the path of the config init param in web.xml");  

bitsCN_com


throw new ServletException();  
}  
}  
public void destroy(){  
super.destroy();  
}  
}  
三,Log4J的封装:  
配置文件:log4j.properties  
log4j.rootLogger=DEBUG, A2, A1  
log4j.appender.A2=org.apache.log4j.RollingFileAppender  
log4j.appender.A2.File=C:/develop/log/error.log  
log4j.appender.A2.Append=true  
log4j.appender.R.MaxFileSize=10000KB  
log4j.appender.A2.layout=org.apache.log4j.PatternLayout  

 
4 关于log4j的文章---粗略看了一遍,不错!  
 log4j.appender.A2.layout.ConversionPattern=[%-5p][%t] %d{yyyy-MM-dd  
HH:mm:ss,SSS} message:%m%n  
log4j.appender.A1=org.apache.log4j.ConsoleAppender  
log4j.appender.A1.layout=org.apache.log4j.PatternLayout  
#Pattern to output the caller's file name and line number.   play.bitsCN.com累了吗玩一下吧
#log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n  
# Print the date in ISO 8601 format  
log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p - %m%n  
EncapsulationLog4J.java //Log4j的实现类  
package com.cn.lx;  
/**  
*  
Title:  
*  
Description:  
*  
Copyright: Copyright © 2004 lixiang  
*  
Company:http://www.css.com.cn/  
* @author lixiang  
* @version 1.0  
*/  
import org.apache.log4j.*;  
import java.io.*;  
import java.util.*;  
/**  
* @author Administrator  
*  
* To change the template for this generated type comment go to   play.bitsCN.com累了吗玩一下吧
* Window>Preferences>Java>Code Generation>Code and Comments  
*/  
public class EncapsulationLog4J  
{  
public static final String PROFILE = "log4j.properties";  
/**  
* Holds singleton instance  
*/  
private static EncapsulationLog4J impl;  
static  
{  
impl = new EncapsulationLog4J();  
}  
private Logger log4j;  
/**  
* prevents instantiation  
*/  
private EncapsulationLog4J()  
{  
log4j = LogManager.getLogger(EncapsulationLog4J.class);  
try  
{  
Properties pro = new Properties();  
InputStream is = getClass().getResourceAsStream(PROFILE);   bbs.bitsCN.com国内最早的网管论坛
pro.load(is);  
PropertyConfigurator.configure(pro);  
}  
catch(IOException e)  
{  
BasicConfigurator.configure();  
e.printStackTrace();  
}  
}  
public void log(String level,Object msg)  
{  
log(level,msg,null);  
}  
public void log(String level,Throwable e)  
{  
log(level,null,e);  
}  
public void log(String level,Object msg,java.lang.Throwable e)  
{  
if(log4j != null)  
{  
log4j.log((Priority)Level.toLevel(level),msg,e);  
}  
}  
/**  
* Singleton Pattern  
*/  
static public EncapsulationLog4J getInstance()  
{  
return impl;   }  
}  

Log.java //记录Log使用类  
package com.cn.lx;  
/**  
*  
Title:  
*  
Description:  
*  
Copyright: Copyright © 2004 lixiang  
*  
Company: http://www.css.com.cn/  
* @author lixiang  
* @version 1.0  
*/  
public class Log  
{  
private static EncapsulationLog4J log = EncapsulationLog4J.getInstance();  
/**  
*  
*/  
public Log()  
{  
//super();  
}  
public static void logError(String msg)  
{  
log.log("ERROR",msg);  
}  
public static void logError(Throwable e)  
{  
log.log("ERROR",null,e);  
}  
public static void logWarn(String msg)  
{  
log.log("WARN",msg);  
}  
public static void logWarn(Throwable e)  
{  
log.log("WARN",null,e);  
}  
public static void logInfo(String msg)  
{  
log.log("INFO",msg);  
}  
public static void logInfo(Throwable e)  
{  
log.log("INFO",null,e);  
}  
public static void logDebug(String msg)  
{  
log.log("DEBUG",msg);  
}  
public static void logDebug(Throwable e)  
{  
log.log("DEBUG",null,e);  
}  
}  


TestLog.java //调用Log类  
package com.cn.lx;  
public class TestLog{  
public static void main(String[] args) {  
Log test = new Log();  
test.logDebug("DEBUG");  
test.logInfo("INFO");  
test.logWarn("WARN");  
test.logError("ERROR");  
try  
{  
int i = Integer.parseInt("lixiang");  
}catch(Exception e)  
{  
test.logDebug(e.toString());  
test.logInfo(e.toString());  
test.logWarn(e.toString());  
test.logError(e.toString());  
}  
}  
}  
执行后的日志信息:  
2004-05-26 21:16:16,474 [main] DEBUG - DEBUG  
2004-05-26 21:16:16,484 [main] INFO - INFO  
2004-05-26 21:16:16,484 [main] WARN - WARN  
2004-05-26 21:16:16,484 [main] ERROR - ERROR  
2004-05-26 21:16:16,484 [main] DEBUG - java.lang.NumberFormatException: For input string:  
"lixiang"  
2004-05-26 21:16:16,484 [main] INFO - java.lang.NumberFormatException: For input string:  
"lixiang"  
2004-05-26 21:16:16,484 [main] WARN - java.lang.NumberFormatException: For input string:  
"lixiang"  
2004-05-26 21:16:16,484 [main] ERROR - java.lang.NumberFormatException: For input string:  
"lixiang"  
注:使用此方法封装Log4j的操作,可以使记录日志变得更方便.唯一不足的是无法返回当 
前类的相关信息.  
最后说明:  
关于对日志进行处理的技术有好多,如JDK 1.4 logging,Avalon LogKit,Jakarta 的Log4J  
,Jakarta的Commons-Logging等.做的最好的是Commons-Logging.下面对其做一介绍:  
The Jakarta Commons Logging (JCL) provides a Log interface that is  
intended to be both light-weight and independent of numerous logging  
toolkits. It provides the middleware/tooling developer with a simple logging  
abstraction, that allows the user (application developer) to plug in a specific  
logging implementation.  
The Jakarta Commons Logging provides a Log interface with  
thin-wrapper implementations for other logging tools, including  
Log4J , Avalon LogKit , the Avalon Framework's logging  
infrastructure, JDK 1.4, and an implementation of JDK 1.4 logging  
APIs (JSR-47) for pre-1.4 systems. The interface maps closely to   feedom.net国内最早的网管网站
Log4J and LogKit.  bbs.bitsCN.com国内最早的网管论坛

log4j使用总结

  • 2012年12月20日 14:56
  • 24KB
  • 下载

log4j使用进阶(转载)

我们在编程时经常不可避免地要使用到一些日志操作,比如开发阶段的调试信息、运行时的日志记录及审计。调查显示,日志代码占代码总量的4%。通常大家可以简单地使用System.out.println()语句输...

log4j的使用(转载)

一、介绍 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务 器、NT的事件记录器、UNIX Syslo...

log4j的使用详解(转载)

简介 log4j是一个非常强大的log记录软件,下面我们就来看看在项目中如何使log4j。 首先当然是得到log4j的jar档包,推荐使用1.2.X版本的     对于log4j,我们需要配置3...

Log4j使用总结(全面)一

一、介绍  Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务 器、NT的事件记录器、UNIX Syslo...
  • JR_Way
  • JR_Way
  • 2016年03月07日 16:28
  • 145

Apache通用日志工具commons-logging和Log4j使用总结

Apache通用日志工具commons-logging和Log4j使用总结前言在程序开发中,有时候为了跟踪代码的运行情况,需要在程序代码中加入一些打印代码运行情况的日志代码,在早期的C语言中,一般都是...
  • dfrg345
  • dfrg345
  • 2017年08月02日 17:29
  • 217

Log4J使用小总结

Log4J使用小总结 日志是软件系统中重要的一环,系统是否在正常运行或者自己的服务器很不幸地宕机了,都要通过系统日志进行分析。而在Java中使用日志,当然首选log4j,功能强大,使用方法简单明...

Log4j 2.X 使用总结

转载自 Blog of 天外的星星: http://www.cnblogs.com/leo-lsw/p/log4j2tutorial.html Log4j 2的好处就不和大家说了,如果你搜了2,说明...

log4j2的详细使用及问题解决[总结]

log4j2相对于log4j 1.x有了脱胎换骨的变化,其官网宣称的优势有多线程下10几倍于log4j 1.x和logback的高吞吐量、可配置的审计型日志、基于插件架构的各种灵活配置等。如果已经掌握...

Apache通用日记工具commons-logging和Log4j使用总结

原文:http://www.myexception.cn/apache/892706.html 前言   在程序开发中,有时候为了跟踪代码的运行情况,需要在程序代码中加入一些打印...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Log4j的使用总结(转载)
举报原因:
原因补充:

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