[SpringCloud] Eureka 与 Ribbon 简介

这篇具有很好参考价值的文章主要介绍了[SpringCloud] Eureka 与 Ribbon 简介。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、服务拆分

1、案例一:多端口微服务

2、案例二:服务远程调用

二、Eureka

1、Eureka 原理分析

2、Eureka 服务搭建(注册 eureka 服务)

3、Eureka 服务注册(注册其他服务)

4、Eureka 服务发现(服务拉取)

三、Ribbon 负载均衡 

1、负载均衡原理

2、负载均衡策略

3、饥饿加载


一、服务拆分

通过 2 个案例,学习如何实现服务拆分。

  • 都需要引入 web 的起步依赖:

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

1、案例一:多端口微服务

需求:

  • 将 Order 和 User 模块的服务进行拆分,通过不同的 URL 进行服务调用。

(1)项目结构

  • 为 2 个模块都添加上各自的 Controller;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(2)编写 Controller

  • 写一个简单的 Controller,在页面上显示字符串即可;
  • UserController 类似;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(3)设置不同的端口,启动 application

  • 为两个模块设置不同的服务器端口(user 设置 8081、order 设置 8080);

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 将 Order 模块和 User 模块的 Application 都启动起来;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 访问页面 /user/query 和 /order/query

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

2、案例二:服务远程调用

需求:

  • 在 Order 的实体类中包含了 User 类型的属性,当根据订单号获取订单信息时,由于 Order 和 User 的数据库访问也是独立的,导致 User 属性为 null。
  • 因此在 Order 模块中需要调用 User 模块的查询 user 的功能来获取 User 信息,再赋值给 Order。

(1)项目结构

  • 两个模块都需要创建对应的实体类;
  • Order 还需要创建 service 和 mapper;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(2)OrderController 和 UserController

  • 两个模块的 Controller 都需要添加相应的方法;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(3)OrderMapper 

  • 为了简单起见,这里不引入连接数据库操作;
  • 直接在 mapper 中实现返回一个 User 的方法;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(4)OrderSrevice

OrderSrevice 需要两个属性:OrderMapper 和 RestTemplate;

其中 RestTemplate 就是帮助我们实现远程服务调用的关键;

  • url 属性:表示发送的请求;
  • responseType 属性:表示返回的数据类型(默认是 JSON);
  • getForObject() 方法:表示发送 get 请求;
  • postForObject() 方法:表示发送 post 请求;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(5)启动两个模块的 application

  • 访问 /order/queryForOrderById/xxx;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

二、Eureka

1、Eureka 原理分析

观看下面视频:

08-Eureka-eureka原理分析_哔哩哔哩_bilibili

2、Eureka 服务搭建(注册 eureka 服务)

(1)创建 eureka 服务模块(eureka 为子工程)

  • 子工程的 pom 文件中引入依赖;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 父工程的 pom 文件做好依赖管理;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(2)编写 application 配置文件,注册 eureka

  • 设置服务端口;
  • 设置 eureka 服务名称;
  • 设置 eureka 服务地址;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

为什么 eureka 自身的服务地址信息也是 client?

  • eureka 也是一个微服务,所以 eureka 启动的时候,会将自己也注册到 eureka 上。
  • 这是为了 eureka 之间的集群通信,当有多个 eureka 时,defaultZone 就需要写上多个 URL。

(3)启动 application,访问 eureka

  • 为启动类添加 @EnableEurekaServer 注解;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 访问 localhost:10086/eureka,则会跳转到 eureka 的管理界面;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • instances 表示注册到 eureka 的服务示例(服务列表);

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

3、Eureka 服务注册(注册其他服务)

(1)引入依赖

  • 分别在 Order 模块和 User 模块的 pom 文件中,都添加上如下依赖;
  • 注意:使用的是客户端 client 的依赖;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(2)编写 eureka 地址信息

这一步骤跟前面的是一样的。

  • 设置服务端口;
  • 设置 eureka 服务名称;
  • 设置 eureka 服务地址;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(3)将 User 和 Order 的 application 都启动

  • 在 Service 中添加 SpringBoot 服务,即可一次性启动;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 访问 /localhost:10086,来到 eureka 管理页面;
  • 此时已经可以看到服务列表已经有 3 个服务了;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(4)多实例部署

如果我们想要 User 有多个服务实例可以添加到服务列表上,可以复制多几份 User 的运行配置。

  • 选中要复制的运行配置,点击复制;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 在 VM Option 中,添加参数 server.port = 一个没用过的端口;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 启动 5 个 application,观察服务列表;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  •  可以发现,Order 和 User 各多了 1 个服务;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

4、Eureka 服务发现(服务拉取)

服务发现就是服务拉取。

服务拉取是基于服务名称获取服务列表(比如获取 UserService 的服务列表,内含 2 个服务),然后在对服务列表做负载均衡

基于前面“服务拆分”的“案例二:服务远程调用”,我们来学习服务拉取。

(1)获取服务列表

  • 修改 OrderService 中的代码,用服务名代替 ip:port
  • (既然需要负载均衡,因此肯定无法指定 ip:port,所以使用服务名代替)

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(2)添加负载均衡注解 @LoadBalanced

  • 在 order-service 项目的启动类 OrderApplication 中的 RestTemplate 添加负载均衡注解:

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(3)启动 application,查询 Order

  • 启动下面 5 个 application;
  • 然后我们选择使用 8080 端口的 Order 来获取信息(也可以用 8083 的);

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 发送 4 次获取 Order 信息的请求,id 从 1~ 4;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

  • 观察 2 个 User 启动类的输出,都输出了 2 次信息;
  • 说明对 user-service 服务列表做到了负载均衡;

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

三、Ribbon 负载均衡 

Ribbon 是一个基于 HTTP 和 TCP 客户端的负载均衡的工具。

它可以在客户端的 application 配置文件中,配置 RibbonServerList(服务端列表),使用 HttpClient 或 RestTemplate 模拟 http 请求,但是步骤比较繁琐。

1、负载均衡原理

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

2、负载均衡策略

Ribbon 的负载均衡规则是一个叫做 IRule 的接口来定义的,每一个子接口都是一种规则。

(1)Java 可以使用的负载均衡规则

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

(2)负载均衡规则修改方法

默认情况下,使用的是 ZoneAvoidanceRule。

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java

需要注意的是:

  • 第一种方式,可以对所有 order-service 模块访问的服务列表做到负载均衡;(大)
  • 第二种方式,只能对配置文件中指定的 service 做到负载均衡;(小)

3、饥饿加载

Ribbon 默认是采用懒加载,即第一次访问时才会去创建 LoadBalanceClient,请求时间会很长。

而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

[SpringCloud] Eureka 与 Ribbon 简介,Spring,spring cloud,spring,后端,eureka,ribbon,java文章来源地址https://www.toymoban.com/news/detail-713472.html

  • enabled = true,表示开启饥饿加载;
  • clients = user-service,表示指定对 user-service 这个服务饥饿加载;
  • clients 其实是数组形式,可以协商多个服务;

到了这里,关于[SpringCloud] Eureka 与 Ribbon 简介的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [SpringCloud] Eureka 与 Ribbon 简介

    目录 一、服务拆分 1、案例一:多端口微服务 2、案例二:服务远程调用 二、Eureka 1、Eureka 原理分析 2、Eureka 服务搭建(注册 eureka 服务) 3、Eureka 服务注册(注册其他服务) 4、Eureka 服务发现(服务拉取) 三、Ribbon 负载均衡  1、负载均衡原理 2、负载均衡策略 3、饥饿加载

    2024年02月08日
    浏览(37)
  • 【合集】Spring Cloud 组件——架构进化史话 & Eureka,Nacos,Apollo,OpenFeign,Ribbon,Sentinel,Gateway ,Seata+事务. . .

    Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁,领导选举,分布式会话,集群状态)。 注意: 首先,尽管Spring Cloud带有“Cloud”这个单词,但它并不是云计算解

    2024年02月03日
    浏览(179)
  • 导入SpringCloud-Eureka依赖的问题Cannot resolve org.springframework.cloud:spring-cloud-starter-netflix-eure

    今天使用SpringCloud时遇到导入SpringCloud-Eureka依赖的问题 Cannot resolve org.springframework.cloud:spring-cloud-starter-netflix-eureka-server:unknown 网上搜了一下,回答多的五花八门,但是不够简单粗暴,这里介绍一个简单的方法,只需要在项目的pom文件中做些设置即可 把大象放进冰箱里需要几步

    2024年02月14日
    浏览(44)
  • spring cloud 之 ribbon

    Spring Cloud Ribbon 是基于 Netflix Ribbon 实现的一套客户端负载均衡的工具, 主要功能是提供客户端负载均衡算法和服务调用 。简单的说,就是在配置文件中列出 Load Balance( LB: 将用户的请求平摊的分配到多个服务上 )后面的所有机器,Ribbon 会自动的帮助我们基于某种规则(如

    2024年02月12日
    浏览(37)
  • Spring Cloud Ribbon:负载均衡

    1. 介绍 Spring Cloud Ribbon 1.1 什么是 Spring Cloud Ribbon Spring Cloud Ribbon是Netflix开源的负载均衡器,它为分布式服务提供了客户端负载均衡的功能。Ribbon可以根据一系列的负载均衡算法和配置策略,将客户端的请求动态分发到多个服务实例上,以实现高可用性和性能优化。 1.2 负载均

    2024年02月19日
    浏览(43)
  • 【Spring Cloud 四】Ribbon负载均衡

    【Spring Cloud一】微服务基本知识 【Spring Cloud 三】Eureka服务注册与服务发现 目前公司项目使用的注册中心主要是Spring Cloud Alibaba的Nacos做的注册中心和配置中心。并且Nacos使用了Ribbon作为默认的负载均衡器。但是相当于将Ribbon的负载均衡给透明化了,日常开发明面上是看不到

    2024年02月14日
    浏览(49)
  • Spring Cloud学习笔记(Ribbon):Ribbon的应用样例

    这是本人学习的总结,主要学习资料如下 - 马士兵教育 我们都知道 Ribbon 是用于负载均衡的。提供同一种服务的 Client 可能有多个,比如有多个 User Client 提供查询用户信息的服务,使用 Ribbon 就能简单地达到负载均衡的效果。 想要使用 Ribbon ,无论是服务提供者还是调用服务

    2024年04月25日
    浏览(36)
  • 【Spring Cloud系列】- Ribbon详解与实战

    在前面的文章 Eureka详解与实战、Eureka Client应用、RestTemplate详解及其负载均衡几篇文章中,已经介绍了Spring Cloud基本应用,本文将从讲解在进程层面的负载均衡,在Spring Cloud中如何使用Ribbon做系统应用层面的负载均衡使用。 Ribbon 是netflix 公司开源的基于客户端的负载均衡组件

    2024年02月15日
    浏览(41)
  • Spring Boot 中的 Spring Cloud Ribbon:什么是它,原理及如何使用

    在分布式系统中,服务之间的通信是非常重要的。在大型的分布式系统中,有许多服务需要相互通信,而这些服务可能会部署在多个服务器上。为了实现服务之间的通信,开发人员需要编写大量的代码来处理负载均衡、故障转移和服务发现等问题。为了简化这个过程,Spring

    2024年02月12日
    浏览(38)
  • 【Spring Cloud】Nacos及Ribbon组件的使用

    🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《Spring Cloud》。🎯🎯 👉点击这里,就可以查看我的主页啦!👇👇 Java方文山的个人主页 🎁如果感觉还不错的话请给我点赞吧!🎁🎁 💖期待你的加入,一起

    2024年01月25日
    浏览(62)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包