SpringCloud下使用Eureka的服务发现与消费
在之前的章节我们已经把服务注册到Eureka Server
,那么我们该怎么调用已经注册后的服务呢?
我们本章来简单的介绍我们具体该怎么调用服务节点
请求内容。
本章目标
消费Eureka
注册的服务节点
的请求信息。
构建项目
我们只需要创建一个服务节点项目
即可,因为服务提供者
也是消费者
,然后将本项目注册到之前编写的服务注册中心
,下载文章/eureka-server.html源码运行即可。
我们使用idea
开发工具创建一个SpringBoot
项目,对应的选择spring-boot-starter-web
、spring-cloud-starter-netflix-ribbon
、spring-cloud-starter-netflix-eureka-client
三个依赖,pom.xml
配置文件如下所示:
1 | <properties> |
添加完依赖后我们需要对本项目进行配置,让本项目注册到服务中心,在之前的章节/eureka-register-service.html有讲过,这里就不做过多的赘述。
配置Eureka客户端
打开XxxApplication
入口类,添加@EnableDiscoveryClient
注解,如下所示:
1 |
|
修改application.yml配置文件
下面我们修改application.yml
配置文件,添加Eureka Client
对应的配置信息,如下所示:
1 | # 服务名称 |
获取服务实例信息
如果你只是将服务注册到服务注册中心
也就是Eureka Server
上,到现在已经完全没有问题了,但是我们想要通过服务名
(spring.application.name
)来获取服务实例列表
该怎么操作呢?
本章内容涉及一点有关Ribbon
的知识点,我们通过添加依赖spring-cloud-starter-netflix-ribbon
就可以直接使用RestTemplate
类进行发送http请求
,而且RestTemnplate
可以直接使用服务名
进行发送请求!!!
实例化RestTemplate
spring-cloud-starter-netflix-ribbon
依赖并没有为我们实例化RestTemplate
,我们需要手动进行实例化,我采用@Bean
方式进行实例化,在XxxApplication
类内添加如下代码:
1 | /** |
在这里有个@LoadBalanced
注解,我们后续章节会对它详细的讲解,博客搜索关键字LoadBalanced
查询文章信息,不过如果你不添加并使用这个注解,你是没有办法通过服务名
直接发送请求的,会出现错误信息。
了解DiscoveryClient
我们需要创建一个发送请求
以及请求消费
的Controller
,如下所示:
1 | /** |
在上面代码中我们注入了DiscoveryClient
,这是一个接口类
,具体该接口的实现类是什么要取决你使用的是什么服务注册中心
,我们本章采用的Eureka
理所当然使用的是Eureka
实现类,源码可以查看org.springframework.cloud.netflix.eureka.EurekaDiscoveryClient
,在EurekaDiscoveryClient
内可以看到具体是怎么通过服务名
获取实例的列表,部分源码如下所示:
1 | @Override |
你如果对具体的源码执行流程感兴趣,可以使用断点来一步一步的观察。
在获取ServiceInstance
服务实例后,可以得到实例的一些基本信息如:
serviceId
:服务名称、服务的实例编号,也就是spring.application.name
配置信息host
:注册该实例的hostName
port
:注册该实例的端口号,对应server.port
配置信息uri
:服务地址metadata
:服务自定义的元数据map
集合
请求转发流程
执行流程:我们在访问
/consumer/index
请求地址时,会通过RestTemplate
转发请求访问http://hengboy-spring-cloud-eureka-consumer/consumer/logic
地址并返回信息this is home page
。
运行测试
我们的测试流程如下:
- 启动服务注册中心
- 启动本章项目
- 访问
http://localhost:20002/consumer/index
- 查看控制台输出内容是否有
this is home page
访问有多种形式,你可以浏览器直接访问地址,我通过curl
命令来访问地址,打开terminal
输入以下命令:
1 | curl http://localhost:20002/consumer/index |
请求正常,查看控制台输出内容如下所示:
1 | 2018-10-04 15:23:36.333 INFO 29075 --- [io-20002-exec-5] c.y.c.h.s.e.consumer.ConsumerController : 服务地址:192.168.1.75,服务端口号:20002,服务实例编号:HENGBOY-SPRING-CLOUD-EUREKA-CONSUMER,服务地址:http://192.168.1.75:20002 |
总结
本章通过Ribbon
简单的实现了服务节点的消费,通过RestTemplate
发送请求来获取响应内容,需要注意的是我们并不是通过IP
:Port
的形式,而是通过服务名
的形式发送请求,这都归功于@LoadBalanced
这个注解,这个注解在讲解Ribbon
时会详细的说明。
SpringCloud下使用Eureka的服务发现与消费