Azure SDK for Java と Logback によるログ

この記事では、Logback を使用したログを、Azure SDK for Java を使用するアプリケーションに追加する方法の概要について説明します。 「Azure SDK for Java でログを構成する」で説明されているように、すべての Azure クライアント ライブラリが SLF4J を通じてログするため、Logback などのログ記録フレームワークを使用できます。

Logback のログを有効にするには、2 つのことを行う必要があります。

  1. Logback ライブラリを依存関係として含めます。
  2. /src/main/resources プロジェクト ディレクトリに logback.xml というファイルを作成します。

Logback の構成に関する詳細については、Logback のドキュメントの「logbackの設定」を参照してください。

Maven の依存関係を追加する

Maven の依存関係を追加するには、プロジェクトの pom.xml ファイルに次の XML を含めます。 1.2.3 バージョン番号は Logback Classic Module ページに示されている最新のリリース バージョン番号に置き換えてください。

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>

プロジェクトに logback.xml を追加する

Logback は、よく使用されるログ記録フレームワークの 1 つです。 Logback のログを有効にするには、プロジェクトの ./src/main/resources ディレクトリに logback.xml というファイルを作成します。 このファイルには、ログ記録のニーズをカスタマイズするためのログ記録構成が含まれます。 logback.xml の構成に関する詳細については、Logback のドキュメントの「logbackの設定」を参照してください。

[コンソールのログ記録]

次の例に示すように、コンソールにログする Logback 構成を作成できます。 この例は、INFO レベル以上であるログ イベントをすべてその発生元に関係なくログするように構成されています。

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <layout class="ch.qos.logback.classic.PatternLayout">
      <Pattern>
        %black(%d{ISO8601}) %highlight(%-5level) [%blue(%t)] %blue(%logger{100}): %msg%n%throwable
      </Pattern>
    </layout>
  </appender>

  <root level="INFO">
    <appender-ref ref="STDOUT" />
  </root>
</configuration>

Azure コアのエラーをログする

次の構成例は、前述の構成に似ていますが、すべての com.azure.core パッケージ化クラス (サブパッケージを含む) からログが発生するレベルを下げています。 この方法では、INFO レベル以上のものがすべてログされます。ただし、com.azure.core については ERROR レベル以上のものだけがログされます。 たとえば、com.azure.core 内のコードのノイズが多すぎると思う場合に、この方法を使用できます。 また、このような構成は、両方向で設定できます。 たとえば、com.azure.core 内のクラスからより多くのデバッグ情報を取得する場合は、この設定を DEBUG に変更できます。

特定のクラスまたは特定のパッケージのログをきめ細かく制御することができます。 ここでに示すように、com.azure.core はすべてのコア クラスの出力を制御しますが、実行中のアプリケーションという観点から最も有益である状況に合わせて、com.azure.security.keyvault または同等のものを使用して同じように出力を制御できます。

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
      <pattern>%message%n</pattern>
    </encoder>
  </appender>

  <logger name="com.azure.core" level="ERROR" />

  <root level="INFO">
    <appender-ref ref="STDOUT" />
  </root>
</configuration>

ログのローテーションが有効になっているファイルにログする

前の例でログを記録しているコンソールは、通常はログ記録する場所として好ましくありません。 代わりに、次の構成を使用して、1 時間ごとのロールオーバーと gzip 形式のアーカイブを行いながらファイルにログします。

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <property name="LOGS" value="./logs" />
  <appender name="RollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${LOGS}/spring-boot-logger.log</file>
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
      <Pattern>%d %p %C{1.} [%t] %m%n</Pattern>
    </encoder>

    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <!-- rollover hourly and gzip logs -->
      <fileNamePattern>${LOGS}/archived/spring-boot-logger-%d{yyyy-MM-dd-HH}.log.gz</fileNamePattern>
    </rollingPolicy>
  </appender>

  <!-- LOG everything at INFO level -->
  <root level="INFO">
    <appender-ref ref="RollingFile" />
  </root>
</configuration>

Spring アプリケーション

Spring フレームワークは、ログ構成など、さまざまな構成について Spring application.properties ファイルを読み取ることで機能します。 ただし、任意のファイルから Logback 構成を読み取るように Spring アプリケーションを構成できます。 これを行うには、Spring の /src/main/resources/application.properties ファイルに次の行を追加して、logback.xml 構成ファイルを指すように logging.config プロパティを構成します。

logging.config=classpath:logback.xml

次のステップ

この記事では、Logback の構成と、Azure SDK for Java でこれをログに使用する方法について説明しました。 Azure SDK for Java はすべての SLF4J ログ記録フレームワークで機能するため、「SLF4J ユーザー マニュアル」で詳細を参照してください。 Logback を使用する場合は、その Web サイトにも数多くの構成ガイダンスがあります。 詳細については、Logback のドキュメントの「logbackの設定」を参照してください。

ログ記録について習得した後は、Azure が提供する、SpringMicroProfile などのフレームワークへの統合を検討してください。