あなたの例のおかげで、さまざまなロガー出力をさまざまなファイルにルーティングするロガー名ベースの識別子のソリューションを実装しました。logback のドキュメントは非常に冗長ですが、この重要な情報を見つけることができませんでした。yayitswei が言及した解決策はすでに見つかっているはずです。
logback.xml:
[...]
<timestamp key="startTimestamp" datePattern="yyyy-MM-dd"/>
<timestamp key="folderTimestamp" datePattern="MM-yyyy"/>
<property name="LOGDIR" value="/var/log/spock" />
<appender name="SIFT" class="ch.qos.logback.classic.sift.SiftingAppender">
<discriminator class="com.enterprise.spock.LoggerNameBasedDiscriminator" />
<sift>
<appender name="FILE-${loggerName}" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOGDIR}/${loggerName}-${startTimestamp}.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOGDIR}/${folderTimestamp}/${loggerName}-%d{yyyy-MM-dd}-%i.log.gz</fileNamePattern>
<maxFileSize>500KB</maxFileSize>
<maxHistory>100</maxHistory>
<totalSizeCap>50MB</totalSizeCap>
</rollingPolicy>
<encoder>
<charset>UTF-8</charset>
<pattern>%level %date{HH:mm:ss.SSS}: %msg %n</pattern>
</encoder>
</appender>
</sift>
</appender>
[...]
編集:ここで提案されているように、TimeBasedRollingPolicy を SizeAndTimeBasedRollingPolicy に置き換えました。そのためには、少なくとも logback 1.1.7 が必要です。
これで得られるのは、作成された各ロガーのログファイルです。すべてのログファイルは /var/log/loggername-2017-08-03.log のようになります。
ファイルに約 500KB が書き込まれると、gz-zipfile として /var/log/loggername/08-2017/loggername-2017-08-03-0.log.gz にアーカイブされます。
gz-zipfile-name の末尾の 0 は%i
上記のもの<fileNamePattern>
です。がない%i
と機能しません。<configuration debug=true>
何かが機能しない場合は、logback.xml で使用することを忘れないでください。