data:image/s3,"s3://crabby-images/54df6/54df62f8a8715fd38f8525e2813df554745692f2" alt="見出し画像"
【マイクロサービスの安定的設定管理】Spring Cloud Bus, Docker, RabbitMQ - Springboot3 第7回
はじめに
こんにちは、今日はマイクロサービスの安定的設定管理として、「Spring Cloud Bus」を勉強します。キーワドは「メッセージブローカ(Message Broker)」になります!
「Spring Cloud Bus」とは?
「Spring Cloud Config Server」は一つの問題点がありますが、それは設定変化をリロードするためには「/refresh」エンドポイントを手動で行う必要があるということです。 これは、複数のアプリケーションがある場合はまったく実用的ではありません。 100個のマイクロサービスがあるとしましょう。 いちいち100個の「/refresh」エンドポイントを呼び出すべきでしょうか? 誰でも考えてみても無理です。
この時に使われるのが「Spring Cloud Bus」モジュールです。 「Spring Cloud Bus」モジュールは、「メッセージブローカー」を通じて多数のアプリケーションと接続するために使用されます。 また、設定変化をブロードキャストすることができる。
data:image/s3,"s3://crabby-images/dff41/dff412ec94202ac7ba5bb149fe0d0cc4e6ff1d01" alt=""
メッセージコンポーネントブローカーとして「RabbitMQ」と「Apache Kafka」が広く使われます。 マイクロサービスはメッセージブロッカーを「Subscribe」し、一つのマイクロサービスに設定変化が発生すると、メッセージブロッカーは自分を「subscribe」している他のマイクロサービスにその変化を「broadcast」します。 この時、「busrefresh」というエンドポイントを使います。
実装手順
1. bus AMQP 依存性追加
department-service/pom.xml
employee-service/pom.xml
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
2. Dockerを通じてRabbitMQインストール
Dockerインストール
data:image/s3,"s3://crabby-images/917b8/917b884569a933b72163abec11cc21263898fb71" alt=""
data:image/s3,"s3://crabby-images/47ea3/47ea3aa85d5d629b385e27f6ca1311900648af95" alt=""
data:image/s3,"s3://crabby-images/f4a74/f4a741fddd6a81f63ad45799c2c5cfcfc92fda24" alt=""
data:image/s3,"s3://crabby-images/8e126/8e126a09fd54fbf82e4e6babebc1c961e0e56172" alt=""
インストール中いろいろ問題がありました;;;
Docker Desktopは起動するがカーネルが古いと怒られた。
data:image/s3,"s3://crabby-images/410cf/410cff4118a3495f63e092a751f3e9b03be9c844" alt=""
data:image/s3,"s3://crabby-images/53706/53706028bec92f28f0c3c4cd90bddfa61f815524" alt=""
data:image/s3,"s3://crabby-images/41590/41590eb901ea0de1799a5eff7747ea4e3dec14fc" alt=""
「Sign In」ボタンを押して、IDを登録して、ログインします。
「https://hub.docker.com/」で 「rabbitmq」のバージョンをチェックします。
data:image/s3,"s3://crabby-images/8de0f/8de0f19ea69225530aad33fb6cce9e5c3ab796e7" alt=""
data:image/s3,"s3://crabby-images/e9bb6/e9bb6224339c34ea8a1bedcc94f3c64defa77e62" alt=""
data:image/s3,"s3://crabby-images/dbffc/dbffcd5b56f15effa1b028dc55859f362cc05969" alt=""
data:image/s3,"s3://crabby-images/fde7c/fde7c22ae351b3ee9073d96b2323a261440fef77" alt=""
data:image/s3,"s3://crabby-images/1ed0b/1ed0bb5fd09ef18ff379ce0af8f38f47c541bfe5" alt=""
data:image/s3,"s3://crabby-images/41180/4118068c4b7adca4b7ab1fb2b0aab74458609a85" alt=""
3. RabbitMQ 設定
department-serviceのapplication.properties
data:image/s3,"s3://crabby-images/ef99c/ef99c759db697c5f642aa4cc09ca5dfd6c2c31b4" alt=""
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
employee-serviceのapplication.properties
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
4. employee-serviceのREST API 生成
data:image/s3,"s3://crabby-images/56244/56244dfa6ab3a4b78289c2fdd2c0333ec36452ba" alt=""
department-serviceの「MessageController」のコード
@RefreshScope
@RestController
public class MessageController {
@Value("${spring.boot.message}")
private String message;
@GetMapping("message")
public String message() {
return message;
}
}
employee-serviceの「MessageController」のコード。エンドポイントが少し変更されました。
@RefreshScope
@RestController
public class MessageController {
@Value("${spring.boot.message}")
private String message;
@GetMapping("/users/message")
public String message() {
return message;
}
}
data:image/s3,"s3://crabby-images/6aae0/6aae0d00a1c5df21a07a4e185cad1fc96c8c8f05" alt=""
data:image/s3,"s3://crabby-images/df03d/df03d85cfe5517fc12ad99f71a9268ef5144c040" alt=""
data:image/s3,"s3://crabby-images/4a3b6/4a3b645f3d6086c83cdd98a2ed23492778a157b0" alt=""
data:image/s3,"s3://crabby-images/bd1a9/bd1a91f297ed9b11ec8fb3d2c64c8b4b6fa170c3" alt=""
data:image/s3,"s3://crabby-images/c9694/c9694555c9ff0699f07206e47d36bdcc85d9974d" alt=""
5. department-serviceとemployee-service設定変更後、「/busrefresh」
data:image/s3,"s3://crabby-images/e5b09/e5b094a518d72293413fef0af0942e9f8cbfa5ad" alt=""
data:image/s3,"s3://crabby-images/be7c3/be7c358bd3ea4f89a8368c81028f8fbb8c083914" alt=""
data:image/s3,"s3://crabby-images/4cc72/4cc72883633f5fefb16b1ae98cc91d71c2d9f683" alt=""
data:image/s3,"s3://crabby-images/07735/077353151d6ed96d11f5ff633aa2516a0ebca2d8" alt=""
data:image/s3,"s3://crabby-images/c246f/c246fc4360776c390a4e42cbd9b45c95d6ace2c3" alt=""
data:image/s3,"s3://crabby-images/065f5/065f5a1dcabe01ae302e37f1db2293b97dd9d859" alt=""
最後に
「Spring Cloud Bus」を使用することで、マイクロサービスアーキテクチャの設定管理を効率的に行う方法を学びました。これにより、複数のアプリケーションがある場合でも設定変更を手動で更新する手間を省くことができ、スムーズな運用が可能となります。また、「RabbitMQ」や「Apache Kafka」などのメッセージブローカーを活用することで、設定変更をブロードキャストし、各マイクロサービスに即座に反映させることができます。これにより、システム全体の安定性と信頼性が向上し、開発者は設定管理にかかる負担を軽減できます。
このように、「Spring Cloud Bus」はマイクロサービスアーキテクチャの設定管理において強力なツールとなり、効果的な運用をサポートします。私も、今後は複数のサービスを連動して開発するときは、こんな方法をつかって安定的な設定管理をしたいと思います!
エンジニアファーストの会社 株式会社CRE-CO
ソンさん
【参考】
[Udemy] Building Microservices with Spring Boot & Spring Cloud