異なるメッセージを2つのファイルに記録するLogback


146

ロギングを行うためにlogback / slf4jを使用しています。ログファイルを解析して一部のデータを分析したいので、大きなファイル(ほとんどがデバッグステートメントで構成されている)を解析する代わりに、それぞれが別のファイルにログを記録する2つのロガーインスタンスが必要です。1つは分析用、もう1つは多目的ロギング用です。これがLogbackや他のロガーで可能かどうか誰かが知っていますか?

回答:


296

logbackでこのようなことをすることは非常に可能です。次に設定例を示します。

<?xml version="1.0"?>
<configuration>
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <file>logfile.log</file>
        <append>true</append>
        <encoder>
            <pattern>%-4relative [%thread] %-5level %logger{35} - %msg %n</pattern>
        </encoder>
    </appender>
    <appender name="ANALYTICS-FILE" class="ch.qos.logback.core.FileAppender">
        <file>analytics.log</file>
        <append>true</append>
        <encoder>
            <pattern>%-4relative [%thread] %-5level %logger{35} - %msg %n</pattern>
        </encoder>
    </appender>
    <!-- additivity=false ensures analytics data only goes to the analytics log -->
    <logger name="analytics" level="DEBUG" additivity="false">
        <appender-ref ref="ANALYTICS-FILE"/>
    </logger>
    <root>
        <appender-ref ref="FILE"/>
    </root>
</configuration>

次に、2つのロガーをセットアップします。1つはすべてのもので、もう1つは次のように分析データをログに記録します。

Logger analytics = LoggerFactory.getLogger("analytics");

1
このようなことを行う必要があるので、同じファイルに改行なしのアペンダーと通常のアペンダーを付けることができます。この情報をありがとう。
djangofan 2013年

別のappender-refが指定されている場合、IMO additivity = falseをデフォルトにする必要があります。非常に頻繁に、いくつかのモジュールがいくつかのタイマーイベントのために非常に頻繁なログジェネレータになるアプリケーションを取得します。これらのログを異なるファイルに分離したいと考えています。10個の異なるファイルに同じログを記録しても、意味がありません。したがって、デフォルトではなくオプトイン機能にする必要があります。ログバックは書き直しだったので、同じ間違いが同じ作者によって修正されているはずです。
samarjit samanta 2015

エラー、デバッグ、情報メッセージをそれぞれ別のファイルに記録したい。logback.xmlで可能ですか
Qasim

@カシム-それは可能です。参照してください- amitstechblog.wordpress.com/2014/09/27/...
アンディDufresne

この回答が示唆するように、異なるパッケージから異なるファイルにログを記録しようとしていますが、それは私にとってはうまくいきません。マイlogbackのXML抽出物はここにある- pastebin.com/Aii4f1Jk。hibernateパッケージのTRACEレベルのログを別のファイルに記録しようとしています。助言がありますか?
アンディDufresne

7

ロガーはいくつでも持つことができます。ただし、異なる方法でログを記録する必要があるパッケージごとに1つ用意する方がよいでしょう。次に、そのパッケージとそのサブパッケージ内のすべてのクラスは、その特定のロガーを取得します。それらはすべて、ルートロガーを共有し、additivity = "true"を使用してログデータをルートロガーアペンダーに送信できます。次に例を示します。

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

<property name="pattern" value="%date{HH:mm:ss.SSS} %-5p %logger{36} 
%X{akkaSource} [%file:%line] - %m%n" />

<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%date{HH:mm:ss.SSS} %-5p %logger{36} %X{akkaSource} [%file:%line] - %m%n</pattern>
    </encoder>
</appender>

<appender name="abc" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${catalina.base}/logs/worker.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>${catalina.base}/logs/worker-%d{yyyy-MM-dd_HH}.log</fileNamePattern>
        <maxHistory>360</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>${pattern}</pattern>
    </encoder>
</appender>

<appender name="xyz" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${catalina.base}/logs/transformer.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>${catalina.base}/logs/transformer-%d{yyyy-MM-dd_HH}.log</fileNamePattern>
        <maxHistory>360</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>${pattern}</pattern>
    </encoder>
</appender>

<logger name="com.xxx.yyy.zzz" level="INFO" additivity="true">
    <appender-ref ref="xyz"/>
</logger>

<logger name="com.aaa.bbb.ccc" level="INFO" additivity="true">
    <appender-ref ref="abc"/>
</logger>

<root>
    <level value="INFO" />
    <appender-ref ref="STDOUT" />
</root>


2

私の場合、クラス名をログ名のままにしたかった

private static final Logger log = LoggerFactory.getLogger(ScheduledPost.class);

そのようなクラスはほとんどなかったので、 logback.xml

<!--additivity=false ensures this log data only goes to the this log, and no one more -->
<logger name="xxx.xxx.xxx.ScheduledPost" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
<logger name="xxx.xxx.xxx.GcmPost" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
<logger name="xxx.xxx.xxx.PushUtils" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.