国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > Linux Shell > 正文

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

2020-07-27 18:58:27
字體:
供稿:網(wǎng)友

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

一、場景和需求

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

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

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

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

log4j.rootLogger = infolog4j.debug = falselog4j.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 filelog4j.additivity.com.chuanliu.platform.activity.platform.activity = falselog4j.category.com.chuanliu.platform.activity.solr = info, solrlog4j.additivity.com.chuanliu.platform.activity.platform.activity.solr = false###### activity full log: contains all of the log #####fulllog4j.appender.full = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.full.File = ${LogFile.Location}/full.loglog4j.appender.full.DatePattern = '.'yyyy-MM-ddlog4j.appender.full.layout = org.apache.log4j.PatternLayoutlog4j.appender.full.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%nlog4j.appender.full.ImmediateFlush = truelog4j.appender.full.append = true######activity full log ##########activity solr log : only contain the log in searcher#####solrlog4j.appender.solr = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.solr.File = ${LogFile.Location}/solr.loglog4j.appender.solr.DatePattern = '.'yyyy-MM-ddlog4j.appender.solr.layout = org.apache.log4j.PatternLayoutlog4j.appender.solr.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%nlog4j.appender.solr.ImmediateFlush = truelog4j.appender.solr.append = true######activity solr log ##### Console output...log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=[%d][%p]%t: %m%n# log sql for mybatis log4j.logger.mybatis =TRACEorg.springframework.web=debug 

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

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

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

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

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

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

以上這篇Log4j 日志文件Linux/Mac/Windows通用存放位置設(shè)置方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 缙云县| 德惠市| 和静县| 曲阳县| 肃南| 辽阳县| 永吉县| 浦江县| 绥棱县| 彭山县| 诸城市| 望奎县| 香河县| 都昌县| 邵东县| 黑龙江省| 海晏县| 哈巴河县| 调兵山市| 筠连县| 彰武县| 安岳县| 韶山市| 贵南县| 深水埗区| 威宁| 南宫市| 九龙县| 抚顺市| 德兴市| 平乐县| 永善县| 建水县| 即墨市| 梅州市| 宿州市| 巧家县| 疏勒县| 钟祥市| 晋宁县| 保定市|