tomcat中的几种log catalina localhost
2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>
體會(huì)
catalina.out catalina.log
是tomcat的標(biāo)準(zhǔn)輸出(stdout)和標(biāo)準(zhǔn)出錯(cuò)(stderr)
cataliana.{yyyy-MM-dd}.log和localhost.{yyyy-MM-dd}.log
是通過(guò)logging.properties配置的tomcat自己運(yùn)行的一些日志, catalina.log 是tomcat自己運(yùn)行的一些日志
localhost.{yyyy-MM-dd}.log
主要是應(yīng)用初始化(listener, filter, servlet)未處理的異常最后被tomcat捕獲而輸出的日志 日志是程序員居家旅行必備,哦不對(duì),是定位問(wèn)題,修復(fù)bug,甚至是驗(yàn)證應(yīng)用是否正常的必備利器。甚至很多時(shí)候,我們做一次部署僅僅是為了加一行l(wèi)og。雖然現(xiàn)在有各種各樣的問(wèn)題診斷工具,但是在定位線上問(wèn)題時(shí),我們很多時(shí)候還是希望有打印良好的log。 打印良好的log很重要,但是知道我們需要的log在哪里也很重要。因?yàn)楦鞣N各樣的原因,我們經(jīng)常會(huì)將log打到不同的文件中,這樣就導(dǎo)致了出問(wèn)題找?guī)讉€(gè)日志文件的情況。 這不,默認(rèn)情況下tomcat就會(huì)生成幾個(gè)日志文件:catalina.out, catalina.{yyyy-MM-dd}.log, localhost.{yyyy-MM-dd}.log。(嗯,這里說(shuō)的是默認(rèn)情況下,這些都是可以配置修改的)。 這幾個(gè)不同的日志文件里的內(nèi)容也不盡相同,查問(wèn)題也要看不同的日志文件,如果沒(méi)找到文件,甚至都無(wú)法了解真正的問(wèn)題是什么。
我們先來(lái)看看這幾個(gè)日志都是怎么產(chǎn)生的,然后來(lái)了解一下什么樣子的東西會(huì)出現(xiàn)在哪個(gè)日志文件。
catalina.out catalina.out其實(shí)是tomcat的標(biāo)準(zhǔn)輸出(stdout)和標(biāo)準(zhǔn)出錯(cuò)(stderr),這是在tomcat的啟動(dòng)腳本里指定的,如果沒(méi)有修改的話stdout和stderr會(huì)重定向到這里。所以我們?cè)趹?yīng)用里使用System.out打印的東西都會(huì)到這里來(lái)。
另外,如果我們?cè)趹?yīng)用里使用其他的日志框架,配置了向Console輸出的,則也會(huì)在這里出現(xiàn)。比如以logback為例,如果配置ch.qos.logback.core.ConsoleAppender則會(huì)輸出到catalina.out里。
cataliana.{yyyy-MM-dd}.log和localhost.{yyyy-MM-dd}.log 這兩個(gè)日志都是通過(guò)logging.properties配置的(默認(rèn)情況下,啟動(dòng)腳本里指定了java.util.logging.config.file和java.util.logging.manager兩個(gè)變量)。
一個(gè)典型的logging.properties可能如下所示:
handlers = 1catalina.org.apache.juli.FileHandler, 2localhost.org.apache.juli.FileHandler, java.util.logging.ConsoleHandler
.handlers = 1catalina.org.apache.juli.FileHandler, java.util.logging.ConsoleHandler
1catalina.org.apache.juli.FileHandler.level = INFO
1catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
1catalina.org.apache.juli.FileHandler.prefix = catalina.
2localhost.org.apache.juli.FileHandler.level = FINE
2localhost.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
2localhost.org.apache.juli.FileHandler.prefix = localhost.
java.util.logging.ConsoleHandler.level = INFO
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].level = INFO
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].handlers = 2localhost.org.apache.juli.FileHandler
這個(gè)文件大致的意思是,root輸出到catalina和console。
而這里的catalina按照配置對(duì)應(yīng)的是catalina.{yyyy-MM-dd}.log,這里的console最終會(huì)輸出到catalina.out。
這就是我們看到catalina.{yyyy-MM-dd}.log和catalina.out的日志很多都是一樣的原因。
配置文件中還有一個(gè)localhost,所有l(wèi)ogname或parent logname為org.apache.catalina.core.ContainerBase.[Catalina].[localhost]的都會(huì)輸出到localhost.{yyyy-MM-dd}.log文件。
而這個(gè)logname又代表著什么呢?在tomcat中有一個(gè)server.xml的配置文件,其中有這么一個(gè)片段: ? ?
我們可以這么簡(jiǎn)單的理解: 一個(gè)Tomcat進(jìn)程對(duì)應(yīng)著一個(gè)Engine,一個(gè)Engine下可以有多個(gè)Host(Virtual Host),一個(gè)Host里可以有多個(gè)Context,比如我們常常將應(yīng)用部署在ROOT下還是webapps里其他目錄,這個(gè)就是Context。 這其中Engine對(duì)應(yīng)著tomcat里的StandardEngine類(lèi),Host對(duì)應(yīng)著StandardHost類(lèi),而Context對(duì)應(yīng)著StandardContext。這幾個(gè)類(lèi)都是從ContainerBase派生。
這些類(lèi)里打的一些跟應(yīng)用代碼相關(guān)的日志都是使用ContainerBase里的getLogger,而這個(gè)這個(gè)logger的logger name就是:?org.apache.catalina.core.ContainerBase.[current container name].[current container name]... 而我們一個(gè)webapp里listener, filter, servlet的初始化就是在StandardContext里進(jìn)行的,比如ROOT里有一個(gè)listener初始化出異常了,打印日志則logger name是org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/]。這其中Catalina和localhost是上面xml片段里的Engine和Host的name,而[/]是ROOT對(duì)應(yīng)的StandardContext的name。所以listener, filter, servlet初始化時(shí)的日志是需要看localhost.{yyyy-MM-dd}.log這個(gè)日志的。
比如現(xiàn)在我們使用Spring,Spring的初始化我們往往是使用Spring提供的一個(gè)listener進(jìn)行的,而如果Spring初始化時(shí)因?yàn)槟硞€(gè)bean初始化失敗,導(dǎo)致整個(gè)應(yīng)用沒(méi)有啟動(dòng),這個(gè)時(shí)候的異常日志是輸出到localhost中的,而不是cataina.out中。所以有的時(shí)候我們應(yīng)用無(wú)法啟動(dòng)了,然后找catalina.out日志,但最后也沒(méi)有定位根本原因是什么,就是因?yàn)槲覀冋业娜罩静粚?duì)。
但有的時(shí)候catalina.out里也有我們想要的日志,那是因?yàn)槲覀兊膽?yīng)用或使用的一些組件自己捕獲了異常,然后將其打印了,這個(gè)時(shí)候如果恰好這些日志被我們配置成輸出到console,則這些日志也會(huì)在catalina.out里出現(xiàn)了。
總結(jié)
那么總結(jié)起來(lái),catalina.out即標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)出錯(cuò),所有輸出到這兩個(gè)位置的都會(huì)進(jìn)入catalina.out,這里包含tomcat運(yùn)行自己輸出的日志以及應(yīng)用里向console輸出的日志。
catalina.{yyyy-MM-dd}.log是tomcat自己運(yùn)行的一些日志,這些日志還會(huì)輸出到catalina.out,但是應(yīng)用向console輸出的日志不會(huì)輸出到catalina.{yyyy-MM-dd}.log。
localhost.{yyyy-MM-dd}.log主要是應(yīng)用初始化(listener, filter, servlet)未處理的異常最后被tomcat捕獲而輸出的日志,而這些未處理異常最終會(huì)導(dǎo)致應(yīng)用無(wú)法啟動(dòng)。
最后想想,這里分幾個(gè)日志文件其實(shí)不利于問(wèn)題查找,為啥不干脆都輸出到catalina.out里呢?
我想tomcat作為通用容器本身,可能考慮到Engine下有多個(gè)Host,每個(gè)Host的日志還是要輸出到不同的文件。而實(shí)際中我們往往是單容器,單Host,甚至是只有一個(gè)ROOT的Context。
所以對(duì)于這種情況,我覺(jué)得是可以將所有日志都輸出到catalina.out方便查問(wèn)題,特別是那些還不知道初始化失敗應(yīng)該去看localhost日志的同學(xué)。
嗯,可以和運(yùn)維商量一下。?
Tomcat日志、項(xiàng)目中的log4j日志、控制臺(tái)——我的日志最后到底跑哪去了?
1、Tomcat自帶日志功能,即時(shí)你的項(xiàng)目中有l(wèi)og4j也不會(huì)影響到Tomcat自己記錄日志。
2、你的項(xiàng)目中的log4j中的日志指定打印到什么地方(控制臺(tái)或者文件),便會(huì)打印到什么地方,和Tomat日志無(wú)關(guān)。
——如果你項(xiàng)目中的log4j指定打印到控制臺(tái),并且你開(kāi)啟的tomcat有控制臺(tái),那么這個(gè)時(shí)候你可以在控制臺(tái)觀察到日志。
——如果你用log4j來(lái)處理了Tomcat的日志(具體需要你自己配置tomcat的配置文件),那么Tomcat便會(huì)使用log4j來(lái)打印,但是這和你項(xiàng)目中的log4j仍然不是同一個(gè)log4j。
3、關(guān)于異常日志的打印
如果你在你的項(xiàng)目中處理了某個(gè)異常:
try {int i = 1/0;}catch(Exception e) {e.printStackTrace();}A、那么這個(gè)異常信息會(huì)打印到你的控制臺(tái)。你說(shuō)你沒(méi)有開(kāi)控制臺(tái),是用服務(wù)的形式跑的?那么這個(gè)異常的信息你就看不見(jiàn)了。
B、你在你的項(xiàng)目中直接throw的,并且沒(méi)有任何地方處理這個(gè)異常,那么最后這個(gè)異常會(huì)被拋給你的容器——Tomcat,Tomcat這時(shí)會(huì)在localhost.日期.log文件中記錄這個(gè)異常。
C、你使用的是log4j:
LogFactory.getLog(Logger.class).error("Thread:"+i+"-print:"+j+"-CurrentThread:"+Thread.currentThread());那么你應(yīng)該去看看你的log4j配置文件中,看看里面寫(xiě)的要把這條錯(cuò)誤信息打印在哪。
——如果是打印到控制臺(tái),那么就去控制臺(tái)找。如果沒(méi)有控制臺(tái),那么這個(gè)錯(cuò)誤信息也就丟了。
——如果是寫(xiě)入某個(gè)文件,那當(dāng)然就是在你的文件中了。
?
4、控制臺(tái)
Tomcat默認(rèn)也會(huì)往控制臺(tái)輸出日志,這部分日志和其catalina.日期.log文件中記錄的是一致的。
程序中的syso、e.printStackTrace(),以及l(fā)og4j如果配置的往控制臺(tái)輸出日志,那么他們?nèi)慷紩?huì)出現(xiàn)在控制臺(tái)上,
別看你eclipse里的控制臺(tái)上有那么多日志,你要搞清楚他們不是同一個(gè)日志記錄器寫(xiě)的。
?
禁用 catalina 日志的輸出:
1catalina.org.apache.juli.FileHandler.level = OFF
?
tomcat參考文檔? http://wiki.jikexueyuan.com/project/tomcat/logging.html
轉(zhuǎn)載于:https://my.oschina.net/newchaos/blog/2186596
總結(jié)
以上是生活随笔為你收集整理的tomcat中的几种log catalina localhost的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 水滴众筹的面试题
- 下一篇: “正则表达式”应当称为“规则表达式”