3.9. ヘルスチェック

3.9.1. Overview

本ガイドラインでは、「アプリケーションでのヘルスチェック」を行うための方式を紹介する。

3.9.1.1. ロードバランサの負荷分散と縮退運転

「ロードバランサの負荷分散と縮退運転」の詳細については、 Macchinetta Framework for Java (5.x) Development Guidelineのロードバランサの負荷分散と縮退運転を参照されたい。

3.9.1.2. ヘルスチェックの種類

「ヘルスチェックの種類」の詳細については、 Macchinetta Framework for Java (5.x) Development Guidelineのヘルスチェックの種類を参照されたい。

3.9.1.3. 本ガイドラインで示すヘルスチェックの構成

本ガイドラインでは、アプリケーションでのヘルスチェックを行うための方式を紹介する。 本アプリケーションではSpring Bootを採用している。Spring Boot自体がヘルスチェック機能であるSpring Boot Actuatorという仕組みを具備しているため、「アプリケーションでのヘルスチェック」の実現方式を、従来の独自で作成する方式ではなく、Spring Boot Actuatorを使用する方式を推奨する。本章ではSpring Boot Actuatorを使用した「アプリケーションでのヘルスチェック」の実現方法を紹介する。

Screen image of HealthCheck Configuration.
項番 説明
(1)
LBからのリクエストを受け、各ヘルスチェックを実行する。エンドポイントはSpring Boot Actuatorの仕様により、/actuator/healthになる。詳細については、Endpointsを参照されたい。
(2)
各ヘルスチェックは、使用ミドルウェアなどの接続・稼動確認を実施する。例では、DataSourceHealthIndicatorからSQLを発行し、データベースが稼動していることを確認している。
これは、データベースアクセスを伴うアプリケーションの場合、アプリケーションが稼動していても、データベースに異常がある場合は正常に業務を行うことができないためである。
(3)
レスポンスをJSON形式で返却する。
本ガイドラインのアプリケーションヘルスチェック方式で返却されるステータスコードおよびレスポンスは以下の通りである。LBは返却されたステータスコード、および必要に応じてレスポンスの内容を検査し、アプリケーションの稼動状況を判断する。
ヘルスチェック処理結果 ステータスコード レスポンス内容
成功
200(正常)
JSON形式で"status": "UP"
エラー発生
503(異常)
JSON形式で"status": "DOWN"

「Spring Boot Actuatorの処理結果ステータス」の詳細については、Writing custom HealthIndicatorsを参照されたい。

  • ヘルスチェックのResponse内容の例
{
  "status": "UP",
  "components": {
    "redis": {
      "status": "UP",
      "components": {
        "version": "3.2.100"
      }
    },
    "db": {
      "status": "UP",
      "components": {
        "dataSource": {
          "status": "UP",
          "database": "PostgreSQL",
          "hello": 1
        }
      }
    }
  }
}
名前 説明
status
ヘルスチェックの結果。全体の結果を表す。
redis
ヘルスチェック対象の個別名称を表す。
redis:
status
ヘルスチェック対象の個別ステータスを表す。
redis:
version
同一階層のこれ以降の項目は、個別の情報を表す。ここでは、バージョン情報のみを表示しているが、インジケータに拠って出力項目は異なる。

3.9.2. How to use

3.9.2.1. Spring Boot Actuatorの導入

Spring Boot Actuatorは、依存関係にjarを追加するだけで、導入可能となる。

pom.xmlで必要なjarを設定する。

  • pom.xml
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

3.9.2.2. Spring Boot Actuatorの設定

基本的にAuto Configが必要な設定を行うため、何も設定する必要はないが、アプリケーションの機能とSpring Boot Actuatorの管理機能のパスを明示的に区別するために、management.endpoints.web.base-pathを設定する。

  • application.yml
spring:
  application:
    name: xxx
<!-- (1) -->
management:
  endpoints:
    web:
      base-path: /management
<!-- (2) -->
  endpoint:
    health:
      show-details: ALWAYS
項番 説明
(1)
Spring Boot ActuatorのヘルスチェックのエンドポイントのURLは、デフォルトではhttp://localhost:8080/xxx/actuator/healthが使用される。
management.endpoints.web.base-pathに/managementを設定することで、http://localhost:8080/xxx/management/healthを使用する。
(2)
「Spring Boot Actuatorの処理結果ステータス」で詳細情報を取得するためにmanagement.endpoint.health.show-detailsにALWAYSを設定する。
設定可能なパラメータは、Health Informationを参照されたい。

3.9.2.3. ヘルスチェック対象

Spring Boot Actuatorがサポートしているヘルスチェック対象は、Auto-configured HealthIndicatorsを参照されたい。

Note

ヘルスチェックは、実施可能な状況であれば、実施される。実施可能な状況とは、DIコンテナ上にヘルスチェックの対象となるリソースに関連するBeanが存在した場合などが対象となる。 例えば、dbチェックの場合はSpringのBean定義にDataSourceが存在した場合を表す。 不要なヘルスチェックが実施される場合は management.health.インジケータ名称.enabledプロパティにfalseを設定する必要がある。

3.9.2.4. エンドポイントのアクセス保護

Spring Boot Actuatorのエンドポイントは、外部に公開するべきでない情報が取得できるため、ロードバランサで外部からアクセスを遮断する必要がある。

ヘルスチェックの対象となるアプリケーションを外部のTomcatにデプロイした場合は、Spring Boot Actuatorのエンドポイントは同一ポートでしか稼動できないため、ロードバランサのL7ルーティングを使用して、保護する必要がある。

Note

Spring Bootに内包されたTomcatを使用する場合は、アプリケーションとSpring Boot Actuator機能でポートを分けることができるため、ロードバランサで対象のポートを保護する。また、「Spring Boot Actuator自体のアクセス保護機能」については、Security with HealthIndicatorsを参照されたい。

3.9.3. How to extend

3.9.3.1. カスタムインジケータ

Spring Boot Actuatorが用意しているデフォルトのヘルスインジケータのみでヘルスチェックを実現できない場合は、カスタムヘルスチェックインジケータを登録することができる。 カスタムヘルスチェックインジケータは、HealthIndicatorインタフェースの実装に、@Componentを付与することで登録される。 「Spring Bootを使用したコンポーネントスキャンの定義方法」については、Structuring your codeを参照されたい。

  • DynamodbHealthIndicator.java
@Component
@ConditionalOnProperty(value = "management.health.dynamodb.enabled", matchIfMissing = true) // (1)
public class DynamodbHealthIndicator extends AbstractHealthIndicator {

    private AmazonDynamoDB amazonDynamoDB;

    @Autowired
    public DynamodbHealthIndicator(AmazonDynamoDB amazonDynamoDB) {
        this.amazonDynamoDB = amazonDynamoDB;
    }

    @Override
    protected void doHealthCheck(Builder builder) throws Exception {  // (2)

        if (this.amazonDynamoDB == null) {
            builder.up().withDetail("amazonDynamoDB", "unknown");
            return;
        }
        try {
            ListTablesResult listTablesResult = amazonDynamoDB.listTables();
            builder.up().withDetail("amazonDynamoDB", listTablesResult
                    .getTableNames()); // (3)
        } catch (Exception e) {
            builder.down(e); // (4)
        }
    }
}
項番 説明
(1)
他のヘルスチェックインジケータと同様に、プロパティで実行可否を制御する。
(2)
AbstractHealthIndicatorの抽象メソッドを実装する。
(3)
疎通確認が成功した場合に、Builderに稼働状況の成功と詳細情報を追加する。
(4)
疎通確認が失敗した場合に、Builderに稼働状況の失敗と原因例外を追加する。

3.9.4. Appendix

3.9.4.1. Spring Boot Actuatorが提供するエンドポイント

「Spring Boot Actuatorが提供するエンドポイント」の詳細については、Endpointsを参照されたい。