log 4 jログファイルサーブレットコンテナにおけるファイル位置の一般的な書き方

1270 ワード

アプリケーションをJettyの下に移動すると、発生したログファイルの位置に問題がある(デフォルトで閉じられている)ことが判明し、その後、log 4 jで確認する.propertiesでの使用
${catalina.base}

もちろんjettyではこの変数は認識されず、似たような変数があります.
${Jetty.base}
しかし、このように設定すれば、将来tomcatに適用されるか、WebLogicなどの他のコンテナでは使用できない場合、プロファイルが様々なサーブレットコンテナで使用できるようにするにはどうすればいいのでしょうか.
実は簡単です.logs/下に構成するだけでいいです.以下は簡略化された構成です.
#  Logging level
app.log=logs/
log4j.rootLogger=debug, file, CONSOLE


log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender


log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%-4r [%t] %-5p %c %x \u2013 %m%n


#- size rotation with log cleanup.
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.MaxFileSize=64MB
log4j.appender.file.MaxBackupIndex=9


#- File to log to and log format
log4j.appender.file.File=${app.log}/app.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%-5p - %d{yyyy-MM-dd HH:mm:ss.SSS}; %C; %m
log4j.logger.org.apache.zookeeper=WARN log4j.logger.org.apache.hadoop=WARN # set to INFO to enable infostream log messages log4j.logger.org.apache.solr.update.LoggingInfoStream=OFF