SpringCloud的Ribbon负载均衡

本文介绍了SpringCloud的Ribbon如何实现客户端负载均衡。Ribbon是一个基于Http和TCP的客户端负载均衡器,当与Eureka结合使用时,可以从注册中心获取服务列表并进行负载均衡。通过实例演示了Ribbon的配置和使用,展示了轮询和随机两种执行策略,实现了服务调用的均衡负载。
摘要由CSDN通过智能技术生成

SpringCloud的负载均衡

服务器端的负载均衡:在客户端向服务器端发送请求的时候,会先请求到负载均衡器,然后负载均衡器根据自身的算法来将请求转发给某台真正提供业务的服务器。然后该服务器将请求返回的数据给负载均衡器,再由负载均衡器将数据返回给客户端

客户端的负载均衡:在客户端的内部执行的一种算法,在向服务器端发送请求的时候,先执行自己的调度算法算出向哪台服务其发送请求,然后直接发送到该服务器。
特点:由客户端的内部程序实现,不需要额外的负载均衡器软硬件的投入。

springcloud的负载均衡有两种方式:

这篇先说Ribbon的负载均衡:

Ribbon实现客户端的负载均衡
Ribbon是一个基于Http和TCP客户端的负载均衡器。Ribbon可以通过客户端中配置的ribbonServerList服务端列表去轮训的访问以达到负载均衡的作用。当Ribbon和Eureka联合使用时,ribbonServerList会被DiscoveryEnableNIWSServerList重写,扩展成从Eureka注册中心获取服务端列表。同时它也会用NIWSDiscoveryPing来取代IPing,它将职责委托给Eureka来确定服务端是否已经启动。

下面通过实例来使用Ribbon实现负载均衡。

首先需要有一个服务注册中心eureka-server,还需要两个服务提供方。然后建立一个新的springboot,叫做eureka-ribbon。

这里写图片描述

启动eureka-server,first-service,second-service 可以看到如下界面,两个服务提供方都叫COMPUTE-SERVICE已经被注册进去。

这里写图片描述

然后开始编写eureka-ribbon的项目

首先在pom.xml中加入如下代码:

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.8.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值