国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Log4j的使用總結!(用于收藏救急用)

2019-11-18 15:31:26
字體:
來源:轉載
供稿:網友

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  
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就是指定日志信息輸出到哪個地方.您可以同時指定多個 
輸出目的地.  
②配置日志信息輸出目的地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有以下幾種:  
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 輸出日志事件的發生位置,包括類目名,發生的線程,以及在代碼中的行數.  
對上面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  
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() +  
"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  
 
 

進入討論組討論。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宣威市| 九龙县| 安顺市| 河东区| 文昌市| 綦江县| 安达市| 佳木斯市| 嘉禾县| 岗巴县| 保德县| 浮梁县| 罗田县| 资兴市| 荆门市| 平湖市| 隆化县| 玉树县| 习水县| 友谊县| 乌鲁木齐县| 浏阳市| 南木林县| 峨眉山市| 松溪县| 桃江县| 古丈县| 兴义市| 枝江市| 屯昌县| 玛多县| 璧山县| 肥乡县| 阳曲县| 扶绥县| 锡林浩特市| 文水县| 布拖县| 灵山县| 锦屏县| 永顺县|