欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年02月17日 09:36:49   作者:daopinz  
本文主要介紹了Tomcat中catalina.out 和 catalina.log的區(qū)別和用途詳解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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配置的(默認(rèn)情況下,啟動腳本里指定了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。

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

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

相關(guān)文章

  • Web應(yīng)用中設(shè)置Context Path案例詳解

    Web應(yīng)用中設(shè)置Context Path案例詳解

    這篇文章主要介紹了Web應(yīng)用中設(shè)置Context Path案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • ELK收集Tomcat日志的實現(xiàn)

    ELK收集Tomcat日志的實現(xiàn)

    本文主要介紹了ELK收集Tomcat日志的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • window和linux通過tomcat9手工部署war包的方法

    window和linux通過tomcat9手工部署war包的方法

    這篇文章主要介紹了window和linux通過tomcat9手工部署war包的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-10-10
  • docker安裝Tomcat 404問題的解決方案

    docker安裝Tomcat 404問題的解決方案

    這篇文章主要介紹了docker安裝Tomcat 404問題的解決方案,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • Idea中tomcat啟動源碼調(diào)試進入到tomcat內(nèi)部進行調(diào)試的方法

    Idea中tomcat啟動源碼調(diào)試進入到tomcat內(nèi)部進行調(diào)試的方法

    這篇文章主要介紹了Idea中tomcat啟動源碼調(diào)試進入到tomcat內(nèi)部進行調(diào)試的方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • Tomcat部署war包并成功訪問網(wǎng)頁詳細圖文教程

    Tomcat部署war包并成功訪問網(wǎng)頁詳細圖文教程

    Tomcat是目前web開發(fā)中非常流行的Web服務(wù)器,這篇文章主要給大家介紹了關(guān)于Tomcat部署war包并成功訪問網(wǎng)頁的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • 修改Tomcat服務(wù)器默認(rèn)端口號的實現(xiàn)方法

    修改Tomcat服務(wù)器默認(rèn)端口號的實現(xiàn)方法

    這篇文章主要介紹了修改Tomcat服務(wù)器默認(rèn)端口號的實現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2017-09-09
  • Nginx/Httpd負載均衡tomcat配置教程

    Nginx/Httpd負載均衡tomcat配置教程

    這篇文章主要介紹了Nginx/Httpd負載均衡tomcat配置方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • tomcat何時寫回響應(yīng)數(shù)據(jù)報的詳析

    tomcat何時寫回響應(yīng)數(shù)據(jù)報的詳析

    這篇文章主要給大家介紹了關(guān)于tomcat是何時寫回響應(yīng)數(shù)據(jù)報的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用tomcat具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 在同一臺服務(wù)器上配置多個Tomcat的方法

    在同一臺服務(wù)器上配置多個Tomcat的方法

    本篇文章主要講訴了在同一臺服務(wù)器上配置多個Tomcat的方法,主要是解決端口沖突問題,有需要的可以了解一下。
    2016-11-11

最新評論