私はwarbackファイルlibフォルダにログバックをデプロイしました。クラスフォルダに次のlogback.xmlがあります。 3行目のTomcat WAR - パスにアプリケーション名を使用するようにログバックを設定する
<?xml version="1.0" encoding="UTF-8" ?>
<configuration>
<property name="destination" value="${catalina.base:-./temp}/logs/${appName:-myapp}" />
<appender name="ROLLING" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${destination}.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- rollover daily -->
<fileNamePattern>${destination}-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<!-- Keep logs for 7 days -->
<maxHistory>7</maxHistory>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<!-- or whenever the file size reaches 100MB -->
<maxFileSize>100MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="error">
<appender-ref ref="ROLLING" />
</root>
</configuration>
私は私のログファイルのパスを作成し、いくつかの変数置換を有します。
<property name="destination" value="${catalina.base:-./temp}/logs/${appName:-myapp}" />
私が展開されて、それはそう${appName}
warファイルの現在の名前に評価したいです。
${destination}
プロパティが
.../logs/myapp
に評価されますと、myappに-dev.warが
.../logs/myapp-dev
に評価されますので、
webapps
- myapp.war
- myapp-dev.war
のように見えます。 JNDIプロパティまたはappNameにアクセスするためにアクセスできるものはありますか?
私は手動でロガーを再設定する必要はありません。
ありがとうございます!
私はこれを行う方法に気づいていません。 JULI(Tomcatの組み込みログ)の拡張要求があります:https://issues.apache.org/bugzilla/show_bug.cgi?id=43682 –
ここに、この問題の別の解決策に関するブログ記事があります:https ://0x0a14.de/adding-the-context-root-to-a-logback-config-file-path/ –