WARファイルのlibフォルダーにlogbackをデプロイし、classesフォルダーに次のlogback.xmlを作成しました。
<?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>
3行目には、ログファイルのパスを作成するいくつかの変数置換があります。
<property name="destination" value="${catalina.base:-./temp}/logs/${appName:-myapp}" />
${appName}
デプロイされたwarファイルの現在の名前に評価されるようにしたいと思います。
だから私のウェブアプリフォルダがそうだったら
webapps
- myapp.war
- myapp-dev.war
myapp.warの${destination}
プロパティはに評価され.../logs/myapp
、myapp-dev.warはに評価され.../logs/myapp-dev
ます。appNameにアクセスするためにアクセスできるJNDIプロパティまたは何かがありますか?
ロガーを手動で再構成する必要はありません。
ありがとう!