您好,登錄后才能下訂單哦!
這篇文章主要介紹了Tomcat中catalina.out和catalina.log的區(qū)別和用途是什么的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Tomcat中catalina.out和catalina.log的區(qū)別和用途是什么文章都會(huì)有所收獲,下面我們一起來看看吧。
catalina.out其實(shí)是tomcat的標(biāo)準(zhǔn)輸出(stdout)和標(biāo)準(zhǔn)出錯(cuò)(stderr),這是在tomcat的啟動(dòng)腳本里指定的,如果沒有修改的話stdout和stderr會(huì)重定向到這里。所以我們?cè)趹?yīng)用里使用System.out打印的東西都會(huì)到這里來。另外,如果我們?cè)趹?yīng)用里使用其他的日志框架,配置了向Console輸出的,則也會(huì)在這里出現(xiàn)。比如以logback為例,如果配置ch.qos.logback.core.ConsoleAppender則會(huì)輸出到catalina.out里。
這兩個(gè)日志都是通過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è)片段:
<Engine name="Catalina" defaultHost="localhost"> <Host name="localhost" appBase="webapps" unpackWARs="false" autoDeploy="false"> </Host> </Engine>
我們可以這么簡(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類,Host對(duì)應(yīng)著StandardHost類,而Context對(duì)應(yīng)著StandardContext。這幾個(gè)類都是從ContainerBase派生。這些類里打的一些跟應(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)用沒有啟動(dòng),這個(gè)時(shí)候的異常日志是輸出到localhost中的,而不是cataina.out中。所以有的時(shí)候我們應(yīng)用無法啟動(dòng)了,然后找catalina.out日志,但最后也沒有定位根本原因是什么,就是因?yàn)槲覀冋业娜罩静粚?duì)。但有的時(shí)候catalina.out里也有我們想要的日志,那是因?yàn)槲覀兊膽?yīng)用或使用的一些組件自己捕獲了異常,然后將其打印了,這個(gè)時(shí)候如果恰好這些日志被我們配置成輸出到console,則這些日志也會(huì)在catalina.out里出現(xiàn)了。
關(guān)于“Tomcat中catalina.out和catalina.log的區(qū)別和用途是什么”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Tomcat中catalina.out和catalina.log的區(qū)別和用途是什么”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。