1. はじめに
現在Javaでシステムを構築しており、ログ関連ライブラリにslf4j + logbackを使用しています。今までログ関連ライブラリの仕様について調べてなかったことに気づき、調査をしていました。その際、「logback.xmlでJNDIを使用して値を取得し、変数に代入できる。」と記載があったが、具体的な設定方法がわからず詰まったため備忘録として作成します。
2. 環境
- OS:Windows10
- アプリケーションサーバ:glassfish-4.1.2
- logback(logback-classic):ver_1.2.3
- slf4j(slf4j-api):ver_1.7.25
3. やりたいこと
glassfishのCustom Resourceにアプリケーションログ出力先を設定する。
各アプリケーションは、Custom Resourceに設定したログ出力先を参照する。
4. glassfishの設定
「JNDI Name」にapplogfile/dirを入力し、「Resource Type」はjava.lang.Stringを選択する。
※ 「Factory Class」は「Resource Type」を選択した際に、自動的に設定されました。
5. logback.xmlの設定
logback.xmlにJNDIを使用する以下の内容を記載する。
<configuration debug="true">
<!--
JNDIを使用して設定した値を取得する箇所
env-entry-name:アプリケーションサーバに設定したJNDI Nameを指定する。
as:JNDI経由で取得した値を格納する変数名を指定する。
-->
<insertFromJNDI env-entry-name="applogfile/dir" as="logdir" />
<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<!--
変数を参照する箇所
-->
<file>${logdir}\\TEST.log</file>
<append>true</append>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="debug">
<appender-ref ref="FILE" />
</root>
</configuration>
6. 結果
・サンプルアプリケーションをglassfishにデプロイし、対象ディレクトリ(ここでは、B:\log)配下にTEST.logが出力されるかどうかを確認する。
・ログ出力内容を確認し、設定している内容が取得できているかどうかを確認する。
〇IDE(ここでは、NetBeans)のコンソールに出力した、ログ内容を確認
情報: 22:37:48,860 |-INFO in ch.qos.logback.classic.joran.action.InsertFromJNDIAction - Setting variable [logdir] to [B:\\log] in [LOCAL] scope
情報: 22:37:48,861 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - About to instantiate appender of type [ch.qos.logback.core.FileAppender]
情報: 22:37:48,869 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - Naming appender as [FILE]
情報: 22:37:48,881 |-INFO in ch.qos.logback.core.joran.action.NestedComplexPropertyIA - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property
情報: 22:37:48,942 |-INFO in ch.qos.logback.core.FileAppender[FILE] - File property is set to [B:\\log\\TEST.log]
7. 参考サイト
〇glassfish関連
https://docs.oracle.com/cd/E19798-01/821-1752/giytz/index.html
〇logback関連
https://logback.qos.ch/manual/configuration_ja.html