JavaWeb的各種Log

作為一個(gè)有追求的程序猿驳概,你了解你見到的各種日志嗎杆麸?JDK的日志、Tomcat的日志沥阱、還有Logback的日志整胃,他們之間只什么關(guān)系?

一喳钟、JavaWeb中的各種log

  1. JDK原生日志API
    • JDK中內(nèi)置了原生的日志打印的API:java.util.logging.Logger,這個(gè)API不依賴于任何的第三方框架在岂,是JDK內(nèi)置的
    • 這個(gè)Logger的級別: SEVERE → WARNING → INFO → CONFIG → FINE → FINER → FINESET
    • 用法如下:
      private Logger logger = Logger.getLogger("<class-name>");
      logger.severe("<severe-msg>");
      logger.warning("<warning-msg>");
      logger.info("<info-msg>");
      logger.config("<config-msg>");
      logger.fine("<fine-msg>");
      logger.finer("<finer-msg>");
      logger.finest("<finest-msg>");
      
    • JDK日志配置
      • 默認(rèn)情況下奔则,日志的輸出都是在控制臺(tái)直接輸出的,并沒有輸出到文件中蔽午,這是因?yàn)樵贘RE默認(rèn)配置中易茬,只配置了一個(gè)ConsoleHandler,這個(gè)配置文件位于<jre-home>/lib/logging.properties及老,注意一般情況下我在安裝JDK的時(shí)候是不會(huì)安裝公共JRE的抽莱,因?yàn)镴DK中就已經(jīng)安裝過了,不過最新的JDK貌似已經(jīng)把二者分開了骄恶,總之食铐,根據(jù)自己的情況找到JRE的家目錄,即可找到該文件僧鲁;
      • logging.properties這個(gè)文件中有個(gè)handlers虐呻,其值只有一個(gè)handlers= java.util.logging.ConsoleHandler,如果想要同時(shí)輸出到文件中寞秃, 只需要在后面追加java.util.logging.FileHandler斟叼,多個(gè)handler之間使用英文都好隔開即可;
      • 在增加了FileHanlder之后春寿,那么FileHanlder的各種配置就生效了朗涩,就可以根據(jù)需要進(jìn)行配置了,如:
        java.util.logging.FileHandler.pattern = %h/java%u.log
        java.util.logging.FileHandler.limit = 50000
        java.util.logging.FileHandler.count = 1
        java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter
        
        1. FileHandler.pattern:用來指定生成的日志文件的路徑名稱绑改;/:本地路徑名分隔符谢床;%t:系統(tǒng)臨時(shí)目錄兄一;%h:"user.home" 系統(tǒng)屬性的值;%g:區(qū)分循環(huán)日志的生成號(hào)萤悴;%u:解決沖突的惟一號(hào)碼瘾腰;%%:轉(zhuǎn)換為單個(gè)百分?jǐn)?shù)符號(hào)"%" ;
        2. FileHandler.limit:用來限制文件的大小覆履,以字節(jié)為單位蹋盆,0表示沒有限制;
        3. FileHandler.count:指定有多少輸出文件參與循環(huán)(默認(rèn)為1)硝全;
        4. FileHandler.formatter:指定要使用的 Formatter 類的名稱(默認(rèn)為java.util.logging.XMLFormatter)栖雾。 另外一個(gè)是:java.util.logging.SimpleFormatter。XMLFormatter是以xml樣式輸出伟众,SimpleFormatter是以普通樣式輸出析藕。
        5. FileHandler.append:指定是否應(yīng)該將 FileHandler 追加到任何現(xiàn)有文件上(默認(rèn)為false);
        6. SimpleFormatter.format:用來自定義SimpleFormatter的輸出樣式凳厢;如:%4$s: %5$s [%1$tc]%n账胧,即輸出樣式為:<level>: <log message> [<date/time>]
      • 日志打印級別的配置:
        1. 全局輸出級別設(shè)置
          [java.util.logging.ConsoleHandler/FileHandler].level=<level-name>
          
        2. 具體包名的輸出級別設(shè)置
          <package-name>.level=<level-name>
          
  2. Tomcat的API
    • Tomcat是Apache的一個(gè)開源項(xiàng)目,Apache旗下還有一個(gè)開源項(xiàng)目先紫,名為Apache common logging治泥,而Tomcat中的日志框架juli正是這個(gè)開源框架的一個(gè)易名項(xiàng)目,究其根源來說遮精,Apache common logging是對JDK打印API的修改封裝居夹;
    • 為了不影響JDK中的Logger的正常使用,Tomcat中增加了自定義的Log配置本冲,這個(gè)配置存在于Tomcat的腳本catalina.bat和catalina.sh中准脂,如下:
      LOGGING_CONFIG="-Djava.util.logging.config.file=$CATALINA_BASE/conf/logging.properties"
      LOGGING_MANAGER="-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager"
      
      • 這兩個(gè)參數(shù)配置給java虛擬機(jī)配置了兩個(gè)東東, 一個(gè)是日志的配置文件還有一個(gè)日志管理器;
    • 在這個(gè)配置文件中檬洞,我們發(fā)現(xiàn)默認(rèn)情況下狸膏,Tomcat支持文件和控制臺(tái)兩種輸出方式;還有就是Tomcat的handler都帶有一個(gè)數(shù)字前綴添怔,自然就想到如果使用系統(tǒng)默認(rèn)的類加載器的話环戈,肯定會(huì)出錯(cuò),Tomcat使用的是自定義的ClassLoader來解析這個(gè)數(shù)字前綴澎灸;而增加數(shù)字前綴的目的就是為了使得一個(gè)類模板生成多個(gè)實(shí)例院塞,每個(gè)實(shí)例都管理一種類型的日志,如:
      • 前綴1對應(yīng)的日志:文件名以catalina.開頭
      • 前綴2對應(yīng)的日志:文件名以localhost.開頭
      • 前綴3對應(yīng)的日志:文件名以manager.開頭
      • 前綴4對應(yīng)的日志:文件名以host-manager.開頭
    • Tomcat與JDK日志的配置
      • 有一點(diǎn)不同性昭,JRE的logging.properties文件中使用handlers配置輸出途徑拦止,而在Tomcat中使用.handlers配置,使用handlers配置上面4中不同的文件日志
      • Tomcat的詳細(xì)配置可查看:http://tomcat.apache.org/tomcat-8.0-doc/config [/valve.html]
  3. Logback的API(Log4j)
    • 提起這個(gè)日志框架,就不得不提起另外另個(gè)東東:slf4j和log4j汹族,這三個(gè)框架(?)什么關(guān)系呢萧求?網(wǎng)上找到一張圖:


      slf4j & log4j & logging
    • slf4j的全稱是:The Simple Logging Facade for(4) Java,即slf4j是一個(gè)門面顶瞒,而log4j和logback則是這些接口的實(shí)現(xiàn)夸政;log4j和logback是由同一個(gè)人完成的,前者是apache實(shí)現(xiàn)的榴徐,logback是為了替代log4j守问,logback可以說是slf4j的原生實(shí)現(xiàn),目前除了老的項(xiàng)目坑资,新項(xiàng)目的日志基本上都是使用logback耗帕;
      • logback是直接實(shí)現(xiàn)了slf4j的接口,不消耗內(nèi)存和計(jì)算開銷的袱贮。slf4j的api在調(diào)用log4j時(shí)需要一個(gè)適配層仿便;
      • log4j和logback可以單獨(dú)的使用,也可以綁定slf4j一起使用:單獨(dú)使用的時(shí)候攒巍,分別調(diào)用框架自己的方法來輸出日志信息嗽仪;綁定slf4j一起使用,調(diào)用slf4j的api來輸入日志信息柒莉,具體使用與底層日志框架無關(guān)闻坚,但是需要底層框架的配置文件;
    • 其實(shí)說到這里就能發(fā)現(xiàn)這個(gè)門面扮演什么角色常柄,其實(shí)就是為了解決眾口難調(diào)的問題,因?yàn)轫?xiàng)目中我們用到很多的框架搀擂,如果每個(gè)框架都有自己的日志輸出框架西潘,難么項(xiàng)目中的日志維護(hù)便成了一個(gè)大問題,為了解決這個(gè)大問題哨颂,log4j和logback框架橫空出世:我們項(xiàng)目中的所有框架的日志輸出都交給slf4j喷市,然后統(tǒng)一對消息進(jìn)行處理;

文章中還有很多可以深入的地方,如果需要,后面繼續(xù)更新
文章參考:Tomcat的Logging威恼、slf4j log4j logback關(guān)系詳解和相關(guān)用法品姓、為什么要使用SLF4J而不是Log4J從Log4j遷移到LogBack的理由

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末箫措,一起剝皮案震驚了整個(gè)濱河市腹备,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌斤蔓,老刑警劉巖植酥,帶你破解...
    沈念sama閱讀 222,681評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡友驮,警方通過查閱死者的電腦和手機(jī)漂羊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來卸留,“玉大人走越,你說我怎么就攤上這事〕苌” “怎么了旨指?”我有些...
    開封第一講書人閱讀 169,421評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長匆赃。 經(jīng)常有香客問我淤毛,道長,這世上最難降的妖魔是什么算柳? 我笑而不...
    開封第一講書人閱讀 60,114評論 1 300
  • 正文 為了忘掉前任低淡,我火速辦了婚禮,結(jié)果婚禮上瞬项,老公的妹妹穿的比我還像新娘蔗蹋。我一直安慰自己,他們只是感情好囱淋,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,116評論 6 398
  • 文/花漫 我一把揭開白布猪杭。 她就那樣靜靜地躺著,像睡著了一般妥衣。 火紅的嫁衣襯著肌膚如雪皂吮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,713評論 1 312
  • 那天税手,我揣著相機(jī)與錄音蜂筹,去河邊找鬼。 笑死芦倒,一個(gè)胖子當(dāng)著我的面吹牛艺挪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播兵扬,決...
    沈念sama閱讀 41,170評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼麻裳,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了器钟?” 一聲冷哼從身側(cè)響起津坑,我...
    開封第一講書人閱讀 40,116評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎傲霸,沒想到半個(gè)月后国瓮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,651評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,714評論 3 342
  • 正文 我和宋清朗相戀三年乃摹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了禁漓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,865評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡孵睬,死狀恐怖播歼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情掰读,我是刑警寧澤秘狞,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站蹈集,受9級特大地震影響烁试,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜拢肆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,211評論 3 336
  • 文/蒙蒙 一减响、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧郭怪,春花似錦支示、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,699評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至攒庵,卻和暖如春嘴纺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背浓冒。 一陣腳步聲響...
    開封第一講書人閱讀 33,814評論 1 274
  • 我被黑心中介騙來泰國打工栽渴, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人裆蒸。 一個(gè)月前我還...
    沈念sama閱讀 49,299評論 3 379
  • 正文 我出身青樓熔萧,卻偏偏與公主長得像糖驴,于是被迫代替她去往敵國和親僚祷。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,870評論 2 361

推薦閱讀更多精彩內(nèi)容

  • /Library/Java/JavaVirtualMachines/jdk-9.jdk/Contents/Home...
    光劍書架上的書閱讀 3,893評論 2 8
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理贮缕,服務(wù)發(fā)現(xiàn)辙谜,斷路器,智...
    卡卡羅2017閱讀 134,716評論 18 139
  • From:Python之日志處理(logging模塊) - 云游道士 - 博客園 https://www.cnbl...
    vigny的先生閱讀 2,691評論 3 5
  • 作為Java開發(fā)人員感昼,對于日志記錄框架一定非常熟悉装哆。而且?guī)缀踉谒袘?yīng)用里面,一定會(huì)用到各種各樣的日志框架用來記錄程...
    意識(shí)流丶閱讀 13,934評論 0 13
  • 有文章中說“男生不可不讀王小波,女生不可不讀周國平”蜕琴,也有人反駁“這是對王二最大的侮辱”萍桌,加之朋友最近推薦讀周國平...
    elvaLi_未知閱讀 260評論 0 1