SpringCloud(一):Eureka服务注册与发现
一 Eureka介绍
按照官方介绍:
Eureka is a REST (Representational State Transfer) based service that is primarily used in the AWS cloud for locating services for the purpose of load balancing and failover of middle-tier servers. Eureka 是一个基于 REST 的服务,主要在 AWS 云中使用, 定位服务来进行中间层服务器的负载均衡和故障转移。
Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现。Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server,并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。Spring Cloud 的一些其他模块(比如Zuul)就可以通过 Eureka Server 来发现系统中的其他微服务,并执行相关的逻辑。
Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用作服务注册服务器。Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡
用一张图来认识一下:
上图简要描述了Eureka的基本架构,由3个角色组成:
1、Eureka Server 提供服务注册和发现
2、Service Provider 服务提供方 将自身服务注册到Eureka,从而使服务消费方能够找到
3、Service Consumer 服务消费方 从Eureka获取注册服务列表,从而能够消费服务
二 创建Maven项目 创建Maven项目作为我们的父工程
三 搭建Eureka服务
直接在当前父工程下创建model
选择Spring Cloud Discovery,然后勾选其中的Eureka Server,点击Next,
这里注意目录得是父工程下的单独一个目录
搭建完后修改配置文件,并在启动类加上@EnableEurekaServer的注解;
#端口号 server.port=8761 #服务名 spring.application.name=eureka-server #设置当前实例的主机名称 eureka.instance.hostname=localhost #是否注册自身到EureakServer上,默认为true;由于当前工程本身即是EurekaServer,所以设置为false; eureka.client.register-with-eureka=false #标识是否从Eureka Server获取注册信息,默认为true;由于当前工程本身即是EurekaServer,所以设置为false; eureka.client.fetch-registry=false #设置Eureka的地址 eureka.client.service-url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
@EnableEurekaServer @SpringBootApplication public class EurekaServerApplication { public static void main(String[] args) { SpringApplication.run(EurekaServerApplication.class, args); } }
配置完成后启动项目,打开浏览器输入localhost:8761,页面如下,至此EurekaServer服务搭建成功。
四 搭建EurekaClient服务 同样在父工程下创建Model,步骤与搭建Server服务类似,这里不再一一阐述,步骤如下图所示:
搭建完后在eureka-client中添加web依赖
<!--添加web依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
修改配置文件,并在启动类上添加@EnableEurekaClient注解,最后启动项目即可。
#端口号 server.port=8080 #服务名 spring.application.name=eureka-client eureka.client.healthcheck.enable=true eureka.client.service-url.defaultZone=http://127.0.0.1:8761/eureka/
@EnableEurekaClient @SpringBootApplication public class EurekaClientApplication { public static void main(String[] args) { SpringApplication.run(EurekaClientApplication.class, args); } }
启动项目进入Eureka注册中心即可发现 eureka-client服务已被注册
注:先启动eureka-server服务 再启动别的服务不然会报错找不到注册中心
过程中如果有小伙伴遇到问题或者有好的见解可以及时联系