目次
Spring Cloud Tencent とは?" >Spring Cloud Tencent とは?
プロジェクト ソース コード アドレス
1. Polaris のインストール
#2. サービスの登録と検出
六、限流熔断
ホームページ Java &#&チュートリアル SpringCloud Tencent の完全なソリューション 1

SpringCloud Tencent の完全なソリューション 1

Jul 14, 2022 pm 02:32 PM
マイクロサービス spring cloud ビッグデータ

Spring Cloud Tencent とは?

Spring Cloud Tencent は、Tencent のオープンソースのワンストップ マイクロサービス ソリューションです。 Spring Cloud Tencent は Spring Cloud 標準マイクロサービス SPI を実装しており、開発者は Spring Cloud Tencent に基づいて Spring Cloud マイクロサービス アーキテクチャ アプリケーションを迅速に開発できます。 Spring Cloud Tencent の中核は、Tencent のオープンソースのワンストップ サービス検出およびガバナンス プラットフォーム Polarismesh に依存して、さまざまな分散マイクロサービス シナリオを実装します。

Spring Cloud Tencent によって提供される機能には、次のものが含まれますが、これらに限定されません:

プロジェクト アドレス:https://github .com/Tencent/spring-cloud-tencent

プロジェクト ソース コード アドレス

https://github.com/lltx/spring-cloud-tencent-demo

1. Polaris のインストール

Polaris は、分散型またはマイクロサービス アーキテクチャにおけるサービスの可視性、フォールト トレランス、フロー制御、セキュリティの問題の解決に特化した Tencent のオープンソース サービス ディスカバリおよびガバナンス センターです。 「業界には、これらの問題の一部を解決できるいくつかのコンポーネントがすでに存在しています」が、標準的な、複数言語に対応した、フレームワークに依存しない実装が不足しています。

Tencent は多数の分散サービスを有しており、事業分野や技術スタックの多様性と相まって、大小合わせて数十の関連コンポーネントを蓄積しています。 2019年から、当社はPolarisを通じてこれらのコンポーネントを抽象化および統合し、企業向けの統合されたサービス検出およびガバナンスソリューションを作成し、企業の研究開発効率と運用品質の向上を支援しました。

Polaris のインストールは非常に簡単です。応答プラットフォームの zip をダウンロードして直接実行します,ダウンロード アドレス:https://github.com/polarismesh/polaris/releases/tag/ v1 .9.0

#2. サービスの登録と検出

  • #サービスは、polaris-discovery 依存関係を追加します

<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-discovery</artifactId>
</dependency>
ログイン後にコピー
  • application.yaml Polaris サーバーに接続します

spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091
ログイン後にコピー
  • サービス監視の開始 Polaris コンソール

    #サービスコールの例
  • @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
      return new RestTemplate();
    }
    
    @Autowired
    private RestTemplate restTemplate;
    
    @GetMapping("/consumer")
    public String consumer() {
      return restTemplate.getForObject("http://lengleng-tencent-discovery-provider/provider/lengleng", String.class);
    }
    ログイン後にコピー
  • 3. 構成管理

アプリケーション起動のブートストラップフェーズ中に、Spring Cloud は PolarisConfigFileLocator を呼び出して、Polaris サーバーから構成ファイルを取得し、それを Spring コンテキストにロードします。構成コンテンツは、Spring Boot の標準 @Value,@ConfigurationProperties アノテーションを通じて取得できます。動的構成更新機能は、Spring Cloud の標準 @RefreshScope メカニズムを通じて実装されます。

#サービスは、polaris-config の依存関係を追加します
  • <dependency>
        <groupId>com.tencent.cloud</groupId>
        <artifactId>spring-cloud-starter-tencent-polaris-config</artifactId>
    </dependency>
    ログイン後にコピー
bootstrap.yaml は、polaris-config にアクセスします
  • #
    spring:
      cloud:
        polaris:
          address: grpc://127.0.0.1:8081
          config:
            groups:
              - name: ${spring.application.name}
                files: "application"
    ログイン後にコピー

    特記事項: これはブートストラップで設定する必要があります, spring-cloud-tencent は Spring boot の最新のファイル読み込みメカニズムに適応していません

Polaris コンソールの追加構成

#コード使用構成

##
@Value("${name:}")
private String name;
ログイン後にコピー
    4. サービス電流制限
  • サービス電流制限は、トラフィックのピークによってサービスが圧倒されるのを防ぐための最も一般的なサービス自己保護手段の 1 つです。 Spring Cloud Tencent Rate Limit モジュールには、Spring Web および Spring WebFlux シナリオ用の電流制限フィルターが組み込まれており、Polaris の電流制限機能と組み合わせて、企業が電流制限機能に迅速にアクセスできるようにします。

サービスは、polaris-ratelimit 依存関係を追加します,電流制限コンポーネントを使用するときに検出を追加して、サービス リストの編集を容易にします

<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-discovery</artifactId>
</dependency>

    com.tencent.cloud
    spring-cloud-starter-tencent-polaris-ratelimit
ログイン後にコピー
  • サービス アクセス Polaris-ratelimit

spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091
      namespace: default
      ratelimit:
        reject-http-code: 403
        reject-request-tips: "lengleng test rate limit"
ログイン後にコピー
  • #Polaris コンソールに電流制限ルールが追加されました

  • #5. サービス ルーティング

  • polaris は、メタデータ ルーティング、最近接ルーティング、ルール ルーティング、カスタム ルーティングなどより多くのルーティング フォームを実装できます。,この記事のデモメタデータ ルーティングの#xff0c;以下に示すように、同じメタデータ情報を持つサービスのみがルーティングされます

# サービスは、polaris-router 依存関係を追加します

<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-router</artifactId>
</dependency>
ログイン後にコピー
    サービス マーク メタデータ
spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091
    tencent:
      metadata:
        content:
          version: local
ログイン後にコピー

六、限流熔断

故障实例熔断是常见的一种容错保护机制。故障实例熔断能实现主调方迅速自动屏蔽错误率高或故障的服务实例,并启动定时任务对熔断实例进行探活。在达到恢复条件后对其进行半开恢复。在半开恢复后,释放少量请求去进行真实业务探测。并根据真实业务探测结果去判断是否完全恢复正常。

  • 添加限流熔断相关的依赖 polaris-circuitbreaker


    com.tencent.cloud
    spring-cloud-starter-tencent-polaris-circuitbreaker



    org.springframework.cloud
    spring-cloud-starter-loadbalancer


<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-discovery</artifactId>
</dependency>


    org.springframework.cloud
    spring-cloud-circuitbreaker-spring-retry



    org.springframework.cloud
    spring-cloud-starter-openfeign
ログイン後にコピー
  • 提供 Feign 服务调用实现

spring-cloud-tencent 当前版本仅支持 feign 熔断

@FeignClient(contextId = "demoFeign", value = "lengleng-circuitbreaker-tencent-circuitbreaker-provider",
  fallback = DemoFeignFallback.class)
public interface DemoFeign {
 @GetMapping("/provider")
 String get(@RequestParam String name);

}
ログイン後にコピー
  • 服务接入 polaris-circuitbreaker

spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091

#开启断路器
feign:
  circuitbreaker:
    enabled: true
ログイン後にコピー
  • 编写熔断规则 polaris.yml

consumer:
  circuitBreaker:
    checkPeriod: 100ms
    chain:
      - errorCount
      - errorRate
    plugin:
      errorCount:
        continuousErrorThreshold: 1
        metricNumBuckets: 1
      errorRate:
        errorRateThreshold: 100
        metricStatTimeWindow: 1s
        requestVolumeThreshold: 1
ログイン後にコピー

               

以上がSpringCloud Tencent の完全なソリューション 1の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP フレームワークとマイクロサービス: クラウド ネイティブの導入とコンテナ化 PHP フレームワークとマイクロサービス: クラウド ネイティブの導入とコンテナ化 Jun 04, 2024 pm 12:48 PM

PHP フレームワークとマイクロサービスを組み合わせる利点: スケーラビリティ: アプリケーションを簡単に拡張し、新しい機能を追加したり、より多くの負荷を処理したりできます。柔軟性: マイクロサービスは独立してデプロイおよび保守されるため、変更や更新が容易になります。高可用性: 1 つのマイクロサービスの障害が他の部分に影響を与えないため、高可用性が確保されます。実践的なケース: Laravel と Kubernetes を使用したマイクロサービスのデプロイ ステップ: Laravel プロジェクトを作成します。マイクロサービスコントローラーを定義します。 Dockerfileを作成します。 Kubernetes マニフェストを作成します。マイクロサービスをデプロイします。マイクロサービスをテストします。

Java フレームワークはマイクロサービスの水平スケーリングをどのようにサポートしていますか? Java フレームワークはマイクロサービスの水平スケーリングをどのようにサポートしていますか? Jun 04, 2024 pm 04:34 PM

Java フレームワークは、マイクロサービスの水平拡張をサポートします。具体的な方法は次のとおりです。 Spring Cloud は、サーバー側とクライアント側の負荷分散のために、Ribbon と Feign を提供します。 NetflixOSS は、サービス検出、負荷分散、フェイルオーバーを実装するための Eureka と Zuul を提供します。 Kubernetes は、自動スケーリング、ヘルスチェック、自動再起動により水平スケーリングを簡素化します。

Golang マイクロサービス フレームワークを使用して分散システムを作成する Golang マイクロサービス フレームワークを使用して分散システムを作成する Jun 05, 2024 pm 06:36 PM

Golang マイクロサービス フレームワークを使用して分散システムを作成します。Golang をインストールし、マイクロサービス フレームワーク (Gin など) を選択し、Gin マイクロサービスを作成し、エンドポイントを追加してマイクロサービスをデプロイし、アプリケーションを構築して実行し、注文と在庫のマイクロサービスを作成し、注文と在庫を処理するエンドポイント Kafka などのメッセージング システムを使用してマイクロサービスに接続する sarama ライブラリを使用して注文情報を生成および消費する

Java フレームワークのマイクロサービス アーキテクチャのデータ整合性保証 Java フレームワークのマイクロサービス アーキテクチャのデータ整合性保証 Jun 02, 2024 am 10:00 AM

マイクロサービス アーキテクチャにおけるデータ整合性の保証は、分散トランザクション、結果整合性、更新の損失という課題に直面しています。戦略には次のものが含まれます。 1. 分散トランザクション管理、サービス間のトランザクションを調整します。 2. 結果整合性。メッセージ キューを介した独立した更新と同期を可能にします。 3. 同時更新をチェックするためのオプティミスティック ロックを使用します。

Spring Boot はマイクロサービス アーキテクチャにおいてどのような役割を果たしますか? Spring Boot はマイクロサービス アーキテクチャにおいてどのような役割を果たしますか? Jun 04, 2024 pm 02:34 PM

SpringBoot は、アノテーションベースの自動構成を提供し、データベース接続などの一般的な構成タスクを処理することで、マイクロサービス アーキテクチャでの開発とデプロイメントを簡素化する上で重要な役割を果たします。コントラクトのテストを通じて API コントラクトの検証をサポートし、サービス間の破壊的な変更を削減します。実稼働環境でのマイクロサービスの管理を容易にするためのメトリクス収集、監視、ヘルスチェックなどの実稼働対応の機能を備えています。

Java フレームワークでのマイクロサービス アーキテクチャの監視と警告 Java フレームワークでのマイクロサービス アーキテクチャの監視と警告 Jun 02, 2024 pm 12:39 PM

Java フレームワークでのマイクロサービス アーキテクチャの監視とアラート マイクロサービス アーキテクチャでは、システムの健全性と信頼性の高い動作を確保するために監視とアラートが重要です。この記事では、Java フレームワークを使用してマイクロサービス アーキテクチャの監視と警報を実装する方法を紹介します。実際のケース: SpringBoot+Prometheus+Alertmanager1 を使用します。Prometheus@ConfigurationpublicclassPrometheusConfig{@BeanpublicSpringBootMetricsCollectorspringBootMetric を統合します。

Java フレームワークを使用してマイクロサービス アーキテクチャを構築する際の課題は何ですか? Java フレームワークを使用してマイクロサービス アーキテクチャを構築する際の課題は何ですか? Jun 02, 2024 pm 03:22 PM

Java フレームワークを使用してマイクロサービス アーキテクチャを構築するには、次のような課題があります。 サービス間通信: REST API、HTTP、gRPC、メッセージ キューなどの適切な通信メカニズムを選択します。分散データ管理: データの一貫性を維持し、分散トランザクションを回避します。サービスの検出と登録: SpringCloudEureka や HashiCorpConsul などのメカニズムを統合します。構成管理: SpringCloudConfigServer または HashiCorpVault を使用して構成を一元管理します。モニタリングと可観測性: Prometheus と Grafana を統合してインジケーターをモニタリングし、SpringBootActuator を使用して運用インジケーターを提供します。

PHP フレームワークとマイクロサービス: データの一貫性とトランザクション管理 PHP フレームワークとマイクロサービス: データの一貫性とトランザクション管理 Jun 02, 2024 pm 04:59 PM

PHP マイクロサービス アーキテクチャでは、データの一貫性とトランザクション管理が重要です。 PHP フレームワークは、これらの要件を実装するためのメカニズムを提供します。Laravel の DB::transaction などのトランザクション クラスを使用して、トランザクション境界を定義します。 Doctrine などの ORM フレームワークを使用して、lock() メソッドなどのアトミック操作を提供し、同時実行エラーを防ぎます。分散トランザクションの場合は、Saga や 2PC などの分散トランザクション マネージャーの使用を検討してください。たとえば、オンライン ストアのシナリオでは、ショッピング カートに追加する際のデータの一貫性を確保するためにトランザクションが使用されます。これらのメカニズムを通じて、PHP フレームワークはトランザクションとデータの一貫性を効果的に管理し、アプリケーションの堅牢性を向上させます。

See all articles