關於log4j.properties文件在web項目中放的位置,找過不少,最後實踐結果是:html
1、web項目java
2、放在src的目錄裏面,而後項目生成後會自動在\WEB-INF\classes文件裏有份log4j.properties,用於發佈web
3、同時在web.xml里加了這個apache
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.properties</param-value>
</context-param>windows
配置項tomcat
成功配置tomcat的log4j日誌系統,格式:HTML+天天以yyyy-mm-dd.log命名的日誌文件
1、引言:
實習單位讓用log4j配置webapp的日誌系統,要求產生的日誌文件是html格式,而且是天天以yyyy-mm-dd日期格式命名的日誌文件。
這個曾經讓本身費神了一段時間,最近花了兩天時間總算配置成功了!不過配置成功的是tomcat的,不是單個webapp的,現把步驟記錄下來,晚上再配置webapp的。先寫一步一步的操做,後面再講解一些log4j的關鍵知識點。
2、一步一步配置tomcat log4j日誌系統
第一步:下載log4j.jar,並把log4j.jar放入$CATALINA_HOME/common/lib.
第二步:新建log4j.properties文件,放到$CATALINA_HOME/common/classes/目錄下.
第三步:寫配置文件log4j.properties:
#log4j.properties
log4j.rootLogger=warn, A1
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.file=F:/UserWorkSpace/jiangcm/Tomcat 5.0/logs/tomcat_log_
log4j.appender.A1.DatePattern=yyyy-MM-dd'.html'
log4j.appender.A1.layout=org.apache.log4j.HTMLLayout
log4j.logger.org.apache=warn
註解:
1)你只須要修改這一行:
log4j.appender.R.File=F:/UserWorkSpace/jiangcm/Tomcat 5.0/logs/tomcat_log_
將路徑修改成你的Tomcat的logs目錄,若是你的系統環境配置了CATALINA_HOME環境變量,那麼可使用${catalina.home}/logs/tomcat_log_進行配置便可。
2)上面的log4j配置僅記錄比較重要的日誌(警告warning、錯誤error、致命錯誤fatal)到Tomcat的logs目錄下的tomcat_log_ 文件中,天天晚上過0點的第一條信息會觸發重命名tomcat_log_,將當前日期附加在tomcat_log_ 文件名中,併產生新的tomcat_log_ 文件。
3)使用FileAppender能夠將log信息輸出到文件中,可是若是文件太大了讀起來就不方便了。這時就可使用 DailyRollingAppender。DailyRollingAppender能夠把Log信息輸出到按照日期來區分的文件中。如上述log4j.properties配置文件就會天天產生一個html文件,每一個html文件只記錄當天的log信息。
4)設置了DailyRollingAppender 之後若是配置項裏面設置了文件的最大值,那麼應該去掉,不然可能不能產生以天爲單位的日誌。
5)Log4j的org.apache.log4j.DailyRollingFileAppender源碼223行
scheduledFilename = fileName+sdf.format(new Date(file.lastModified()));
也就是說備份的日至文件都是文件名後面加上你所配的DatePattern格式化後的字符串。除非你本身寫個appender。
6)上述log4j.properties生成的日誌文件,名稱格式以下:tomcat_log_2007-02-24.html;
注意:生成的第一個日誌文件格式以下:tomcat_log_,即只是A1.file中設置的名稱;生成的第二個日誌文件以後的文件命名纔會加上所配的DatePattern格式化後的字符串。
7)配置DailyRollingFileAppender格式的日誌系統,若是要驗證生成的日誌文件結果,要注意一點,須要關閉tomcat,修改系統日期爲次日的日期,再重啓tomcat,這樣才能自動生成一個新的日誌文件;由於要修改日期才能觸發產生新的日誌文件。
第四步:重啓tomcat.
ok,如今就已經在tomcat中配置好log4j了。
第五步:驗證
驗證上述配置的log4j日誌系統:
利用tomcat自帶的web應用程序jsp-examples,如今配置好了日誌系統,那麼若是在jsp-examples這個web應用程序的.java文件中使用了日誌,則IE訪問這個web app的jsp文件時,就應該可以自動產生日誌文件到配置的路徑中。
步驟:
a)進入目錄「F:\UserWorkSpace\jiangcm\Tomcat 5.0\webapps\jsp-examples\WEB-INF\classes\dates」;
b)修改JspCalendar.java文件,在這個文件中加上日誌的代碼,以下所示:
package dates;
import java.text.DateFormat;
import java.util.*;
import org.apache.log4j.Logger;
import org.apache.log4j.Level;
import org.apache.log4j.*;
public class JspCalendar {
Calendar calendar = null;
static Logger logger = Logger.getLogger(JspCalendar.class);
public JspCalendar() {
logger.debug("This is debug.");
logger.info("This is an info.");
logger.warn("This is a warning.");
logger.error("This is an error.");
logger.fatal("This is a fatal error.");
calendar = Calendar.getInstance();
Date trialTime = new Date();
calendar.setTime(trialTime);
}
public int getYear() {
return calendar.get(Calendar.YEAR);
}
……
}
註釋:
加上的代碼有兩部分,一是構造一個logger對象,一是輸出logger信息,以下所示,其餘代碼沒動:
static Logger logger = Logger.getLogger(JspCalendar.class);
logger.debug("This is debug.");
logger.info("This is an info.");
logger.warn("This is a warning.");
logger.error("This is an error.");
logger.fatal("This is a fatal error.");
c)從新編譯JspCalendar.java;
d)修改日期爲2007-02-26;
e)重啓tomcat;
f)在IE中輸入「http://localhost:8086/jsp-examples/dates/date.jsp」,運行該jsp文件;
g)這時在目錄「F:\UserWorkSpace\jiangcm\Tomcat 5.0\logs」下看到了新產生的日誌文件:tomcat_log_2007-02-25.html.
ok!說明日誌系統配置成功啦,啦~!!
3、遺留問題
3.1 上述配置的是tomcat的日誌系統,應該是對tomcat下的全部webapp都起做用,如今本身只驗證了jsp-examples這個webapp,尚未驗證過其餘的webapp。
3.2 配置的是tomcat的日誌系統,輸出的應該都只是tomcat的標準輸入/輸出信息等,感受webapp的日誌信息應該和tomcat的系統日誌信息分開,可是應該怎麼分開呢?若是對每一個webapp單獨配置日誌系統,那麼這些日誌內容會輸出到tomcat的系統日誌中嗎?
3.3 不需任何配置,tomcat5.0的默認日誌目錄「F:\UserWorkSpace\jiangcm\Tomcat 5.0\logs」下就有按日期產生的日誌文件,文件命名格式以下:localhost_log.2007-02-26.txt,而且這個文件是自動生成的,上述配置在目錄「F:\UserWorkSpace\jiangcm\Tomcat 5.0\logs」下生成了tomcat_log_2007-02-25.html文件,而且tomcat自己也自動生成了一個localhost_log.2007-02-26.txt文件,至關於自動生成了兩個日誌文件。
固然這兩個日誌文件的內容不一樣,tomcat_log_2007-02-25.html中的內容以下:
待貼圖
而localhost_log.2007-02-26.txt的內容以下:
2007-02-26 14:03:21 StandardContext[/balancer]org.apache.webapp.balancer.BalancerFilter: init(): ruleChain: [org.apache.webapp.balancer.RuleChain: [org.apache.webapp.balancer.rules.URLStringMatchRule: Target string: News / Redirect URL: http://www.cnn.com], [org.apache.webapp.balancer.rules.RequestParameterRule: Target param name: paramName / Target param value: paramValue / Redirect URL: http://www.yahoo.com], [org.apache.webapp.balancer.rules.AcceptEverythingRule: Redirect URL: http://jakarta.apache.org]]
2007-02-26 14:03:22 StandardContext[/jsp-examples]ContextListener: contextInitialized()
2007-02-26 14:03:22 StandardContext[/jsp-examples]SessionListener: contextInitialized()
2007-02-26 14:03:22 StandardContext[/servlets-examples]ContextListener: contextInitialized()
2007-02-26 14:03:22 StandardContext[/servlets-examples]SessionListener: contextInitialized()
感受就是localhost_log.2007-02-26.txt中是tomcat的系統日誌,而omcat_log_2007-02-25.html中是.java中本身寫的logger的內容。
那麼,是否是tomcat5中系統日誌就會自動按日生成,不需配置;開發人員若是須要日誌系統,那麼就在本身的webapp中配置一個,而不須要管tomcat的系統日誌了???
3.4 tomcat_log_2007-02-25.html與localhost_log.2007-02-26.txt內容不一樣的緣由有沒有多是由於:
本身的log4j.properties中設置apache的級別是warn:??
log4j.logger.org.apache=warn
剛驗證了一下,好像沒有關係,「log4j.logger.org.apache=warn」這句好像不只對localhost_log.2007-02-26.txt無影響,並且對tomcat_log_2007-02-25.html的輸出也無影響。
那麼「log4j.logger.org.apache=warn」這句的做用是什麼呢???
3.5 webapp中如何配置日誌系統,而且把webapp的日誌信息與tomcat自身的系統日誌分開???
4、參考資料:
1.我想每一天都產生一個以"yyyy-mm-dd.log"命名日誌文件,請問該怎麼配置file選項,謝謝了!
http://community.csdn.net/Expert/TopicView3.asp?id=4788993
2.使用log4j爲Tomcat輸出日誌
http://www.chinawin.net/myblog/archives/314-log4jTomcataeoeOE.html
1. 若是Tomcat當前正在運行,關閉Tomcat。
2. 從Apache的網站下載Commons Logging發行包。
3. 將壓縮包中的commons-logging.jar解壓縮到你Tomcat安裝路徑的common/lib目錄中。
4. 從Apache的網站下載Log4j發行包。
5. 將壓縮包中的log4j-1.2.12.jar解壓縮到你Tomcat安裝路徑的common/lib目錄中。
6. 在Tomcat安裝路徑的common/classes 建立log4j的配置文件log4j.properties(配置文件在隨後一節)。
7. 重起Tomcat
3.在Web應用中使用log4j
http://www.3doing.net/forums/printpage.asp?BoardID=11&ID=184
注意:上面的load-on-startup應設爲1,以便在Web容器啓動時即裝入該Servlet。log4j.properties文件放在根的properties子目錄中,也能夠把它放在其它目錄中。應該把.properties文件集中存放,這樣方便管理。
4.og4j日誌文件路徑的配置
http://wangluwww.spaces.live.com/blog/
解決log4j輸出的日誌文件的位置的配置問題
我一直但願本身的web應用的配置可以簡化,最好的方式就是打個包後扔哪都能用,即便非得再作一些配置的話,也但願只是一些鏈接池的配置信息。這個目標在如今手頭的這個項目中也幾乎達到了,除了log文件的位置。
在log4j的配置文件中對於log輸出的路徑一貫都是使用絕對路徑,這樣就致使在不一樣的機器上部署時都得從新定義一下log文件的輸出位置。雖然說費時很少,可對於我這種寧肯少一事,不肯多一事的人來講,老是以爲有點鬱悶。
踏破鐵鞋無覓,得來不費功夫。不經意見看到了一個文檔,介紹說log4j的配置文件支持windows的環境變量,格式相似velocity:${env},ok,問題解決:
通常來講咱們會將一些初始化的信息放到web.xml中,以便在系統啓動時就運行。循此思路,將log文件的位置放到webapp下面的任意處,如webapp/WEB-INF/conf/logs下面,則能夠在log4j.properties文件中作以下定義:
log4j.appender.R.File=${webappHome}/WEB-INF/conf/logs/sysout.log
其中的${webappHome}便是經過System.setProperty("webappHome", webappHome);實現的,此操做可經過一初始的servlet進行,具體方法略。
5. Log4j優化
http://www.3doing.net/forums/printpage.asp?BoardID=11&ID=184
有多少人用Log4j的時候會在每個Debug/Info以前加一個判斷?
可能不少人都說了,這有什麼關係,我在運行的時候是把Log Level設置成Error的。
那麼請看下面這個代碼:
String result;
...
...
...
logger.debug(」result is」 + result );
再看看這個代碼:
String result;
...
...
...
if(logger.isDebugEnabled())
{
logger.debug(」result is」 + result );
}
把Log Level設置成ERROR,運行結果又區別嗎?沒有!!
程序的性能有區別嗎?區別大了!!!
由於什麼呢?
雖然第一段代碼也不產生Log輸出,可是debug()裏面的字符串變量是實例化了,明白了嗎?
這個就是爲何不少人抱怨Log4j佔用很大CPU時間的緣由了,尤爲是在大循環的時候。
趕快在你的程序中加上這樣的判斷條件吧。app