ユーレカサービス管理
サービスガバナンスとは何ですか?
SpringCloudは、カプセル化Netflitは、サービス管理を実装するためにユーレカモジュールを開発しました。
リモートRPC呼び出しの伝統的な枠組みの中で、各サービスおよびサービス管理の間の依存性は、ガバナンスのサービスを使用する必要があるので、より複雑であり、サービスおよびサービス管理の間の依存性は、サービスコール、負荷分散、フォールトトレランスを実現することができ、達成発見と登録サービス。
登録および検出サービスとは何ですか?
ユーレカサーバーサービスの登録とCSの設計アーキテクチャ、ユーレカServerを使用して、彼は、登録センターサービスです。そして、他のマイクロサービスシステムは、保守要員をユーレカサーバーに接続して、ハートビート接続を維持するために、クライアントを使用して、このようなシステムは、ユーレカサーバーで適切に機能している各サービスシステムで監視することができます。
サービス登録と発見には、登録センターがあります。登録センターに到達するために、エイリアス方法を変更するために|(サービスプロバイダ消費者)のサーバが起動すると、レジストリに登録方法エイリアス、および他になど、そのようなサービスの住所、メールアドレスなどのサーバ情報を所有するとき実際のサービスのアドレス、およびローカルRPCを実装するには、心のコアフレームの先端にRPCコールを呼び出します。そのレジストリ、なぜなら各サービスの管理とサービス(サービスガバナンスの概念)のレジストリの依存関係の使用、リモートRPCのいずれかフレームワークは、レジストリ(ストレージサービスアドレス情報(インターフェースアドレス))が存在することになります
ユーレカサーバーとユーレカクライアント:エウレカは2つのコンポーネントで構成され
1、ユーレカサーバー:提供サービスレジストリサービス(スタートアップクラスに追加@EnableEurekaServer)
ノード構成によって開始各マイクロサービス後、EurekaServerに登録され、EurekaServerは、レジストリ内のサービス情報のすべての情報サービスノードを格納するように、サービスノードは、視覚的インタフェースで直接見ることができます。
Mavenの依存性:
古いバージョン(2018年)の前にEurekaServer
<依存>
<groupIdを> org.springframework.cloud </ groupIdを>
<たartifactId>ばねクラウドスタータユーレカ</たartifactId>
</依存関係>
今ユーレカ(現在は2020.2を使用して)サーバーの新バージョン
<依存>
<groupIdを> org.springframework.cloud <groupIdを>
<たartifactId>ばねクラウドスタータのNetflix、ユーレカサーバ</たartifactId>
</依存関係>
YML配置:
サーバ:
ポート: 7001
ユーレカ:
インスタンス:
#ユーレカサーバーインスタンス名(サーバーIP)
ホスト名:eureka7001.com
クライアント:
#偽の表現は、レジストリに自身を登録しません
登録は -with-ユーレカ:偽
#偽表現自身の終わりには、レジストリで、私の義務は、インスタンスを維持することで、サービスを検索する必要はありません。
フェッチ -registry:偽
サービス - URL:
#ユーレカアドレス検索サービスおよび登録サービスと対話するための設定サーバーは、このアドレスに依存する必要があります。
# 1 :スタンドアローンは、独自のです
defaultzone:HTTP:// eureka7001.com:7001/eureka/
#クラスターは、他のユーレカと呼ばれます
Defaultzone#:HTTP:// eureka7002.com:7002/eureka/
#@@@@自己保護メカニズム[閉じる] @@@ ##################### ######################################
#サーバー:
##クローズ自己保護メカニズム、サービスを追い出さなければ時間内に利用可能でないことを確認するために、
#有効 -selfを-保存:偽
##サービスが利用できない2秒を提案
#立ち退き -intervalタイマー・イン・MS:2000
2、レジストリを介してアクセス可能なユーレカクライアント(@EnableEurekaClientが起動クラスに追加)
是一个java客户端,用于简化Eureka Server 的交互,客户端同时也具备一个内置的、使用轮询(round-robin)负载算法的负载均衡器,在应用启动后,将会向Eureka Server发送心跳(默认周期30秒)。如果Eureka Server 在多个心跳周期内没有接受到某个节点的心跳, EurekaServer将会从服务注册表中移除节点(默认90秒)
Maven依赖:
<!--eureka client-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
Yml配置
server: port: 8001 eureka: client: # 表示是否将自己注册进Eureka Server 默认为true register-with-eureka: true # 是否从EurekaServer 抓取已有的注册信息,默认为true。单节点为所谓,集群必须设置为true才能配合ribbon使用负载均衡 fetchRegistry: true # 注册中心地址 service-url: # 单机版注册地址 # defaultZone: http://localhost:7001/eureka # 集群版 defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka # 实例ID instance: instance-id: payment8001 # 访问路径可以显示IP地址 prefer-ip-address: true # Eureka 客户端向服务端发送心跳的时间间隔,单位为秒(默认是30秒) # lease-renewal-interval-in-seconds: 1 # Eureka服务端在收到最后一次心跳后的等待时间上线,单位为秒(默认是90秒),超时将剔除服务 # lease-expiration-duration-in-seconds: 2 spring: application: name: cloud-payment-service
微服务RPC远程调用的最核心的是高可用
所以搭建集群的Eureka注册中心,实现负载均衡加容错。
EurekaServer集群原理:互相注册,相互守望
单机集群配置:
找到C:\Windows\System32\drivers\etc\hosts文件:
修改映射配置加入hosts文件中:
127.0.0.1 eureka7001.com
127.0.0.1 eureka7002.com
集群修改yml注册中心地址:7001指向7002, 7002指向7001
server: port: 7001 eureka: instance: # eureka 服务端的实例名称 hostname: eureka7001.com client: # false 表示不向注册中心注册自己 register-with-eureka: false #false 表示自己端就是注册中心,我的职责就是维护实例,并不需要去检索服务 fetch-registry: false service-url: # 设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址 defaultZone: http://eureka7002.com:7002/eureka/
server: port: 7002 eureka: instance: # eureka 服务端的实例名称 hostname: eureka7002.com client: # false 表示不向注册中心注册自己 register-with-eureka: false #false 表示自己端就是注册中心,我的职责就是维护实例,并不需要去检索服务 fetch-registry: false service-url: # 设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址 defaultZone: http://eureka7001.com:7001/eureka/
项目启动注意:
应该先启动服务注册中心(7001、7002),然后再去启动服务提供者与服务消费者
通过接口显示注册中心的注册信息:
启动类上添加: @EnableDiscoveryClient
@Resource private DiscoveryClient discoveryClient; @GetMapping("payment/discovery") public Object discovery(){ List<String> services = discoveryClient.getServices(); for (String service : services) { log.info("********service: " + service); } List<ServiceInstance> instances = discoveryClient.getInstances("CLOUD-PAYMENT-SERVICE"); for (ServiceInstance instance : instances) { log.info(instance.getServiceId()+ "\t" + instance.getHost()+ "\t" + instance.getPort() + "\t" + instance.getUri()); } return this.discoveryClient; }