Springcloud的核心组件之Ribbon

上篇文章详细介绍了springcloud的注册中心Eureka,那么这篇文章则会介绍springcloud的另外一个组件Spring Cloud Ribbon以及我们较为熟知同样起到了负载均衡作用的Nginx,二者又有怎样的区别呢?

Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用。 Spring Cloud Ribbon虽只是一个工具类框架,它在服务体系中起着重要作用,它不像服务注册中心、配置中心、API网关那样需要独立部署,但是它几乎存在于每一个Spring Cloud构建的微服务基础设施中。

如何集成Ribbon?

① 首先引入Ribbon依赖

其实这里不引用ribbon依赖也是可以的,因为在spring-cloud-starter-netflix-eureka-client依赖中已经包含了Ribbon Starter。

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-ribbon</artifactId>
</dependency>

② 在启动类中添加@EnableDiscoveryClient注解

@EnableDiscoveryClient
@EnableEurekaClient
@SpringBootApplication
public class SpringcloudClientApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcloudClientApplication.class, args);
}
}

③ RestTemplate的使用

提到Ribbon就必须要介绍一下RestTemplate!RestTemplate是Spring提供的一个访问Http服务的客户端类! 传统情况下访问restful服务,一般使用Apache的HttpClient。不过这种方式使用太过繁琐。spring提供了一种简单便捷的模板类进行操作,也就是RestTemplate类。

如下所示:

/**
* LoadBalanced:使RestTemplate以负载均衡的方式调用服务
* @return
*/
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
 

④验证Ribbon的负载均衡

代码案例:

思路:1.启用注册中心,2.创建两个服务提供者,3.创建服务消费者,以restTemplate的方式调用服务提供者,查看ribbon组件是否以负载均衡的方式调用服务提供者。

1 :启动注册中心,可以参考之前的文章

注册中心启动,可以进群要源码

2:创建两个服务者,并启动

#服务端口    配置如下
server.port=8066
#服务名称
spring.application.name=provider-client
#服务地址
eureka.instance.hostname=localhost
#取消检索服务
eureka.client.fetch-registry=true
eureka.client.register-with-eureka=true #注册中心路径,表示向这个注册中心注册服务,如果向注册中心注册多个服务,用“,”进行分隔
eureka.client.serviceUrl.defaultZone=http://localhost:8011/eureka

3:创建控制器,提供服务,返回端口信息

@RestController
public class RibbonController {
@GetMapping("/testRibbon")
public String hello(String name , HttpServletRequest request){
//返回端口信息
return " 此时被调用的服务端口为: " + request.getServerPort() + " , hello " + name;
}
}

4:第二个服务提供者和上面类似只是配置文件的端口不一致

#服务端口
server.port=8077
#服务名称
spring.application.name=provider-client
#服务地址
eureka.instance.hostname=localhost
#取消检索服务
eureka.client.fetch-registry=true
eureka.client.register-with-eureka=true #注册中心路径,表示向这个注册中心注册服务,如果向注册中心注册多个服务,用“,”进行分隔
eureka.client.serviceUrl.defaultZone=http://localhost:8011/eureka

5:启动消费者,以RestTemplate方式调用

  • 配置文件如下:
#服务方端口
server.port=8091
#服务名称
spring.application.name=consumer-client-01
#服务地址
eureka.instance.hostname=localhost
eureka.instance.prefer-ip-address=true
eureka.instance.instance-id=consumer-client-01
#取消检索服务
eureka.client.fetch-registry=true
eureka.client.register-with-eureka=true
#注册中心路径,表示向这个注册中心注册服务,如果向注册中心注册多个服务,用“,”进行分隔
eureka.client.serviceUrl.defaultZone=http://localhost:8011/eureka
  • 使用RestTemplate类访问restful服务
@Configuration
public class RestTemplateTest {
/**
* 添加LoadBalanced,使RestTemplate以负载均衡的方式调用服务
* @Configuration:类上面务往添加@Configuration注解
* @return
*/
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
  • 创建控制器,调用服务提供者
@RestController
public class ConsumerController {
@Autowired
private RestTemplate restTemplate; //注入RestTemplate @GetMapping("/sayHello")
public String sayHello(String name){
String url = "http://provider-client/test?name=" + name;
String result = restTemplate.getForObject(url , String.class);
return result;
}
}
 

6:启动消费者服务,并查看注册中心注册情况

提供者和服务消费者成功注册到注册中心

7:访问服务消费者,验证服务调用是否以负载均衡方式

第一次访问端口为8066

第二次访问端口则为8077

发现两个服务提供者服务分别被调用了2次,说明Ribbon默认的负载均衡策略是轮询的方式。小伙伴们也可以多调用几次验证一下

Ribbon和Nginx的区别

Ribbon和Nginx都是起到负载均衡的作用,但是二者又有怎么样的区别呢??

Ribbon 是Netflix公司的一个处理负载均衡开源的项目,它是运行在服务端的负载均衡器,如下图。

Ribbon过程

如上图所示很清晰的描述了其工作原理就是Consumer端获取到了所有的服务列表之后,在其内部使用负载均衡算法,使用轮询的方式对多个服务进行调用。

nginx过程

相比Nginx我们可以看到的是Nginx是接收了所有的请求进行之后进行的负载均衡处理。

简单的总结来说:
Nginx: 服务器端负载均衡,ribbon在服务节点挂掉后,可以自动去除节点。
Ribbon:客户端负载均衡,nginx剔除不可用节点相对复杂。

欢迎关注公众号! 公众号回复:入群 ,扫码加入我们交流群!

扫码关注公众号获取更多学习资料

这样介绍Ribbon,从此任何问题也难不住你的更多相关文章

  1. springcloud(十二):Ribbon客户端负载均衡介绍

    springcloud(十二):Ribbon客户端负载均衡介绍 Ribbon简介 使用分布式微服务脚骨的应用系统,在部署的时候通常会为部分或者全部微服务搭建集群环境,通过提供多个实例来提高系统的稳定型 ...

  2. SpringCloud学习系列之二 ----- 服务消费者(Feign)和负载均衡(Ribbon)使用详解

    前言 本篇主要介绍的是SpringCloud中的服务消费者(Feign)和负载均衡(Ribbon)功能的实现以及使用Feign结合Ribbon实现负载均衡. SpringCloud Feign Fei ...

  3. spring cloud 微服务调用--ribbon和feign调用

    这里介绍ribbon和feign调用两种通信服务调用方式,同时介绍如何引入第三方服务调用.案例包括了ribbon负载均衡和hystrix熔断--服务降级的处理,以及feign声明式服务调用.例子包括s ...

  4. 从零开始学spring cloud(六) -------- Ribbon

    一.Ribbon介绍 Ribbon就是客户端侧负责均衡实现的一种方式,那么Ribbon是什么呢? Ribbon是Netflix发布的云中间层服务开源项目,其主要功能是提供客户端侧负载均衡算法.Ribb ...

  5. Spring Boot + Spring Cloud 构建微服务系统(二):服务消费和负载(Ribbon)

    使用RestTemplate调用服务 在上一篇教程中,我们是这样调用服务的,先通过 LoadBalancerClient 选取出对应的服务,然后使用 RestTemplate 进行远程调用. Load ...

  6. 服务消费和负载(Ribbon)

    使用RestTemplate调用服务 在上一篇教程中,我们是这样调用服务的,先通过 LoadBalancerClient 选取出对应的服务,然后使用 RestTemplate 进行远程调用. Load ...

  7. Spring Cloud微服务开发笔记5——Ribbon负载均衡策略规则定制

    上一篇文章单独介绍了Ribbon框架的使用,及其如何实现客户端对服务访问的负载均衡,但只是单独从Ribbon框架实现,没有涉及spring cloud.本文着力介绍Ribbon的负载均衡机制,下一篇文 ...

  8. Fluent Ribbon 第六步 StartScreen

    上一节,介绍了Toolbar的主要功能,说明了ToolBar的一些最基本用法,这一节,介绍Ribbon的一个重要功能startScreen, startScreen软件第一次启动,呈现的界面. 由于R ...

  9. Fluent Ribbon 第七步 状态栏

    上一节,介绍了StartScreen的主要功能,本节介绍Ribbon的另外一个小功能StatusBar,状态栏是脱离ribbon之外单独存在,可以单独使用的控件 其基本代码定义如下: <Flue ...

随机推荐

  1. Android Studio 3.3.1 向avd模拟器发送本地文件

    "工具栏/View/Tool Windows/Device File Pxplorer" 选择模拟器在找到对应的文件夹upload即可

  2. NGK算力生态建设者狂欢!SPC之后又有VAST!

    想致富,先挖矿.这句话已经成为了币圈的一句名言.挖矿一词始终贯穿着区块链以及数字加密领域. 据小道消息透露,NGK官最近将会推出两款挖矿产品---SPC星空币以及其子币VAST维萨币. 下面笔者就来一 ...

  3. 人物传记——Kyle Tedford:持之以恒的品质从哪里来?

    心理学家表示,95%的人类行为发生在无意识中,而大多数这种行为是由习惯引起的.习惯,就像我们大脑设定的程序.通过每日持续努力,你会把坚持的习惯节奏慢慢进入身体中,并且会很容易加持下去. 做事三分钟热度 ...

  4. JVM系列(四):java方法的查找过程实现

    经过前面几章的简单介绍,我们已经大致了解了jvm的启动框架和执行流程了.不过,这些都是些无关痛痒的问题,几行文字描述一下即可. 所以,今天我们从另一个角度来讲解jvm的一些东西,以便可以更多一点认知. ...

  5. canal数据同步的环境配置

    canal数据同步的环境配置:(适用于mysql) 前提:在linux和windows系统的mysql数据库中创建相同结构的数据库和表,我的linux中mysql是用docker实现的(5.7版本), ...

  6. Go benchmark 一清二楚

    前言 基准测试(benchmark)是 go testing 库提供的,用来度量程序性能,算法优劣的利器. 在日常生活中,我们使用速度 m/s(单位时间内物体移动的距离)大小来衡量一辆跑车的性能,同理 ...

  7. 大话Spark(6)-源码之SparkContext原理剖析

    SparkContext是整个spark程序通往集群的唯一通道,他是程序的起点,也是程序的终点. 我们的每一个spark个程序都需要先创建SparkContext,接着调用SparkContext的方 ...

  8. python3+tkinter实现的黑白棋,代码完整 100%能运行

    今天分享给大家的是采用Python3+tkinter制作而成的小项目--黑白棋 tkinter是Python内置的图形化模块,简单易用,一般的小型UI程序可以快速用它实现,具体的tkinter相关知识 ...

  9. FreeBSD 镜像站问题 @2021

    主要问题在于官方无论如何也不开放 rsync 且不接受镜像站的官方二级镜像申请. 多次联系均无二次联系,如邮件列表,大概五次,其中三次回应,两次无回应.其主要回复内容为"深表歉意,但台湾地区 ...

  10. Python编程中可能经常用到的函数

    1.os.walk() 一般用法为 import os ph=r'D:\temp\build' for root,dirs,files in os.walk(ph): print(root,dirs, ...