你的位置:首页 > 软件开发 > Java > SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

发布时间:2017-12-05 00:01:06
参考SpringCloud官网第16、17章16. Client Side Load Balancer: RibbonRibbon是一个客户端的负载均衡器,它提供对大量的HTTP和TCP客户端的访问控制。Feign也是用的Ribbon,所以在这一章你也可以用@FeignCli ...

SpringCloud学习笔记——Ribbon

参考SpringCloud官网第16、17章

16. Client Side Load Balancer: Ribbon

Ribbon是一个客户端的负载均衡器,它提供对大量的HTTP和TCP客户端的访问控制。Feign也是用的Ribbon,所以在这一章你也可以用@FeignClient

Ribbon的一个核心概念是命名的客户端。每个负载均衡器都是这个组件的全体的一部分,它们一起工作来连接到服务器,并且它们全体都有一个给定的名字。

Spring Cloud用RibbonClientConfiguration在ApplicationContext中创建一个新的全体,它包含一个ILoadBalancer、一个RestClient和一个ServerListFilter

16.1 How to Include Ribbon

SpringCloud学习笔记——Ribbon

16.2 Customizing the Ribbon Client

Spring Cloud可以让你自己完全控制Ribbon客户端,通过用@RibbonClient来声明额外的配置。例如

SpringCloud学习笔记——Ribbon

在这个例子中,这个客户端由RibbonClientConfiguration和FooConfiguration一起组成。

注意:本例中,FooConfiguration必须用@Configuration注解标注,但是它不应该在主Application Context的组件扫描之中,否则它将被所有的Ribbon客户端共享。如果你用@ComponentScan(或者@SpringBootApplication),那么你应该采取措施来避免它被包含到扫描的范围中。

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

16.3 Customizing default for all Ribbon Clients

通过@RibbonClients注解可以为所有的Ribbon客户端提供一个默认的配置。例如

SpringCloud学习笔记——Ribbon

 

说了这么多,那究竟怎么用呢?下面看示例演示

在这个示例中有三个角色:注册中心、服务提供方、服务消费方

SpringCloud学习笔记——Ribbon

服务提供方是eureka-demo-client,消费方是ribbon-demo,下面看下消费方是如何配置的

首先是pom.

SpringCloud学习笔记——Ribbon

其次是application.yml,也没什么特别的

SpringCloud学习笔记——Ribbon

最后是启动类

SpringCloud学习笔记——Ribbon

还有调用的类

SpringCloud学习笔记——Ribbon

先启动eureka-demo-server,然后再启动另外两个工程

SpringCloud学习笔记——Ribbon

浏览器访问消费方地址

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

哈哈哈,访问成功!!!

SpringCloud学习笔记——Ribbon

 

17. Declarative REST Client: Feign

Feign是一个声明式的Web服务客户端,它使得访问Web服务变得更容易。为了使用Feign,需要创建接口并且使用注解标注它。使用Feign的时候,Spring Cloud集成Ribbon和Eureka来提供一个具有负载均衡能力的HTTP客户端。

17.1 How to Include Feign

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

@FeignClient注解的value值是一个任意客户端的名字,这个名字被用于创建Ribbon负载均衡器。你还可以使用url属性来指定一个url。

Ribbon客户端想要发现"stores"这个服务的真实的物理地址。如果你的应用中使用的是Eureka,那么它将通过Eureka服务注册类解析。

17.2 Overriding Feign Defaults

SpringCloud学习笔记——Ribbon

 

SpringCloud学习笔记——Ribbon

 

接下来,用Feign演示如何调用

再新建一个工程feign-demo

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

SpringCloud学习笔记——Ribbon

 

原标题:SpringCloud学习笔记——Ribbon

关键词:Spring

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录