4
在Logback中,我們可以配置爲:1當日志文件的大小達到50MB時,旋轉文件並對其進行壓縮。所以我想知道它會在一個單獨的線程中執行壓縮的東西,它會有任何性能問題?在Logback中壓縮日誌文件的單獨線程?
在Logback中,我們可以配置爲:1當日志文件的大小達到50MB時,旋轉文件並對其進行壓縮。所以我想知道它會在一個單獨的線程中執行壓縮的東西,它會有任何性能問題?在Logback中壓縮日誌文件的單獨線程?
我調查了logback-1.0.3。 讓我們考慮用例:
正如你所看到的,所有東西都將被記錄並壓縮在與記錄數據相同的線程中。因此你不應該登錄時間關鍵的線程。我個人認爲,登錄同一個線程對於大多數應用程序來說並不重要,但它很大程度上取決於你的環境,性能要求,e.t.c。
如果要異步記錄數據,可以使用AsyncAppender。在這種情況下,壓縮也將在單獨的線程中。
也許在同一個線程中調用compress方法的可能解決方案之一就是使用一個異步appender ... – 2013-02-18 11:23:52
@AdamDyga你是對的。這是這個問題的法律解決方法。 – Taky 2013-02-18 11:45:34
logback doc說異步appender使用固定大小的阻塞隊列,並且如果隊列開始填滿(壓縮大文件時可能會發生),則會在INFO級別和以下級別放置消息(您可以調整或禁用此選項)。如果隊列一直填滿,調用線程會阻塞,所以行爲會再次實現有效同步。您可能能夠調整隊列大小和文件大小以避免這種情況。 – 2015-09-03 18:05:21