上节我们学会了如何搭建一个eureka server服务,本节我们使用ribbon来实现服务间的调用。

前置条件:

1、创建几个工程

eureka-server
            |- 服务注册中心
        product-provider-8777
        product-provider-8778
        product-provider-8779
        product-provider-8780
            |- 服务提供者,提供商品查询服务,请求url为: http://host:port/product/selectOne/{productId},返回服务的端口、服务名和商品信息
            |- 上面四个product-provider-%d的工程代码都是一样的
            |- 8777 和 8778 一组,spring.application.name = product-provider-01
            |- 8779 和 8780 一组,spring.application.name = product-provider-02
        order-consumer
            |- 服务消费者,调用product-provider-%d服务,来完成商品信息的获取
            |- 访问url : http://host:port/orders/create/{providerId}/{productId}
                ** providerId 用来替换上面%d的值
                ** productId 商品编号,可以使用p0001、p0002、p0003

需求:

|- 在consumer工程中使用ribbon来完成provider工程的调用
    |- 调用 product-provider-01 时修改默认的负载均衡策略(轮询)采用自定义的随机策略

|- ribbon客户端立即初始化,服务端配置

ribbon:
eager-load:
enabled: true
clients: product-provider-8780 # 需要立即初始化的服务名

实现步骤:

1、eureka-server和product-provider功能没有什么特殊的地方,需要将8777和8778工程的spring.application.name的值改成product-provider-01另外2个修改成product-provider-02
    2、consumer工程
        |- 配置RestTemplate,需要加上@LoadBalanced注解,使之具有客户端负载均衡的能力(ribbon)
        |- 由于product-provider-01的负载均衡策略需要改变,因此需要配置RibbonClient
            ** 注意在RibbonClient中指定的配置文件不可在spring boot的主上下文中被扫描到,否则会是一个全局的配置,对所有的RibbonClient都会生效,如果需要对单独的RibbonClient
                     生效,则需要定义一个配置文件 RibbonProductProvider01Conf 这个可以在spring boot的主上下文中,里面的RibbonClient指定的配置文件 RibbonProductProvider01Configuration
                     必须要在spring boot的主上下文之外。

代码结构:

实现:

一、注册中心和服务提供者

这部分的代码都是普通的代码,没有什么需要注意的

二、服务消费者

1、定义RestTemplate

@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}

   注意: @LoadBalanced注解 加上即可

2、修改product-provider-01的负载均衡策略
    2.1、RibbonProductProvider01Configuration文件的编写

/**
* 注意: 此类不可被spring 的主上下文扫描到,否则就是全局配置,对所有的ribbon客户端都会起作用
* <p>
* 对 spring.application.name = product-provider-01 进行单独配置
* 修改对product-provider-01的负载均衡策略为随机访问,不在是默认的轮训访问
*
* @author huan.fu
* @date 2018/5/29 - 11:40
*/
@Configuration
public class RibbonProductProvider01Configuration { /**
* 设置负载均衡策略为 随机,默认是轮训
*
* @return
*/
@Bean
public IRule ribbonRule() {
return new RandomRule();
} }

可以进行配置的选项,以及默认值
    IClientConfig  DefaultClientConfigImpl
    IRule  ZoneAvoidanceRule
    IPing  DummyPing
    ServerList<Server>  ConfigurationBasedServerList
    ServerListFilter<Server>  ZonePreferenceServerListFilter
    ILoadBalancer  ZoneAwareLoadBalancer
    ServerListUpdater  PollingServerListUpdater

2.2、 RibbonProductProvider01Conf配置文件的编写

/**
* 对 spring.application.name = product-provider-01 进行单独配置
* 修改对product-provider-01的负载均衡策略为随机访问,不在是默认的轮训访问
*
* @author huan.fu
* @date 2018/5/29 - 11:40
*/
@RibbonClient(name = "product-provider-01", configuration = RibbonProductProvider01Configuration.class)
@Component
public class RibbonProductProvider01Conf { }

注意:@RibbonClient中的name的是服务提供者的spring.application.name的值,configuration指向上面编写的配置文件

3、编写控制层进行调用

/**
* 订单控制器
*
* @author huan.fu
* @date 2018/5/28 - 16:52
*/
@RestController
@RequestMapping("orders")
public class OrdersController { @Autowired
private RestTemplate restTemplate; /**
* 创建订单
*
* @param productId
* @return
*/
@GetMapping("create/{providerId}/{productId}")
public Map<String, Object> createOrders(@PathVariable String providerId, @PathVariable String productId) {
return restTemplate.getForObject("http://product-provider-" + providerId + "/product/selectOne/" + productId, Map.class);
} }

测试:

1、注册中心截图

2、运行结果

完整代码

https://gitee.com/huan1993/spring-cloud-parent/tree/master/ribbon

spring cloud ribbon的使用的更多相关文章

  1. 撸一撸Spring Cloud Ribbon的原理-负载均衡器

    在上一篇<撸一撸Spring Cloud Ribbon的原理>中整理发现,RestTemplate内部调用负载均衡拦截器,拦截器内最终是调用了负载均衡器来选择服务实例. 接下来撸一撸负载均 ...

  2. 笔记:Spring Cloud Ribbon 客户端配置详解

    自动化配置 由于 Ribbon 中定义的每一个接口都有多种不同的策略实现,同时这些接口之间又有一定的依赖关系,Spring Cloud Ribbon 中的自动化配置能够很方便的自动化构建接口的具体实现 ...

  3. 笔记:Spring Cloud Ribbon 客户端负载均衡

    Spring Cloud Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡工具,基于 Netflix Ribbon 实现,通过Spring Cloud 的封装,可以让我们轻松的将面向服 ...

  4. 为Spring Cloud Ribbon配置请求重试(Camden.SR2+)

    当我们使用Spring Cloud Ribbon实现客户端负载均衡的时候,通常都会利用@LoadBalanced来让RestTemplate具备客户端负载功能,从而实现面向服务名的接口访问. 下面的例 ...

  5. Spring Cloud微服务笔记(四)客户端负载均衡:Spring Cloud Ribbon

    客户端负载均衡:Spring Cloud Ribbon 一.负载均衡概念 负载均衡在系统架构中是一个非常重要,并且是不得不去实施的内容.因为负载均衡对系统的高可用性. 网络压力的缓解和处理能力的扩容的 ...

  6. 基于Spring cloud Ribbon和Eureka实现客户端负载均衡

    前言 本案例将基于Spring cloud Ribbon和Eureka实现客户端负载均衡,其中Ribbon用于实现客户端负载均衡,Eureka主要是用于服务注册及发现: 传统的服务端负载均衡 常见的服 ...

  7. 撸一撸Spring Cloud Ribbon的原理-负载均衡策略

    在前两篇<撸一撸Spring Cloud Ribbon的原理>,<撸一撸Spring Cloud Ribbon的原理-负载均衡器>中,整理了Ribbon如何通过负载均衡拦截器植 ...

  8. spring cloud Ribbon

    参考:https://www.jianshu.com/p/1bd66db5dc46 Ribbon 是什么 spring cloud ribbon 是一个基于HTTP 和 TCP 的客户端负载均衡工具, ...

  9. 第四章 客户端负载均衡:Spring Cloud Ribbon

    spring cloud ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡工具,它基于Netflix Ribbon 实现.通过Spring Cloud 的封装,可以轻松的将面向服务的R ...

  10. Spring Cloud Ribbon入门

    一.简介 Spring Cloud Ribbon是一个基于Http和TCP的客户端负载均衡工具,它是基于Netflix Ribbon实现的.它不像服务注册中心.配置中心.API网关那样独立部署,但是它 ...

随机推荐

  1. Linux高级之语句表达式

    表达式 表达式和语句是 C 语言中的基础概念.什么是表达式呢?表达式就是由一系列操作符和操作数构成的式子.操作符可以是 C 语言标准规定的各种算术运算符.逻辑运算符.赋值运算符.比较运算符等.操作数可 ...

  2. 一篇文章搞懂Nginx

    Nginx 的产生 Nginx 同 Apache 一样都是一种 Web 服务器.基于 REST 架构风格,以统一资源描述符(Uniform Resources Identifier)URI 或者统一资 ...

  3. [Python]爬虫获取知乎某个问题下所有图片并去除水印

    获取URL 进入某个知乎问题的主页下,按F12打开开发者工具后查看network面板. network面板可以查看页面向服务器请求的资源.资源的大小.加载资源花费的时间以及哪些资源加载失败等信息.还可 ...

  4. 关于PHP的方法参数类型约束

    在之前的文章PHP方法参数的那点事儿中,我们讲过关于PHP方法参数的一些小技巧.今天,我们带来的是更加深入的研究一下PHP中方法的参数类型. 在PHP5之后,PHP正式引入了方法参数类型约束.也就是如 ...

  5. html 表单input disabled属性提交后台无法获得数据

    在input上加入disabled属性后, 点击提交会遗漏该值, 有两个办法: 一 可以考虑readonly属性,一样的不可修改操作,但是可以提交 二 在提交时 js 代码操作去除input上的dis ...

  6. npm WARN ajv-keywords@2.1.1 requires a peer of ajv@^5.0.0 but none is installed. You must install peer dependencies yourself.

    解决: npm install -g npm-install-peers npm install -g npm npm i ajv 但是好像没啥用

  7. Modern PHP 使用生成器yield 处理csv文件 Generator

    * 使用生成器处理csv文件 <?php function getRows($file) { $handle = fopen($file, 'rb'); if ($handle === fals ...

  8. Linux文件(夹)属性与权限

    文件属性与权限,文件权限设置 参考资料:鸟哥的Linux私房菜 用户与用户组 Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这 ...

  9. jquery中请求格式

    $.ajax({ url:"/ceshi/", type:"get", cache:false, dataType:"json", data ...

  10. 从产业链、架构和技术三个层面,看元宇宙与RPA的发展关系

    你可能还不知道,元宇宙也将带动RPA高速发展 一文读懂RPA如何赋能元宇宙,虚拟空间更需要RPA无处不在 三个层面,解读元宇宙如何利好RPA行业发展 从产业链.架构和技术三个层面,看元宇宙与RPA的发 ...