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プッシュ通知についてお話ししましょう

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

推薦する

民間病院のウェブサイト編集者は最適化に重点を置くべきでしょうか、それともマーケティングに重点を置くべきでしょうか?

民間病院のウェブサイト編集者は、最適化とマーケティングのどちらに重点を置くべきでしょうか?現在、各地...

#クリスマス# vmiss: 香港 VPS は年間 75 元から、1G メモリ/1 コア/10gSSD/1T トラフィック/500M 帯域幅

vmiss は今年のクリスマス プロモーションを開始しました。香港国際回線の VPS が 30% 割...

ウェブサイトの運営方法とウェブサイトの内部リンクの最適化

2018年最もホットなプロジェクト:テレマーケティングロボットがあなたの参加を待っていますウェブサイ...

ブランドプロモーションとマーケティング: アベンジャーズとレイバーデーを一緒にマーケティングするにはどうすればよいでしょうか?

あっという間にメーデーがやって来ます。この記事では、メーデーのマーケティングとプロモーションの方向性...

レンタカー業界戦争の背後にある「呪い」:敏感な資本ノード

電子商取引戦争の煙はまだ消えず、もう一つの資本集約型産業であるレンタカー業界が再び濃い煙を噴出させた...

疑似オリジナリティを好む人が知っておくべきこと

私は医療業界で検索エンジンマーケティングに携わっています。医療業界のプロモーションや編集に携わったこ...

韓国サーバー

韓国のサーバーは登録不要です。中国本土に物理的に近いため、速度が非常に速く、そのため韓国のサーバーは...

hxkvm-日本のデータセンターVPS評価、KVM/3ネットワーク直接接続

2009年に設立された「Nine Zero Innovation Laboratory」の製品である...

より効率的な情報

以前、北京で開催されたインタラクティブ体験デーで、私は新浪のプロダクトマネージャー、李啓明氏の「より...

クラウドネイティブの AWS サービスを活用してセキュリティ体制を強化するにはどうすればよいでしょうか?

[[428809]]この記事はWeChat公式アカウント「新チタン雲務」から転載され、喬炳成が翻訳し...

ブログを通じて安定した外部リンクを素早く増やす方法

昨年、私は SEO の仕事を引き受けましたが、ターゲット キーワードはアンティーク、アンティーク、G...

SEOウェブサイトのキーワードランキングに関するいくつかの問題

ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービスSEO 担当者として、S...

マイクロソフトのメールボックス計画はウェブマスターに新たなマーケティングモデルをもたらすかもしれない

最近、マイクロソフトが 10 年以上運用されてきた Hotmail に根本的な変更を加えることを決定...

キャッシュバック型タオバオ加盟店を禁止するタオバオの動機と野望

タオバオは、咳をするだけで広範囲に影響を及ぼすほど巨大だ。タオバオ・アライアンスが来年からキャッシュ...