Spring Cloud通过Eureka或Consul等服务注册与发现组件来实现微服务间的相互感知。服务提供者将自己的服务信息注册到注册中心,服务消费者从注册中心获取服务提供者的信息,从而进行服务调用。
在Spring Cloud中,服务发现是一种机制,用于自动检测和定位分布式系统中的服务实例。它允许服务实例在启动时向服务注册中心注册自己的网络地址,并且服务消费者可以从服务注册中心查询和获取所需服务实例的网络地址。这样,服务消费者就可以通过服务发现机制动态地找到并调用服务提供者,而无需硬编码服务提供者的网络地址。
通过使用服务发现机制,Spring Cloud应用程序可以更加灵活和可靠地处理分布式系统中的服务调用和依赖关系。它可以有效地解决服务实例的动态变化、网络地址的变更以及服务的可用性和健康状态等问题,提高系统的可扩展性、容错性和可维护性。
服务发现的主要功能包括服务的注册、查询、注销以及服务健康检查。当服务提供者启动并注册到服务注册中心时,它的网络地址和服务信息将被存储在注册中心中。服务消费者可以通过查询注册中心来获取所需服务的网络地址列表,并根据负载均衡策略选择一个合适的服务实例进行调用。同时,服务注册中心还会定期检查已注册的服务实例的健康状况,如果某个服务实例出现故障或不可达,注册中心会将其标记为不健康并从服务列表中移除。
git代码仓库:springCloud-eureka: Eureka(服务注册和发现)的使用案例
从组件功能看:
黄色注册中心集群,分别部署在北京、天津、青岛机房;
红色服务提供者,分别部署北京和青岛机房;
淡绿色服务消费者,分别部署在北京和天津机房;
从机房分布看:
北京机房部署了注册中心、服务提供者和服务消费者;
天津机房部署了注册中心和服务消费者;
青岛机房部署了注册中心和服务提供者;
搭建服务注册中心(如Eureka Server),用于服务的注册和发现。
新建项目,选择Spring Initializr,JDK 1.8,选择默认的https://start.spring.io。
编辑Group和Artifact。
选择依赖,在Spring Cloud Discovery中选择Eureka Server。
项目命名,完成创建。
修改pom.xml文件,添加Eureka Server的依赖。
修改启动类,添加@EnableEurekaServer注解。
修改配置文件application.yml或application.properties,配置Eureka Server的相关参数,如服务端口、服务名称等。
server: port: 8761 # 指定服务端口 spring: application: name: eureka-server # 指定服务名称 eureka: client: service-url: defaultZone: http://localhost:8761/eureka/ # 指定服务注册中心的地址 server: enable-self-preservation: false # 禁用自我保护模式(仅建议开发环境使用)
注意,在配置文件中,defaultZone的值需要设置为Eureka Server的地址,如果是单机环境,可以设置为localhost。如果是集群环境,需要设置为其他Eureka Server的地址。
最后启动项目,访问http://localhost:8761/,即可看到Eureka Server的管理界面。