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を使用した「アプリケーションでのヘルスチェック」の実現方法を紹介する。
項番 | 説明 |
---|---|
(1)
|
LBからのリクエストを受け、各ヘルスチェックを実行する。エンドポイントはSpring Boot Actuatorの仕様により、/actuator/healthになる。詳細については、Endpointsを参照されたい。
|
(2)
|
各ヘルスチェックは、使用ミドルウェアなどの接続・稼動確認を実施する。例では、DataSourceHealthIndicatorからSQLを発行し、データベースが稼動していることを確認している。
これは、データベースアクセスを伴うアプリケーションの場合、アプリケーションが稼動していても、データベースに異常がある場合は正常に業務を行うことができないためである。
|
(3)
|
レスポンスをJSON形式で返却する。
|
ヘルスチェック処理結果 | ステータスコード | レスポンス内容 |
---|---|---|
成功
|
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を参照されたい。