亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Log4j 日志文件Linux/Mac/Windows通用存放位置設(shè)置方法

 更新時(shí)間:2017年01月23日 10:56:24   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇Log4j 日志文件Linux/Mac/Windows通用存放位置設(shè)置方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

log4j1/log4j2中category的配置以及l(fā)og的輸出位置(windows和linux通用的log輸出位置)

一、場(chǎng)景和需求

假設(shè)我現(xiàn)在有3個(gè)獨(dú)立的用project(暫時(shí)用maven關(guān)聯(lián)起來(lái),當(dāng)然也可以不用maven),一個(gè)是提供公共服務(wù)的infrastructure,一個(gè)是提供存儲(chǔ)的persister,一個(gè)是提供搜索的searcher,其中提供基礎(chǔ)服務(wù)的所有的類,例如DateUtils,HttpUtils等工具類都位于目錄com.chuanliu.platform.activity下,而提供存儲(chǔ)服務(wù)的所有類都位于com.chuanliu.platform.activity.persist目錄下,提供搜索服務(wù)的所有類都位于com.chuanliu.platform.activity.solr下。

現(xiàn)在項(xiàng)目的需求是有一個(gè)log文件叫full.log,需要記錄所有的日志,不管是infrastructure下的,還是persister下的,還是seracher下的,另外還需要一個(gè)日志文件叫solr.log,記錄所有發(fā)生在搜索目錄下的日志。當(dāng)然將來(lái)還應(yīng)該將searcher目錄下的日志放在searcer.log中。

除此之外還應(yīng)該支持根據(jù)不同的部署環(huán)境設(shè)置不同的log輸出位置,因?yàn)閣indows和linux具有不同的目錄結(jié)構(gòu)。

二、無(wú)論是log4j1還是log4j2中,都可以使用如下配置:

log4j.rootLogger = info
log4j.debug = false

log4j.category.com.chuanliu.platform.activity = info, full, stdout
#The child logger appender will not inherit the parent logger's appender, or the logs will be output twice in the file
log4j.additivity.com.chuanliu.platform.activity.platform.activity = false

log4j.category.com.chuanliu.platform.activity.solr = info, solr
log4j.additivity.com.chuanliu.platform.activity.platform.activity.solr = false

###### activity full log: contains all of the log ####
#full
log4j.appender.full = org.apache.log4j.DailyRollingFileAppender
log4j.appender.full.File = ${LogFile.Location}/full.log
log4j.appender.full.DatePattern = '.'yyyy-MM-dd
log4j.appender.full.layout = org.apache.log4j.PatternLayout
log4j.appender.full.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%n
log4j.appender.full.ImmediateFlush = true
log4j.appender.full.append = true

######activity full log ####

######activity solr log : only contain the log in searcher####
#solr
log4j.appender.solr = org.apache.log4j.DailyRollingFileAppender
log4j.appender.solr.File = ${LogFile.Location}/solr.log
log4j.appender.solr.DatePattern = '.'yyyy-MM-dd
log4j.appender.solr.layout = org.apache.log4j.PatternLayout
log4j.appender.solr.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%n
log4j.appender.solr.ImmediateFlush = true
log4j.appender.solr.append = true
######activity solr log ####

# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d][%p]%t: %m%n

# log sql for mybatis 
log4j.logger.mybatis =TRACE


org.springframework.web=debug 

這樣經(jīng)過(guò)測(cè)試,你會(huì)發(fā)現(xiàn),所有的log都進(jìn)入了full.log中,而只有com.chuanliu.platform.activity.solr下的日志輸出進(jìn)入了solr.log.

另外對(duì)于日志的輸出位置, ${LogFile.Location},我們可以在不同環(huán)境的配置文件中自定義LogFile.Location的值,比如在代表本地環(huán)境的dev.properties中,定義LogFile.Location=C://logs

代表測(cè)試環(huán)境的qa.properties中,定義LogFile.Location=/usr/local/var/logs,同樣在生產(chǎn)環(huán)境中定義相同的值為:LogFile.Location=/usr/local/var/logs,這樣在不同環(huán)境下就會(huì)在不同路徑下生成不同的log文件。

其實(shí),經(jīng)過(guò)測(cè)試后,沒(méi)有這么麻煩,我們可以統(tǒng)一將windows和linux的log輸出配置到同一個(gè)地方,即上面我們可以統(tǒng)一的將輸出設(shè)置為/usr/local/var/logs,這樣的設(shè)置在linux中,大家都能理解,但在windows中,可能不是那么好理解,在windows中,/usr/local/var/log有2層含義:

1、如果是在eclipse中執(zhí)行這些日志輸出的類的方法,那么將在workspace所在的磁盤(pán),例如E盤(pán)中創(chuàng)建目錄/usr/local/var/log,并輸出full.log和solr.log.

2、如果是在tomcat中應(yīng)用執(zhí)行日志的輸出,那邊就是在tomcat所在的磁盤(pán)中,例如D盤(pán)中創(chuàng)建目錄/usr/local/var/log,并輸出full.log和solr.log,即便是在eclipse中啟動(dòng)tomcat,這時(shí)tomcat的wtpapps目錄是在eclipse所在的目錄,如E盤(pán)中,但是真正使用的tomcat是在D盤(pán)中的,那么同樣是在/usr/local/var/logs中輸出如上的日志文件。

以上這篇Log4j 日志文件Linux/Mac/Windows通用存放位置設(shè)置方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • shell腳本使用兩個(gè)橫杠接收外部參數(shù)的方法

    shell腳本使用兩個(gè)橫杠接收外部參數(shù)的方法

    這篇文章主要介紹了shell腳本使用兩個(gè)橫杠接收外部參數(shù)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • 三分鐘學(xué)會(huì)Linux基本指令

    三分鐘學(xué)會(huì)Linux基本指令

    本文小馬將把Linux一般比較常見(jiàn)的指令給大家一一列舉出來(lái),為了大家忘記某些指令后,可以方便查詢記憶,再次小馬建議,Linux指令并不需要去特別花時(shí)間專門(mén)記憶,只需要多進(jìn)行操作實(shí)現(xiàn)就行,這篇文章主要介紹了Linux基本指令,需要的朋友可以參考下
    2022-12-12
  • 使用bash shell刪除目錄中的特定文件的3種方法

    使用bash shell刪除目錄中的特定文件的3種方法

    這篇文章主要介紹了使用bash shell刪除目錄中的特定文件的3種方法,分別為擴(kuò)展模式匹配符、GLOBIGNORE 變量和find 命令,需要的朋友可以參考下
    2014-06-06
  • 一天一個(gè)shell命令 linux文本內(nèi)容操作系列-grep命令詳解

    一天一個(gè)shell命令 linux文本內(nèi)容操作系列-grep命令詳解

    這篇文章主要介紹了一天一個(gè)shell命令 linux文本內(nèi)容操作系列-grep命令詳解 ,需要的朋友可以參考下
    2016-06-06
  • 兩個(gè)備份數(shù)據(jù)庫(kù)的shell腳本

    兩個(gè)備份數(shù)據(jù)庫(kù)的shell腳本

    這篇文章主要是分享兩個(gè)備份數(shù)據(jù)庫(kù)的shell腳本,需要的朋友可以參考下,功能略有不同
    2013-02-02
  • Shell常用操作符總結(jié)

    Shell常用操作符總結(jié)

    這篇文章主要介紹了Shell常用操作符總結(jié),本文講解了算術(shù)操作 符、關(guān)系操作符、測(cè)試操作符等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • shell腳本怎樣判斷文件是否存在

    shell腳本怎樣判斷文件是否存在

    這篇文章主要介紹了shell腳本怎樣判斷文件是否存在問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • shell中函數(shù)的應(yīng)用

    shell中函數(shù)的應(yīng)用

    今天這個(gè)腳本其實(shí)很簡(jiǎn)單,但很實(shí)用,講的是shell中函數(shù)的應(yīng)用,需要的朋友可以參考下
    2016-08-08
  • bash shell中的if-then語(yǔ)句

    bash shell中的if-then語(yǔ)句

    bash shell的 if 語(yǔ)句會(huì)運(yùn)行 if 后面的那個(gè)命令,如果該命令的退出狀態(tài)碼是0,位于 then 部分的命令就會(huì)被執(zhí)行,這篇文章主要介紹了bash shell中的if-then語(yǔ)句,需要的朋友可以參考下
    2023-12-12
  • Linux內(nèi)核鏈表實(shí)現(xiàn)過(guò)程

    Linux內(nèi)核鏈表實(shí)現(xiàn)過(guò)程

    本文講解Linux內(nèi)核鏈表實(shí)現(xiàn)的過(guò)程,說(shuō)了鏈表的定義及初始化宏定義、操作和刪除操作等內(nèi)容,詳細(xì)看下面
    2013-11-11

最新評(píng)論