目录
远程调用的问题
服务消费者该如何获取服务提供者的地址信息?
如果有多个服务提供者,消费者该如何选择?
消费者该如何得知服务提供者的健康状态?
Eureka原理
eureka的作用
服务消费者该如何获取服务提供者的地址信息?
服务提供者启动时向eureka提供自己的信息
eureka保存这些信息
消费者根据服务名称向eureka拉取服务提供者信息
如果有多个服务提供者,消费者该如何选择?
服务消费者根据负载均衡算法,从服务列表中挑选一个
消费者该如何得知服务提供者的健康状态?
服务提供者会每隔30s向EurekaService发送心跳请求,报告健康状态
eureka会更新记录服务列表信息,心跳不正常会被列表剔除
消费者就会拉取到最新最有效的信息
总结
在eureka架构中,微服务角色有两类:
eurekaserver:服务器,注册中心
记录服务信息
心跳监控
errekaclient:客户端
provider:服务提供者,例如user-service
注册自己的信息到eurekaservice
每隔30s向eurekaservice发送心跳
consumer:服务消费者,例如order-service
根据服务名称向eurekaservice拉取服务列表
基于服务列表做负载均衡,选中一个微服务后发起远程调用
搭建EurekaServer
步骤一
新建一个maven模块,在pom.xml中加入依赖
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
同时还要确保你的父工程也加入了这个模块。一般来说idea会给你自动加入
<modules>
<module>user-service</module>
<module>order-service</module>
<module>eureka-server</module>
</modules>
步骤二
编写启动类,此时你的项目是继承了父工程的依赖,你可以使用springboot的注解
@SpringBootApplication
@EnableEurekaServer //关键
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class,args);
}
}
步骤三
添加并配置application.xml文件
server:
port: 10088
spring:
application:
name: eurekaserver
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10088/eureka/
ok,步骤完了,此时我们可以通过浏览器输入
localhost:10088来检验一下
出现这些就说明你注册成功了
总结
引入eureka-server依赖
添加@EnableEurekaService注解
在application.yml中配置eureka地址
服务注册
在项目中引入以下依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency>
更新application.yml文件
在所有项目(服务中引入),并不只是一个项目。
项目启动后,我们登录注册中心的网站可以看到注册时服务不止一个了
总结
order-service虽然是消费者,但是和user-service都是eureka的client端,同样可以实现服务注册;
首先 导入依赖, 然后 修改application.yml文件
服务发现
在消费者的服务中实现服务拉取
服务拉取是基于服务名称获取服务列表,然后对服务列表做负载均衡
修改业务层的代码,修改访问路径,用服务名代替ip、端口。
将之前的localhost:8081修改为userservice
对RestTemlpate做负载均衡的注解
@Bean
@LoadBalanced //关键
public RestTemplate restTemplate(){
return new RestTemplate();
}
重新启动服务,依然可以得到对象
注册中心总结
搭建eurekaservice
引入eureka-service依赖
添加@EnableEurekaServer
在application.yml中配置eureka的地址
服务注册
引入eureka-client依赖
在application.yml中配置eureka地址
服务发现
引入eureka-client依赖
在application.yml中配置eureka地址
给RestTemplate添加负载均衡注解
用服务提供者的服务名称远程调用