「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Spring Boot と Spring Cloud を使用したマイクロサービスの開発

Spring Boot と Spring Cloud を使用したマイクロサービスの開発

2024 年 11 月 6 日に公開
ブラウズ:684

Developing Microservices with Spring Boot and Spring Cloud

マイクロサービス アーキテクチャは、スケーラブルなモジュール型システムを構築するための一般的なソリューションになっています。マイクロサービスを使用すると、モノリシック アプリケーションをより小さな独立した特殊なサービスに分割できるため、システムの保守と進化が容易になります。この投稿では、Spring Boot と Spring Cloud を使用して堅牢かつ効率的なマイクロサービスを作成する方法を検討します。

マイクロサービスの概要
マイクロサービスの背後にある主なアイデアは、アプリケーションを独立して開発、デプロイ、拡張できる小さなサービスに分割することです。各マイクロサービスは特定の機能を担当し、通常は REST API またはメッセージングを使用して軽量な方法で他のサービスと通信する必要があります。

マイクロサービスには次のような利点があります:

  • 独立したスケーラビリティ: 各サービスは個別にスケーリングできます。
  • 継続的デプロイ: 他のマイクロサービスに影響を与えることなく、マイクロサービスを更新または修正できます。
  • 技術的な柔軟性: 各サービスは、異なるテクノロジとフレームワークを使用して実装できます。 次に、Spring Boot と Spring Cloud を使用してマイクロサービスを作成および管理する方法を見てみましょう。

それでは、Spring BootSpring Cloud を使用してマイクロサービスを作成および管理する方法を見てみましょう。

Spring Boot を使用したマイクロサービスの作成

Spring Boot は、最小限の構成と素早い起動に重点を置いているため、マイクロサービスの構築が簡単になります。まずは 2 つのマイクロサービス、「ユーザー」サービス (User-service) と「注文」サービス (Order-service) を作成しましょう。

  1. Spring Boot プロジェクトのセットアップ

マイクロサービスをセットアップするには、Spring Initializr を使用して、Spring Web や Spring Data JPA など、必要な依存関係を含む新しいプロジェクトを生成できます。ユーザー サービスの REST コントローラーの基本的な例を次に示します:

@RestController
@RequestMapping("/users")
public class UserController {

    @GetMapping("/{id}")
    public ResponseEntity getUserById(@PathVariable Long id) {
        User user = new User(id, "Matheus");
        return ResponseEntity.ok(user);
    }
}

各マイクロサービスは独自のデータベースを持つことができ、サービスが独立して分離されることが保証されます。ユーザーサービスには、たとえば H2 または PostgreSQL を使用した構成を使用できます。

  1. REST API の公開 各マイクロサービスは REST API 経由でリソースを公開し、他のサービスやクライアントがその機能を利用できるようにします。以下は、ユーザー サービスの API を使用する Order-service のエンドポイントの例です。
@RestController
@RequestMapping("/orders")
public class OrderController {

    private final RestTemplate restTemplate;

    public OrderController(RestTemplate restTemplate) {
        this.restTemplate = restTemplate;
    }

    @GetMapping("/{id}")
    public ResponseEntity getOrderById(@PathVariable Long id) {
        User user = restTemplate.getForObject("http://user-service/users/"   id, User.class);
        Order order = new Order(id, user, "Order details");
        return ResponseEntity.ok(order);
    }
}

RestTemplate は、マイクロサービス間で HTTP リクエストを行うために使用されます。

Spring Cloud を使用したマイクロサービスの管理
Spring Boot はマイクロサービスを迅速に作成するのに役立ちますが、Spring Cloud は分散環境でこれらのサービスの通信と復元力を管理するための追加ツールを提供します。いくつかの重要なコンポーネントについて説明しましょう。

  1. エウレカディスカバリーサーバー マイクロサービスの課題の 1 つはサービスの検出です。 Eureka は、固定 URL を必要とせずにサービス自体を登録し、他のサービスを検出できるようにする検出サーバーです。
  • spring-cloud-starter-netflix-eureka-server の依存関係を Eureka サーバーに追加します。
  • User-service と Order-service の両方で application.yml ファイルを構成して、Eureka サーバーに登録します。
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/

これで、サービスは Eureka に自動的に登録され、お互いを見つけやすくなります。

  1. Spring Cloud Gateway を使用した API ゲートウェイ マイクロサービス アーキテクチャでは、すべてのサービスに対して単一のエントリ ポイントを持つことが不可欠です。 API ゲートウェイはクライアントとマイクロサービスの間の仲介者として機能し、リクエストを効率的にルーティングします。

spring-cloud-starter-gateway 依存関係を追加して、単純なゲートウェイを作成します:

spring:
  cloud:
    gateway:
      routes:
        - id: user-service
          uri: lb://USER-SERVICE
          predicates:
            - Path=/users/**
        - id: order-service
          uri: lb://ORDER-SERVICE
          predicates:
            - Path=/orders/**

これにより、/users/** に対するリクエストはすべてユーザー サービスにルーティングされ、/orders/** にも同じことが当てはまります。

3.** サーキットブレーカーによる回復力 (Hystrix)**

マイクロサービス環境では、障害は避けられません。 Hystrix は、障害を分離することでサービスを過負荷から保護するサーキット ブレーカーです。これを別のサービスを使用するメソッドに適用する方法の例を示します:

@HystrixCommand(fallbackMethod = "fallbackGetUser")
public User getUser(Long id) {
    return restTemplate.getForObject("http://user-service/users/"   id, User.class);
}

public User fallbackGetUser(Long id) {
    return new User(id, "Default User");
}

ユーザー サービスが失敗した場合、fallbackGetUser メソッドが呼び出され、システムが機能し続けることが保証されます。

Spring Boot を Spring Cloud と組み合わせると、スケーラブルで復元力のあるマイクロサービスを開発するための優れたインフラストラクチャが提供されます。サービス検出、ルーティング、障害管理などの機能を使用すると、アプリケーションは分散された動的な環境で動作する準備が整います。

モノリシック アプリケーションからマイクロサービスに移行する場合でも、最初から始める場合でも、Spring Boot と Spring Cloud はプロセスを高速化し、堅牢なアーキテクチャを確保できます。

この投稿は気に入りましたか?ご質問やご提案がございましたら、コメント欄に残してください。そして、これらのヒントから恩恵を受ける可能性がある他の開発者とそれを共有することを忘れないでください。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/matheusmartinello/developing-microservices-with-spring-boot-and-spring-cloud-5feh?1 侵害がある場合は、削除するために[email protected]に連絡してください。それ
最新のチュートリアル もっと>
  • Web ページを高速化する
    Web ページを高速化する
    DOM とは何ですか?それは何を食べるのでしょうか? DOM (Document Object Model) は Web ページとその開発の基礎です。これは、HTML および XML ドキュメント用のプログラミング インターフェイスであり、ドキュメントの構造をツリー状のオブジェクト...
    プログラミング 2024 年 11 月 7 日に公開
  • JavaScript での require と import
    JavaScript での require と import
    コーディングを始めたとき、require() を使用してモジュールやインポートを使用して他のファイルをインポートするいくつかの js ファイルを見たことを覚えています。何が違うのか、なぜプロジェクト間で一貫性がないのかがよくわからず、いつも混乱していました。同じことを疑問に思っている場合は、読み続け...
    プログラミング 2024 年 11 月 7 日に公開
  • イメージを使用した Vite/React アプリケーションのデプロイ: 完全ガイド
    イメージを使用した Vite/React アプリケーションのデプロイ: 完全ガイド
    Vite/React アプリケーションを GitHub Pages にデプロイすることはエキサイティングなマイルストーンですが、このプロセスでは、特に画像やアセットを扱う場合、予期せぬ課題が発生することがあります。このブログ投稿では、初期導入から一般的な問題のトラブルシューティング、効果的な解決策の...
    プログラミング 2024 年 11 月 7 日に公開
  • React アプリで API 呼び出しを最適化した方法
    React アプリで API 呼び出しを最適化した方法
    React 開発者として、私たちは、複数の急速な状態変化を API と同期する必要があるシナリオによく直面します。小さな変更ごとに API 呼び出しを行うのは非効率的であり、クライアントとサーバーの両方に負担がかかる可能性があります。ここで、デバウンスと賢明な状態管理が機能します。この記事では、ペイ...
    プログラミング 2024 年 11 月 7 日に公開
  • さあ行こう!
    さあ行こう!
    GO を試す必要がある理由 Go は、高速かつ軽量で静的に型付けされたコンパイル言語で、効率的で信頼性の高いアプリケーションの構築に最適です。そのシンプルさとクリーンな構文により、特に初心者にとって、学習と使用が簡単になります。 Go の優れた機能には、ゴルーチンによる組み込み同時...
    プログラミング 2024 年 11 月 6 日に公開
  • PNG 画像を CSS データ URI の Base64 としてエンコードするにはどうすればよいですか?
    PNG 画像を CSS データ URI の Base64 としてエンコードするにはどうすればよいですか?
    CSS データ URI の PNG 画像に Base64 エンコーディングを使用するデータ URI を使用して PNG 画像を CSS スタイルシートに埋め込むには、PNG データ最初に Base64 形式にエンコードする必要があります。この手法を使用すると、外部画像ファイルをスタイルシート内に直接...
    プログラミング 2024 年 11 月 6 日に公開
  • API 時間別データの応答性の高い JavaScript カルーセル
    API 時間別データの応答性の高い JavaScript カルーセル
    I almost mistook an incomplete solution for a finished one and moved on to work on other parts of my weather app! While working on the carousel that w...
    プログラミング 2024 年 11 月 6 日に公開
  • Web 開発における PHP と JavaScript の主な違いは何ですか?
    Web 開発における PHP と JavaScript の主な違いは何ですか?
    PHP と JavaScript: サーバー側とクライアント側 PHP は JavaScript とは異なる役割を果たします。 PHPはサーバーサイドで動作します。サーバーはアプリケーションを実行します。フォームなどを処理します。フォームを送信すると、PHP がそれを処理します。一...
    プログラミング 2024 年 11 月 6 日に公開
  • C++ で構造体とクラスのメンバーを反復処理して、実行時に名前と値にアクセスするにはどうすればよいですか?
    C++ で構造体とクラスのメンバーを反復処理して、実行時に名前と値にアクセスするにはどうすればよいですか?
    構造体とクラスのメンバーの反復C では、構造体またはクラスのメンバーを反復して名前を取得することができます。そして価値観。これを実現するためのいくつかのアプローチを次に示します。マクロの使用REFLECTABLE マクロを使用して、イントロスペクションを可能にする構造体を定義できます。マクロは、構造...
    プログラミング 2024 年 11 月 6 日に公開
  • 項目 正確な答えが必要な場合は、float と double を避ける
    項目 正確な答えが必要な場合は、float と double を避ける
    float と double の問題: 科学的および数学的計算用に設計されており、2 進浮動小数点演算を実行します。 金銭の計算や正確な答えが必要な状況には適していません。 0.1 などの 10 の負の累乗を正確に表すことができないため、エラーが発生します。 例 1: ドル額を減算する際の計算が正し...
    プログラミング 2024 年 11 月 6 日に公開
  • Go で WebSocket を使用してリアルタイム通信を行う
    Go で WebSocket を使用してリアルタイム通信を行う
    チャット アプリケーション、ライブ通知、共同作業ツールなど、リアルタイムの更新が必要なアプリを構築するには、従来の HTTP よりも高速でインタラクティブな通信方法が必要です。そこで WebSocket が登場します。今日は、アプリケーションにリアルタイム機能を追加できるように、Go で WebSo...
    プログラミング 2024 年 11 月 6 日に公開
  • Python でプロキシを使用して Selenium Webdriver を実行する方法
    Python でプロキシを使用して Selenium Webdriver を実行する方法
    Python でプロキシを使用して Selenium Webdriver を実行するSelenium Webdriver スクリプトを Python スクリプトとしてエクスポートし、コマンド ラインから実行しようとすると、次のような問題が発生する場合があります。使用上の問題 プロキシの場合にエラーが...
    プログラミング 2024 年 11 月 6 日に公開
  • || がいつ行われるか演算子は JavaScript でデフォルトの演算子として機能しますか?
    || がいつ行われるか演算子は JavaScript でデフォルトの演算子として機能しますか?
    || の目的を理解するJavaScript の非ブール オペランドを持つ演算子JavaScript では、|| は演算子は論理 OR 演算子と呼ばれることが多く、通常はブール式を評価するために使用されます。ただし、 || が次のような場合に遭遇する可能性があります。演算子は非ブール値で使用されます...
    プログラミング 2024 年 11 月 6 日に公開
  • Java 23 の新機能を探る
    Java 23 の新機能を探る
    開発者、プログラミング愛好家、学習者の皆様 Java Development Kit (JDK) 23 が正式にリリースされました (2024/09/17 一般提供)。これは Java プログラミング言語の進化におけるもう 1 つの重要なマイルストーンです。この最新のアップデートでは、開発者のエクス...
    プログラミング 2024 年 11 月 6 日に公開
  • ES6 配列の分割: 期待どおりに動作しないのはなぜですか?
    ES6 配列の分割: 期待どおりに動作しないのはなぜですか?
    ES6 配列の構造化: 予期しない動作ES6 では、配列の代入を構造化すると予期しない結果が生じる可能性があり、プログラマは困惑します。そのような例の 1 つを次のコードで示します:let a, b, c [a, b] = ['A', 'B'] [b, c] = ['BB', 'C'] consol...
    プログラミング 2024 年 11 月 6 日に公開

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3