久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

tomcat中的幾種log catalina localhost

 liang1234_ 2020-07-02

體會

catalina.out

catalina.log 是tomcat的標(biāo)準(zhǔn)輸出(stdout)和標(biāo)準(zhǔn)出錯(stderr)

cataliana.{yyyy-MM-dd}.log和localhost.{yyyy-MM-dd}.log

是通過logging.properties配置的tomcat自己運行的一些日志,,

catalina.log 是tomcat自己運行的一些日志

localhost.{yyyy-MM-dd}.log主要是應(yīng)用初始化(listener, filter, servlet)未處理的異常最后被tomcat捕獲而輸出的日志

日志是程序員居家旅行必備,哦不對,,是定位問題,,修復(fù)bug,甚至是驗證應(yīng)用是否正常的必備利器,。甚至很多時候,,我們做一次部署僅僅是為了加一行l(wèi)og。雖然現(xiàn)在有各種各樣的問題診斷工具,,但是在定位線上問題時,,我們很多時候還是希望有打印良好的log。

打印良好的log很重要,,但是知道我們需要的log在哪里也很重要,。因為各種各樣的原因,,我們經(jīng)常會將log打到不同的文件中,這樣就導(dǎo)致了出問題找?guī)讉€日志文件的情況,。

這不,,默認情況下tomcat就會生成幾個日志文件:catalina.out, catalina.{yyyy-MM-dd}.log, localhost.{yyyy-MM-dd}.log。(嗯,,這里說的是默認情況下,,這些都是可以配置修改的)。

這幾個不同的日志文件里的內(nèi)容也不盡相同,,查問題也要看不同的日志文件,,如果沒找到文件,,甚至都無法了解真正的問題是什么。

我們先來看看這幾個日志都是怎么產(chǎn)生的,,然后來了解一下什么樣子的東西會出現(xiàn)在哪個日志文件,。

catalina.out

catalina.out其實是tomcat的標(biāo)準(zhǔn)輸出(stdout)和標(biāo)準(zhǔn)出錯(stderr),,這是在tomcat的啟動腳本里指定的,,如果沒有修改的話stdout和stderr會重定向到這里,。所以我們在應(yīng)用里使用System.out打印的東西都會到這里來。另外,,如果我們在應(yīng)用里使用其他的日志框架,,配置了向Console輸出的,則也會在這里出現(xiàn),。比如以logback為例,,如果配置ch.qos.logback.core.ConsoleAppender則會輸出到catalina.out里,。

cataliana.{yyyy-MM-dd}.log和localhost.{yyyy-MM-dd}.log

這兩個日志都是通過logging.properties配置的(默認情況下,,啟動腳本里指定了java.util.logging.config.file和java.util.logging.manager兩個變量)。一個典型的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

這個文件大致的意思是,,root輸出到catalina和console,。而這里的catalina按照配置對應(yīng)的是catalina.{yyyy-MM-dd}.log,這里的console最終會輸出到catalina.out,。這就是我們看到catalina.{yyyy-MM-dd}.log和catalina.out的日志很多都是一樣的原因,。

配置文件中還有一個localhost,所有l(wèi)ogname或parent logname為org.apache.catalina.core.ContainerBase.[Catalina].[localhost]的都會輸出到localhost.{yyyy-MM-dd}.log文件,。而這個logname又代表著什么呢,?在tomcat中有一個server.xml的配置文件,其中有這么一個片段:

<Engine name='Catalina' defaultHost='localhost'>
 <Host name='localhost'  appBase='webapps'
       
unpackWARs='false' autoDeploy='false'>
 </Host>
</Engine>

我們可以這么簡單的理解: 一個Tomcat進程對應(yīng)著一個Engine,,一個Engine下可以有多個Host(Virtual Host),,一個Host里可以有多個Context,比如我們常常將應(yīng)用部署在ROOT下還是webapps里其他目錄,,這個就是Context,。

這其中Engine對應(yīng)著tomcat里的StandardEngine類,,Host對應(yīng)著StandardHost類,而Context對應(yīng)著StandardContext,。這幾個類都是從ContainerBase派生,。這些類里打的一些跟應(yīng)用代碼相關(guān)的日志都是使用ContainerBase里的getLogger,而這個這個logger的logger name就是: org.apache.catalina.core.ContainerBase.[current container name].[current container name]...

而我們一個webapp里listener, filter, servlet的初始化就是在StandardContext里進行的,,比如ROOT里有一個listener初始化出異常了,,打印日志則logger name是org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/]。這其中Catalina和localhost是上面xml片段里的Engine和Host的name,,而[/]是ROOT對應(yīng)的StandardContext的name,。所以listener, filter, servlet初始化時的日志是需要看localhost.{yyyy-MM-dd}.log這個日志的。比如現(xiàn)在我們使用Spring,,Spring的初始化我們往往是使用Spring提供的一個listener進行的,,而如果Spring初始化時因為某個bean初始化失敗,導(dǎo)致整個應(yīng)用沒有啟動,,這個時候的異常日志是輸出到localhost中的,,而不是cataina.out中。所以有的時候我們應(yīng)用無法啟動了,,然后找catalina.out日志,,但最后也沒有定位根本原因是什么,就是因為我們找的日志不對,。但有的時候catalina.out里也有我們想要的日志,,那是因為我們的應(yīng)用或使用的一些組件自己捕獲了異常,然后將其打印了,,這個時候如果恰好這些日志被我們配置成輸出到console,,則這些日志也會在catalina.out里出現(xiàn)了。

總結(jié)

那么總結(jié)起來,,catalina.out即標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)出錯,,所有輸出到這兩個位置的都會進入catalina.out,這里包含tomcat運行自己輸出的日志以及應(yīng)用里向console輸出的日志,。catalina.{yyyy-MM-dd}.log是tomcat自己運行的一些日志,,這些日志還會輸出到catalina.out,但是應(yīng)用向console輸出的日志不會輸出到catalina.{yyyy-MM-dd}.log,。localhost.{yyyy-MM-dd}.log主要是應(yīng)用初始化(listener, filter, servlet)未處理的異常最后被tomcat捕獲而輸出的日志,,而這些未處理異常最終會導(dǎo)致應(yīng)用無法啟動。

最后想想,,這里分幾個日志文件其實不利于問題查找,,為啥不干脆都輸出到catalina.out里呢?我想tomcat作為通用容器本身,可能考慮到Engine下有多個Host,,每個Host的日志還是要輸出到不同的文件,。而實際中我們往往是單容器,單Host,,甚至是只有一個ROOT的Context,。所以對于這種情況,我覺得是可以將所有日志都輸出到catalina.out方便查問題,,特別是那些還不知道初始化失敗應(yīng)該去看localhost日志的同學(xué),。嗯,可以和運維商量一下,。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點,。請注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多