网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > JAVA > 核心技术 > 高级编程 > Log4j的使用总结!(用于收藏救急用)  

Log4j的使用总结!(用于收藏救急用)

2007-01-11  作者:bitsCN整理  来源:JavaResearch  点评 投稿 收藏

1 关于log4j的文章---粗略看了一遍,不错!  
 出处给忘了好像是下面这个:  
  http://dev2dev.bea.com.cn/bbs/servlet/D2DServlet/download/124-14026-77822-650/深入学习Log4J.pdf 
深入学习Log4J  
李翔  

内容:  
一,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_com
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就是指定日志信息输出到哪个地方.您可以同时指定多个 
输出目的地.  

网管网www_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有以下几种:   网管u家u.bitscn@com
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 输出日志事件的发生位置,包括类目名,发生的线程,以及在代码中的行数.   中国网管论坛bbs.bitsCN.com
对上面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  
网管联盟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();  

网管论坛bbs_bitsCN_com


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子元素定义一个日志输出目的地  

网管bitscn_com


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() +   中国网管论坛bbs.bitsCN.com
"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  
网管网www.bitscn.com

 
 

网管u家u.bitsCN.com

网管下载dl.bitscn.com


上一页12 3 下一页
TAGs   收藏   用于   总结   使用       public      import       
 上一篇:管理 Java 类路径(UNIX 和 Mac OS X)   下一篇:抽象类对象类和对象包装类
相关文章列表
Log4j的使用总结!(用于收藏救急用) 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
1.用java编写的小游戏源代码分析
2.在.Net程序中使用log4net记录日志
3.Java与sqlserver2000的连接
4.Java源代码案例--骑士巡游问题
5.Java游戏编程分析--棋子的拖动
6.JAVA 正则表达式4种常用的功能
7.Log4j的使用总结!(用于收藏救急用)
8.JFreeChart中柱状图的详细设置
9.学习教程:Java Annotation 高
10.JAVA对象转为Java String的几种常用方法
最新推荐文章:
1.该如何实践State模式
2.JFreeChart中柱状图的详细设置
3.Java Swing APIs可插拔式外观风格特性应
4.用信号量Semaphore实现互斥锁Mutex
5.使用Weblogic Integration的应用程序架构
6.设计Java应用程序
7.对Java嵌套类的讨论(上)
8.提高Java代码可重用性的三个措施
9.JAVA上加密算法的实现用例
10.总结篇:将内部类进行到底
网管论坛交流:
·不疯魔不成活
·令你大开眼界的真正标准化机房,已整理重
·华为HCSE OSPF路由协议培训教材 V3.0
·为赈灾,女孩舍身拍“裸照”
·Windows Server 2003服务器群集创建和配
·exchange2k3全套官方资料
·双儿一周岁了。。。特殊的礼物来啦。。
·存储备份技术版块守则
·无盘技术交流区守则
·DOS命令基础大全之命令详解<作者吐血