Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >SpringCloud组件:Eureka的服务发现与消费

SpringCloud组件:Eureka的服务发现与消费

作者头像
恒宇少年
发布于 2018-10-10 09:16:18
发布于 2018-10-10 09:16:18
1.2K00
代码可运行
举报
运行总次数:0
代码可运行

在之前的章节我们已经把服务注册到Eureka Server,那么我们该怎么调用已经注册后的服务呢?

我们本章来简单的介绍我们具体该怎么调用服务节点请求内容。

本章目标

消费Eureka注册的服务节点的请求信息。

构建项目

我们只需要创建一个服务节点项目即可,因为服务提供者也是消费者,然后将本项目注册到之前编写的服务注册中心,下载文章SpringCloud组件:搭建Eureka服务注册中心源码运行即可。

我们使用idea开发工具创建一个SpringBoot项目,对应的选择spring-boot-starter-webspring-cloud-starter-netflix-ribbonspring-cloud-starter-netflix-eureka-client三个依赖,pom.xml配置文件如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
......
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.5.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <spring-cloud.version>Finchley.SR1</spring-cloud.version>
</properties>

<dependencies>
    <!--Web依赖-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!--ribbon-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
    </dependency>
    <!--client-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>
......

添加完依赖后我们需要对本项目进行配置,让本项目注册到服务中心,在之前的章节SpringCloud组件:将微服务提供者注册到Eureka服务中心有讲过,这里就不做过多的赘述。

配置Eureka客户端

打开XxxApplication入口类,添加@EnableDiscoveryClient注解,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@SpringBootApplication
@EnableDiscoveryClient
public class SpringCloudEurekaConsumerApplication {
 //...
}
修改application.yml配置文件

下面我们修改application.yml配置文件,添加Eureka Client对应的配置信息,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 服务名称
spring:
  application:
    name: hengboy-spring-cloud-eureka-consumer
# 启动端口号
server:
  port: 20002
# Eureka 服务注册中心配置
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10000/eureka/
  # 配置优先使用IP地址注册服务
  instance:
    prefer-ip-address: true

获取服务实例信息

如果你只是将服务注册到服务注册中心也就是Eureka Server上,到现在已经完全没有问题了,但是我们想要通过服务名(spring.application.name)来获取服务实例列表该怎么操作呢?

本章内容涉及一点有关Ribbon的知识点,我们通过添加依赖spring-cloud-starter-netflix-ribbon就可以直接使用RestTemplate类进行发送http请求,而且RestTemnplate可以直接使用服务名进行发送请求!!!

实例化RestTemplate

spring-cloud-starter-netflix-ribbon依赖并没有为我们实例化RestTemplate,我们需要手动进行实例化,我采用@Bean方式进行实例化,在XxxApplication类内添加如下代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 实例化RestTemplate对象实例
 *
 * @return
 */
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
    return new RestTemplate();
}

在这里有个@LoadBalanced注解,我们后续章节会对它详细的讲解,博客搜索关键字LoadBalanced查询文章信息,不过如果你不添加并使用这个注解,你是没有办法通过服务名直接发送请求的,会出现错误信息。

了解DiscoveryClient

我们需要创建一个发送请求以及请求消费Controller,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 消费者控制器
 *
 * @author:于起宇 <p>
 * ================================
 * Created with IDEA.
 * Date:2018/9/29
 * Time:5:55 PM
 * 简书:http://www.jianshu.com/u/092df3f77bca
 * 码云:https://gitee.com/hengboy
 * GitHub:https://github.com/hengyuboy
 * ================================
 * </p>
 */
@RestController
@RequestMapping(value = "/consumer")
public class ConsumerController {
    /**
     * logger instance
     */
    static Logger logger = LoggerFactory.getLogger(ConsumerController.class);
    /**
     * 注入服务客户端实例
     */
    @Autowired
    private DiscoveryClient discoveryClient;
    /**
     * 注入restTemplate模板
     */
    @Autowired
    private RestTemplate restTemplate;

    /**
     * 服务消费者业务逻辑方法
     * 该方法使用restTemplate访问获取返回数据
     *
     * @return
     */
    @RequestMapping(value = "/logic")
    public String home() {
        return "this is home page";
    }

    /**
     * 请求地址
     * 输出服务的基本信息
     */
    @RequestMapping(value = "/index")
    public void index() {
        discoveryClient.getInstances("hengboy-spring-cloud-eureka-consumer")
                .stream()
                .forEach(
                        instance -> {
                            logger.info("服务地址:{},服务端口号:{},服务实例编号:{},服务地址:{}", instance.getHost(), instance.getPort(), instance.getServiceId(), instance.getUri());
                            String response = restTemplate.getForEntity("http://" + instance.getServiceId() + "/consumer/logic", String.class).getBody();
                            logger.info("响应内容:{}", response);
                        }

                );
    }
}

在上面代码中我们注入了DiscoveryClient,这是一个接口类,具体该接口的实现类是什么要取决你使用的是什么服务注册中心,我们本章采用的Eureka理所当然使用的是Eureka实现类,源码可以查看org.springframework.cloud.netflix.eureka.EurekaDiscoveryClient,在EurekaDiscoveryClient内可以看到具体是怎么通过服务名获取实例的列表,部分源码如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Override
public List<ServiceInstance> getInstances(String serviceId) {
    List<InstanceInfo> infos = this.eurekaClient.getInstancesByVipAddress(serviceId,
            false);
    List<ServiceInstance> instances = new ArrayList<>();
    for (InstanceInfo info : infos) {
        instances.add(new EurekaServiceInstance(info));
    }
    return instances;
}

你如果对具体的源码执行流程感兴趣,可以使用断点来一步一步的观察。

在获取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

运行测试

我们的测试流程如下:

  1. 启动服务注册中心
  2. 启动本章项目
  3. 访问http://localhost:20002/consumer/index
  4. 查看控制台输出内容是否有this is home page

访问有多种形式,你可以浏览器直接访问地址,我通过curl命令来访问地址,打开terminal输入以下命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
curl http://localhost:20002/consumer/index

请求正常,查看控制台输出内容如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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
......
2018-10-04 15:23:36.748  INFO 29075 --- [io-20002-exec-5] c.y.c.h.s.e.consumer.ConsumerController  : 响应内容:this is home page

总结

本章通过Ribbon简单的实现了服务节点的消费,通过RestTemplate发送请求来获取响应内容,需要注意的是我们并不是通过IP:Port的形式,而是通过服务名的形式发送请求,这都归功于@LoadBalanced这个注解,这个注解在讲解Ribbon时会详细的说明。

源码位置

有问题要问?

如果你有技术相关的问题想要咨询恒宇少年,请去博客首页左侧导航栏,点击知识星球微信扫码加入我的星球。

与恒宇少年面对面

如果你喜欢恒宇少年的相关文章,那么就去微信公众号(恒宇少年)关注我吧!!! 当然你也可以去 SpringCloud码云源码 项目底部扫描微信公众号二维码关注我,感谢阅读!!!

学习目录推荐

开源信息

这段时间一直在编写开源的相关框架,致力于公司使用的框架升级以及开源计划,将公司使用到的工具以及插件进行升级重构并且开源。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.10.04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
SpringCloud组件:你的Eureka服务注册中心安全吗?
在之前的章节我们讲到了SpringCloud组件:搭建Eureka服务注册中心,已经可以让我们自定义的微服务节点进行注册到该Eureka Server上,不过在注册过程中存在一个风险的问题,如果我们的Eureka Server的地址无意暴露在外,那岂不是通过Eureka协议创建的任意服务都可以进行注册到该Eureka Server吗?(当然如果你配置了服务器的安全组并且使用内网的IP地址或者主机名方式对外提供服务注册地址几乎不存在这个问题。)
恒宇少年
2018/10/11
1.5K0
服务发现与消费--Eureka与Ribbon的联手出击
服务消费者的目标只有两个:发现服务,消费服务。其中服务的发现由Eureka客户端提供,而服务的消费由Ribbon完成。
JathonKatu
2020/10/27
4750
服务发现与消费--Eureka与Ribbon的联手出击
SpringCloud组件:Eureka高可用集群部署
我们在之前的章节SpringCloud组件:搭建Eureka服务注册中心学习到了单个服务注册中心的创建,不过单模式的部署方式在实战中确实不太提倡,因为有很多种原因可能会导致服务注册中心宕机,如果宕机就会有一些灾难性的问题出现,所以保证服务注册中心处于活着运行状态显得尤为重要!!!
恒宇少年
2018/10/10
2.7K0
目录:SpringCloud核心技术学习目录
这段时间一直在编写开源的相关框架,致力于公司使用的框架升级以及开源计划,将公司使用到的工具以及插件进行升级重构并且开源。
恒宇少年
2018/09/20
9210
最适合新手入门的SpringCloud教程 6—Ribbon负载均衡「F版本」
写博客一个多月了,断断续续的更新,今天有小伙伴催更新了,很高兴,说明我的分享是有意义的。
鹿老师的Java笔记
2020/04/14
4600
SpringCloud组件:搭建Eureka服务注册中心
Eureka服务注册中心是netflix开源组织提供的一个服务高可用的解决方案,在前端时间一直在疯传的2.0开源流产的问题,其实并不影响我们的使用,netflix只不过是不再维护2.0分支的开源代码,所以做出了免责声明,不过对于我们使用者来说确实比较担心这一点,还有不少人更换服务注册中心,比如:zookeeper、consul。
恒宇少年
2018/10/10
7740
SpringCloud组件:搭建Eureka服务注册中心
SpringCloud组件: GateWay整合Eureka转发服务请求
在上一篇文章Spring Cloud GateWay 路由转发规则介绍中我们讲解了SpringCloud Gateway内部提供的断言、谓语,让我们可以组合更精确的业务场景进行请求,既然SpringCloud GateWay担任了网关的角色,在之前Zuul可以通过服务名进行自动转发,SpringCloud Gateway是否可以实现自动转发呢?
恒宇少年
2019/05/07
5.6K0
SpringCloud组件: GateWay整合Eureka转发服务请求
SpringCloud组件:将微服务提供者注册到Eureka服务中心
Eureka提供了Server当然也提供了Client,如果你对Eureka Server不了解,点击SpringCloud组件:搭建Eureka服务注册中心阅读文章查看具体的编码实现。
恒宇少年
2018/10/10
1.1K0
SpringCloud组件:将微服务提供者注册到Eureka服务中心
负载均衡Bibbon
Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用。Spring Cloud Ribbon虽然只是一个工具类框架,它不像服务注册中心、配置中心、API网关那样需要独立部署,但是它几乎存在于每一个Spring Cloud构建的微服务和基础设施中。因为微服务间的调用,API网关的请求转发等内容,实际上都是通过Ribbon来实现的,包括后续我们将要介绍的Feign,它也是基于Ribbon实现的工具。所以,对Spring Cloud Ribbon的理解和使用,对于我们使用Spring Cloud来构建微服务非常重要。
暴躁的程序猿
2022/03/24
5420
负载均衡Bibbon
Spring Cloud(三)服务提供者 Eureka + 服务消费者(rest + Ribbon)
Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡的工具。它是一个基于HTTP和TCP的客户端负载均衡器。它可以通过在客户端中配置ribbonServerList来设置服务端列表去轮询访问以达到均衡负载的作用。 Ribbon是什么? Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一起。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简单的说,就是在配置文件中列出Load Ba
程序员鹏磊
2018/02/09
1K0
Spring Cloud(三)服务提供者 Eureka + 服务消费者(rest + Ribbon)
Spring Cloud 系列之负载均衡 Ribbon
  Ribbon 是 Netflix 发布的负载均衡器,它有助于控制 HTTP 和 TCP 客户端的行为。为 Ribbon 配置服务提供者地址列表后,Ribbon 就可基于某种负载均衡算法,自动地帮助服务消费者去请求。Ribbon 默认为我们提供了很多的负载均衡算法,例如轮询、随机等。当然,我们也可为 Ribbon 实现自定义的负载均衡算法。Ribbon 现在已经进入维护状态,但目前仍在大规模使用,Spring Cloud 准备使用 LoadBalancer 作为 Ribbon 的替换方案。
Demo_Null
2020/11/11
9450
Spring Cloud 系列之负载均衡 Ribbon
SpringCloud---Eureka
Spring Cloud封装了Netflix 公司开发的Eureka模块来实现服务治理
大忽悠爱学习
2021/11/15
3590
Eureka 服务注册与发现
Spring Cloud封装了Netflix 公司开发的Eureka模块来实现服务治理
用户9615083
2022/12/25
6990
Eureka 服务注册与发现
springCloud - 第3篇 - 消费者调用服务 ( RestTemplate + Ribbon )
2. spring Initializr - module SDK 选择自己的 JDK ,其余的可以不用填写,next。
微风-- 轻许--
2019/08/01
7300
Spring Cloud 2.x系列之服务发现&服务消费者Ribbon
在《服务注册&服务提供者》这一篇可能学习了这么开发一个服务提供者,在生成上服务提供者通常是部署在内网上,即是服务提供者所在的服务器是与互联网完全隔离的。这篇说下服务发现(服务消费者),通常服务消费者是部署在与互联网联通的服务器上,提供restful接口给H5和App调用。
BUG弄潮儿
2022/06/30
2400
Spring Cloud 2.x系列之服务发现&服务消费者Ribbon
SpringCloud必会知识点最全(精美版)
Spring Cloud也是一样,它将现在非常流行的一些技术整合到一起,实现了诸如:配置管理,服务发现,智能路由,负载均衡,熔断器,控制总线,集群状态等等功能。
编程张无忌
2021/01/26
2K0
SpringCloud必会知识点最全(精美版)
SpringCloud服务发现注册Eureka +Ribbon + Feign
假设有2个微服务A和B分别在端点http:// localhost:8181 /和http:// localhost:8282 /上运行,如果想要在A服务中调用B服务,那么我们需要在A服务中键入B服务的url,这个url是负载均衡器分配给我们的,包括负载平衡后的IP地址,那么很显然,B服务与这个URL硬编码耦合在一起了,如果我们使用了服务自动注册机制,就可以使用B服务的逻辑ID,而不是使用特定IP地址和端口号来调用服务。
慕容千语
2019/06/11
1K0
springCloud学习2(服务发现)
  通常服务实例都只向一个服务发现实例注册,服务发现实例之间再通过数据传输,让每个服务实例注册到所有的服务发现实例中。   服务在向服务发现实例注册后,这个服务就能被服务消费者调用了。服务消费者可以使用多种模型来"发现"服务。
用户2038589
2018/12/28
5020
微服务架构之Spring Cloud入门
欢迎访问千羽的编程时光 https://nateshao.gitee.io或者原文获取更多精彩文章!
千羽
2021/01/14
7650
微服务架构之Spring Cloud入门
SpringCloud组件:将服务提供者注册到Eureka集群
在之前章节SpringCloud组件:将微服务提供者注册到Eureka服务中心已经讲解了把服务注册到单个Eureka Server节点上,既然我们在SpringCloud组件:Eureka高可用集群部署讲到了如何去构建Eureka Server 集群的问题,那么我们该考虑下怎么将服务注册到Eureka Server集群上呢?
恒宇少年
2018/10/10
1.9K0
推荐阅读
相关推荐
SpringCloud组件:你的Eureka服务注册中心安全吗?
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验