av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Tomcat中catalina.out 和 catalina.log的區(qū)別和用途詳解

瀏覽:215日期:2023-03-19 16:51:37
目錄
  • catalina.out
  • cataliana.{yyyy-MM-dd}.log和localhost.{yyyy-MM-dd}.log
  • 總結(jié)

catalina.out

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ì)到這里來(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è)片段:

<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)用無(wú)法啟動(dòng)了,然后找catalina.out日志,但最后也沒有定位根本原因是什么,就是因?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í)不利于問題查找,為啥不干脆都輸出到catalina.out里呢?我想tomcat作為通用容器本身,可能考慮到Engine下有多個(gè)Host,每個(gè)Host的日志還是要輸出到不同的文件。而實(shí)際中我們往往是單容器,單Host,甚至是只有一個(gè)ROOT的Context。

一般是用log4j按照業(yè)務(wù)劃分,對(duì)一些比較重要的業(yè)務(wù)會(huì)單獨(dú)打到一個(gè)文件,方便容易定位問題,,其他的默認(rèn)會(huì)打到catalina。

到此這篇關(guān)于Tomcat中catalina.out 和 catalina.log的區(qū)別和用途詳解的文章就介紹到這了,更多相關(guān)Tomcat catalina.out  catalina.log內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: Tomcat
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩三级视频 | 国产精品久久国产精品99 gif | 国产精品亚洲综合 | 国产欧美日韩精品一区二区三区 | 欧美一级精品片在线看 | 久久专区 | 欧美天堂在线 | 国产一区二区三区四区三区四 | 国产一区 | 男女视频91| 欧美亚洲另类丝袜综合网动图 | 91资源在线观看 | 精品一区二区电影 | www操操 | 精品视频在线观看 | 欧美久久视频 | 午夜视频一区 | 久久精品国产99国产精品 | 日韩成人专区 | 免费特级黄毛片 | jizz在线看片 | 色网站在线 | 91精品久久久久久久久久入口 | 精品国产欧美一区二区三区不卡 | 精品久久一区二区 | 天天影视亚洲综合网 | 日韩毛片 | 久久精品免费 | 亚洲欧美一区二区三区国产精品 | 国产特级毛片 | 视频一区在线 | 国产精品日本一区二区在线播放 | 欧美一级大片免费观看 | 亚洲精品播放 | 天堂免费 | 日韩欧美专区 | 亚洲福利视频网 | 欧美一区| 在线观看av不卡 | 久久久久无码国产精品一区 | 日本不卡一区 |