2012-07-17 125 views
1

我已經啓用了Jetty Access生產日誌,事情進展順利,直到今天。今天,訪問日誌似乎不再需要數據,即使服務本身沒有運行。我懷疑有些事情我不明白「retainDays」屬性。下面是從等/,設置了日誌摘錄的jetty.xml ...jetty access.log不再記錄

<!-- Built-in Jetty AccessLog log --> 
<Ref id="AccessLog"> 
    <Set name="requestLog"> 
    <New id="RequestLogImpl" class="org.eclipse.jetty.server.NCSARequestLog"> 
     <Arg><SystemProperty name="jetty.logs" default="/data/logs"/>/dm-app1_access.log</Arg> 
     <Set name="retainDays">7</Set> 
     <Set name="append">true</Set> 
     <Set name="extended">false</Set> 
     <Set name="logLatency">true</Set> 
     <Set name="LogTimeZone">GMT</Set> 
    </New> 
    </Set> 
</Ref> 

爲什麼看似登錄時停止這小子打RETAINDAYS價值?我期望它只是截斷並繼續登錄到/data/logs/dm-app1_access.log。

+0

這是一種Jetty文檔失敗。 http://wiki.eclipse.org/Jetty/Tutorial/RequestLog沒有明確retainDays和「yyyy_mm_dd」之間的關係。如果您閱讀了NCSARequestLog.java和RolloverFileOutputStream的JavaDoc的源代碼,就會發現字符串「yyyy_mm_dd」需要獲取像rollover一樣的內容。看起來你完全可以改變它。啊。 – 2012-07-17 19:10:49

+0

我們就如何改善這兩種情況提出了補丁和建議:) – 2012-07-17 19:24:04

+0

我的建議是該訪問日誌應該與logback的RollingFileAppender完全相同。這將允許我尾巴固定的文件名和記錄機制將處理翻轉。花了4個小時,源代碼深入瞭解,'yyyy_mm_dd'僅僅是RolloverFileOutputStream.setFile()中應用的實際SimpleDateFormat值的佔位符。最不驚奇的原則是,這次冒險不是。 – 2012-07-18 17:57:15

回答

1

由於我的文件名不包含「yyyy_mm_dd」佔位符,停止記錄。中的配置工作完成一個日誌文件的命名格式相似,我們如何有我們的logback RollingFileAppenders會像...

<!-- Built-in Jetty AccessLog log --> 
<Ref id="AccessLog"> 
    <Set name="requestLog"> 
    <New id="RequestLogImpl" class="org.eclipse.jetty.server.NCSARequestLog"> 
     <Set name="filename"><SystemProperty name="jetty.logs" default="./logs"/>/access.yyyy_mm_dd.log</Set> 
     <Set name="filenameDateFormat">yyyyMMdd</Set> 
     <Set name="retainDays">3</Set> 
     <Set name="append">true</Set> 
     <Set name="extended">false</Set> 
     <Set name="logLatency">true</Set> 
     <Set name="LogTimeZone">GMT</Set> 
    </New> 
    </Set> 
</Ref> 

...這得到像日誌/ access.20120718.log創建的訪問日誌文件。當我發現「文件名」屬性中的'yyyy_mm_dd'只是「filenameDateFormat」屬性中包含的實際SimpleDateFormat的佔位符時,這個重要的學習時刻就來臨了。

+0

三人爲自己的回答歡呼,儘管它沒有幫助我:) – 2017-05-09 22:17:36