Spring Cloud はマイクロサービス アーキテクチャを構築します: 分散構成センター [Dalston バージョン]

Spring Cloud はマイクロサービス アーキテクチャを構築します: 分散構成センター [Dalston バージョン]

Spring Cloud Config は、分散システムのインフラストラクチャおよびマイクロサービス アプリケーションに集中的な外部構成サポートを提供するために Spring Cloud チームによって作成された新しいプロジェクトです。サーバー部分とクライアント部分の 2 つの部分に分かれています。サーバーは分散構成センターとも呼ばれます。これは、構成リポジトリに接続し、構成情報の取得や情報の暗号化/復号化などのアクセス インターフェイスをクライアントに提供する独立したマイクロサービス アプリケーションです。クライアントは、マイクロサービス アーキテクチャ内のマイクロサービス アプリケーションまたはインフラストラクチャです。指定された構成センターを通じてアプリケーション リソースとビジネス関連の構成コンテンツを管理し、起動時に構成センターから構成情報を取得して読み込みます。 Spring Cloud Config は、サーバーとクライアントの環境変数とプロパティ構成の抽象マッピングを実装しているため、Spring で構築されたアプリケーションに適しているだけでなく、他の言語で実行されるアプリケーションでも使用できます。 Spring Cloud Config で実装された構成センターは、デフォルトで Git を使用して構成情報を保存するため、Spring Cloud Config で構築された構成サーバーは、マイクロサービスアプリケーションの構成情報のバージョン管理を自然にサポートし、Git クライアントツールを通じて構成コンテンツを簡単に管理およびアクセスできます。もちろん、SVN リポジトリ、ローカライズされたファイル システムなど、他のストレージ方法もサポートしています。

[[237179]]

この記事では、Git ストレージに基づいて分散構成センターを構築し、クライアントを変換して、構成センターから構成情報を取得してコードにバインドできるようにする方法を学習します。

倉庫の設定を準備する

  • Code Cloud または Github で作成できる Git リポジトリを準備します。たとえば、この記事で用意されているウェアハウスの例: http://git.oschina.net/didispace/config-repo-demo
  • 構成センターを読み取るアプリケーションの名前が config-client であると仮定すると、git リポジトリ内のプロジェクトのデフォルトの構成ファイル config-client.yml を作成できます。
  1. 情報:
  2. プロファイル:デフォルト 

さまざまな環境の読み込み構成を示すために、git リポジトリに dev 環境用の別の構成ファイル config-client-dev.yml を作成できます。

  1. 情報:
  2. プロフィール: 開発者

ビルド構成センター

Spring Cloud Config を使用して分散構成センターを構築するのは非常に簡単で、必要な手順は 3 つだけです。

  • config-server-git という名前の基本的な Spring Boot プロジェクトを作成し、pom.xml に次の依存関係を導入します (parent と dependencyManagement の部分は省略します)。
  1. <依存関係>
  2. <依存関係>
  3. <groupId>org.springframework.cloud</groupId>
  4. <artifactId>spring-cloud-config-server</artifactId>
  5. </依存関係>
  6. </依存関係>
  • Spring Boot プログラムのメインクラスを作成し、@EnableConfigServer アノテーションを追加して、Spring Cloud Config のサーバー側機能を有効にします。
  1. @EnableConfigServer
  2. @SpringBootアプリケーション
  3. パブリッククラスアプリケーション{
  4.  
  5. 公共 静的void main(String[] args) {
  6. 新しい SpringApplicationBuilder(Application.class).web( true ).run(args);
  7. }
  8.  
  9. }
  • 構成サービスに関する基本情報と Git リポジトリの関連情報を application.yml に追加します。次に例を示します。
  1. 応用:
  2. 名前: config-server
  3. 雲:
  4. 設定:
  5. サーバ:
  6. git:
  7. uri: http://git.oschina.net/didispace/config-repo-demo/
  8. サーバ:
  9. ポート: 1201

この時点で、Spring Cloud Config を使用して Git で構成コンテンツを管理する分散構成センターが完成しました。まずアプリケーションを起動し、エラーが発生しないことを確認してから、次の操作を試してください。

Git リポジトリにアクセス許可が必要な場合は、次の 2 つのプロパティを構成することでこれを実現できます。

  • spring.cloud.config.server.git.username: Gitリポジトリにアクセスするためのユーザー名
  • spring.cloud.config.server.git.password: Gitリポジトリにアクセスするためのユーザーパスワード

これらの準備が完了すると、ブラウザ、POSTMAN、CURL などのツールを使用して構成コンテンツに直接アクセスできるようになります。設定情報にアクセスするための URL と設定ファイルのマッピング関係は次のとおりです。

  • /{アプリケーション}/{プロファイル}[/{ラベル}]
  • /{アプリケーション}-{プロファイル}.yml
  • /{ラベル}/{アプリケーション}-{プロファイル}.yml
  • /{アプリケーション}-{プロファイル}.properties
  • /{ラベル}/{アプリケーション}-{プロファイル}.properties

上記の URL は、{application}-{profile}.properties に対応する構成ファイルをマップします。ここで、{label} は Git 上のさまざまなブランチに対応し、デフォルトは master です。異なる構成コンテンツにアクセスするために、異なる URL を構築してみることができます。たとえば、config-client アプリケーションの開発環境であるマスター ブランチにアクセスするには、次の URL にアクセスします: http://localhost:1201/config-client/dev/master すると、次の応答が返されます。

  1. {
  2. 「名前」 : 「config-client」
  3. 「プロファイル」 : [
  4. 「開発」  
  5. ]、
  6. 「ラベル」 : 「マスター」
  7. "バージョン" : null
  8. 「状態」 : null
  9. 「プロパティソース」 : [
  10. {
  11. 「名前」 : 「http://git.oschina.net/didispace/config-repo-demo/config-client-dev.yml」
  12. "ソース" : {
  13. 「情報プロファイル」 : 「dev」  
  14. }
  15. },
  16. {
  17. 「名前」 : 「http://git.oschina.net/didispace/config-repo-demo/config-client.yml」
  18. "ソース" : {
  19. "info.profile" : "デフォルト"  
  20. }
  21. }
  22. ]
  23. }

Json は、アプリケーション名: config-client、環境名: dev、ブランチ名: master、およびデフォルト環境と dev 環境の構成内容を返すことがわかります。

クライアントの構築

上記の検証を完了し、構成サービスセンターが正常に動作していることを確認しました。それでは、マイクロサービス アプリケーションで上記の構成情報を取得してみます。

  • config-client という名前の Spring Boot アプリケーションを作成し、pom.xml に次の依存関係を導入します。
  1. <依存関係>
  2. <依存関係>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. </依存関係>
  6. <依存関係>
  7. <groupId>org.springframework.cloud</groupId>
  8. <artifactId>spring-cloud-starter-config</artifactId>
  9. </依存関係>
  10. </依存関係>
  • 次のようにして、Spring Boot アプリケーションのメイン クラスを作成します。
  1. @SpringBootアプリケーション
  2. パブリッククラスアプリケーション{
  3.  
  4. 公共 静的void main(String[] args) {
  5. 新しい SpringApplicationBuilder(Application.class).web( true ).run(args);
  6. }
  7.  
  8. }

構成ファイルを取得するための config-server-git の場所を指定する bootstrap.yml 構成を作成します。次に例を示します。

  1. 春:
  2. 応用:
  3. 名前: config-client
  4. 雲:
  5. 設定:
  6. URI: http://localhost:1201/
  7. プロファイル:デフォルト 
  8. レーベル: マスター
  9.  
  10. サーバ:
  11. ポート: 2001

上記の構成パラメータと Git に保存されている構成ファイルのさまざまな部分との対応関係は次のとおりです。

  • spring.application.name: 設定ファイルルールの{application}部分に対応します
  • spring.cloud.config.profile: 構成ファイルルールの{profile}部分に対応します
  • spring.cloud.config.label: 構成ファイルルールの{label}部分に対応します
  • spring.cloud.config.uri: 構成センターのconfig-serverのアドレス

config-server の設定情報が正しく読み込まれるように、上記のプロパティを bootstrap.properties で設定する必要があることに注意することが重要です。

上記のコードの記述が完了すると、読者は config-server-git と config-client の両方を起動し、http://localhost:2001/info にアクセスできます。このエンドポイントは、git リポジトリから取得した構成情報を返すことがわかります。

  1. {
  2. 「プロファイル」 : 「デフォルト」  
  3. }

さらに、config-client のプロファイルを dev に変更して、ロードされた構成の変更を観察することもできます。

コードサンプル

サンプルプロジェクトは、以前 CodeCloud と GitHub で作成された SpringCloud-Learning プロジェクトを使用し、再編成されます。異なるディレクトリによって Brixton と Dalston を区別する例。

具体的なプロジェクトの説明は次のとおりです。

  • Git リポジトリに基づく構成センター: config-server-git
  • 構成センターのクライアントを使用する: config-client

【この記事は51CTOコラムニスト「Zhai Yongchao」によるオリジナル記事です。転載の許可を得るには、51CTO を通じて著者に連絡してください。

この著者の他の記事を読むにはここをクリックしてください

<<:  分散seckillシステムの構築からWebSocketプッシュ通知についてお話ししましょう

>>:  マルチクラウド: 新しい監視キャッシュ

推薦する

vpsace-1g メモリ/75g メモリ/ニューヨーク/年間 50 ドル

vpsaceドメイン名は2011年に登録されました。運用開始などの履歴情報に関する公式情報はありませ...

分散トランザクションを実装するにはどうすればいいですか? Seata の XA モデルの詳細な分析

Seata 1.2.0 バージョンでは、XA プロトコルをサポートする新しいトランザクション モード...

cyanode-$2.5/KVM/512M メモリ/15g SSD/500g トラフィック/ロサンゼルス

cyanode.com は、HugeServer Networks と提携している新しいブランドです...

サイト最適化の最初のステップ、URL リンクが正しく設定されているかどうか確認してください。

月給5,000~50,000のこれらのプロジェクトはあなたの将来ですはじめに:ウェブサイトへのURL...

友好的なリンク交換に関する奇妙な見方: リンク = 友情?

少し前に、Ye Jianhui は SEO グループで興味深い議論を目にしました。その議論は、フレン...

英国ロンドンデータセンターのCN2 GIAラインを備えたakkocloudのVPSの簡単なレビュー

Akkocloudは最近、英国のcn2 gia vpsを購入しました。10%割引で販売されているよう...

360 度検索エンジンは、懸命に働くウェブマスターに希望をもたらすことができるでしょうか?

8月16日は特別な日でした。仕事でも私生活でも常に注目を集めていた周紅毅氏は、今日は控えめな態度で、...

B2Bプラットフォームの重みが向上し、ロングテールキーワードがB2Bプラットフォームを有効活用できることが観察されています。

企業のウェブサイトでロングテールキーワードのランキングを獲得するのは簡単ではありません。ウェブサイト...

dataplugs - イースター、香港専用サーバー、最大 1000 香港ドルの割引

Duoxiantong のイースター イベントが始まりました: 2020 年 3 月 22 日から ...

クラウドの停止に注意してください: データセンターの冗長性をどのように設計しますか?

多くのパブリック クラウド プロバイダーは、日常業務で壊滅的な停止を頻繁に経験しており、IT マネー...

ハイブリッドクラウドワークを導入するために必要な 5 つのスキル

パンデミックによって私たちの働き方、時間、場所が再定義された 2020 年初頭には、ハイブリッド ク...

Zhikeウェブサイト業界の発展はボトルネックに遭遇しました:整合性システムに問題がある

求職者は、「ジョブブローカー」または「ジョブコンサルタント」とも呼ばれ、求職者の雇用ニーズに基づいて...

企業はどのようにしてクラウド移行を成功させることができるのでしょうか?

データによれば、クラウドに移行する企業がますます増えています。これらの企業は、サードパーティのインフ...

友好的なリンクを交換する際に注意すべき4つのポイント

ウェブサイトの最適化に携わる専門家は、ウェブサイトのランキングを決定する 3 つの要素は、フレンドリ...

hostvenom-3.4 USD/VPS/KVM/512 MB RAM/15 GB SSD/1 TB トラフィック/安定したデータセンター

Hostvenom は 2009 年に設立され、ホスティング事業の運営を開始しました。主な事業はシカ...