SpringCloud微服务(02):Ribbon和Feign组件,服务调用和负载均衡
本文源码:GitHub·点这里 || GitEE·点这里
一、Ribbon简介
1、基本概念
Ribbon是一个客户端的负载均衡(Load Balancer,简称LB)器,它提供对大量的HTTP和TCP客户端的访问控制。
2、负载均衡简介
目前主流的负载均衡方案可分成两类:
1)集中式
即在服务的消费方和提供方之间使用独立的LB设施,可以是硬件,如F5,也可以是软件,如nginx,由该设施负责把访问请求通过某种策略转发至服务的提供方;
2)进程内
将LB逻辑集成到消费方,消费方从服务注册中心获取可用服务列表,然后根据指定负载均衡策略选择合适的服务器。Ribbon就属于该方式。
3、Ribbon负载策略
1) RoundRobinRule 轮询 轮询服务列表List<Server>的index,选择index对应位置的服务。 2) RandomRule 随机 随机服务列表List<Server>的index,选择index对应位置的服务。 3) RetryRule 重试 指定时间内,重试(请求)某个服务不成功达到指定次数,则不再请求该服务。
二、Feign简介
1、基本概念
Feign 是一个声明式的 Web Service 客户端。它的出现使开发 Web Service 客户端变得很简单。使用 Feign 只需要创建一个接口加上对应的注解,比如:@FeignClient 接口类注解。
2、执行流程
1) 主程序入口添加 @EnableFeignClients 注解开启对 FeignClient 接口扫描加载。接口使用@FeignClient注解。
2) 调用Feign 接口中的方法被时,通过JDK的代理的方式,生成具体的 RequestTemplate。
3) RequestTemplate 生成 Request请求,结合Ribbon实现服务调用负载均衡策略。
三、综合使用案例
1、项目结构图
1)、模块描述
Eureka注册中心 node02-eureka-7001 两个服务提供方 node02-provider-6001 node02-provider-6002 Ribbon服务调用 node02-consume-8001 Feign服务调用 node02-consume-8002
2)、依赖Eureka知识
上篇文章Eureka使用详解。
2、Ribbon服务调用
代码所属模块:node02-consume-8001
1)、核心依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> </dependency>
2)、配置文件
@Configuration public class LoadConfig { @Bean @LoadBalanced public RestTemplate getRestTemplate (){ return new RestTemplate() ; } @Bean public IRule getIRule (){ // 默认轮询算法 // return new RoundRobinRule() ; // 重试算法:默认情况,访问某个服务连续三次失败,就不会再访问 // return new RetryRule() ; // 随机算法 return new RandomRule() ; } }
3)、调用方式
@RestController public class ConsumeController { @Autowired private RestTemplate restTemplate ; String server_name = "http://NODE02-PROVIDER" ; // http://localhost:8001/showInfo @RequestMapping("/showInfo") public String showInfo (){ return restTemplate.getForObject(server_name+"/getInfo",String.class) ; } }
这里的NODE02-PROVIDER就是服务提供方的配置文件。两个服务提供方的这块配置相同,Ribbon正基于此,实现多个服务调用的负载均衡。
spring: application: name: node02-provider
4)、提供方接口
@RequestMapping("/getInfo") public String getInfo (){ LOG.info("provider-6002"); return "success" ; }
3、Feign服务调用
代码所属模块:node02-consume-8002
1)、核心依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> </dependency>
2)、配置文件
@FeignClient(value = "NODE02-PROVIDER") public interface GetAuthorService { @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET) String getAuthorInfo (@PathVariable("authorId") String authorId) ; }
3)、调用方式
@RestController public class ConsumeController { @Resource private GetAuthorService getAuthorService ; @RequestMapping(value = "/getAuthorInfo") public String getAuthorInfo () { return getAuthorService.getAuthorInfo("1") ; } }
4)、启动类注解
// 因为包名路径不同,需要加basePackages属性 @EnableFeignClients(basePackages={"cloud.block.code.service"})
5)、提供方接口
@RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET) public String getAuthorInfo (@PathVariable("authorId") String authorId) { LOG.info("provider-6002"); return "知了一笑"+authorId ; }
四、源代码地址
GitHub·地址 https://github.com/cicadasmile/spring-cloud-base GitEE·地址 https://gitee.com/cicadasmile/spring-cloud-base
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
SpringCloud微服务(01):Eureka组件,服务注册与发现
本文源码:GitHub·点这里 || GitEE·点这里 一、Eureka基本架构 1、Eureka简介 Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,SpringCloud将它集成在其子项目spring-cloud-netflix中,以实现SpringCloud的服务发现功能。 2、Eureka角色结构图 角色职责如下:1)、Register:服务注册中心,它是一个Eureka Server ,提供服务注册和发现功能。2)、Provider:服务提供者,它是一个Eureka Client ,提供服务。3)、Consumer:服务消费者,它是一个Eureka Cient ,消费服务。 3、Eureka中几个核心概念 1)、Registe服务注册当Client向Server 注册时,Client 提供自身的元数据,比如IP 地址、端口、运行状况指标的Uri 、主页地址等信息。2)、Renew服务续约Client 在默认的情况下会每隔30 秒发送一次心跳来进行服务续约。通过服务续约来告知Server该Client仍然可用。正常情况下,如果Server在90 ...
- 下一篇
Remax - 使用真正的 React 构建小程序
为什么要用 React 来构建小程序 Learn once, write anywhere. 因为 React 是我们最熟悉的技术。 小程序糟糕的 API 设计已经有很多文章吐槽,这里就不再赘述了。再加上现在一大堆小程序平台,每个平台之间又有大大小小的差异,这对于有跨平台需求的小程序来说无异于是一场灾难。 React 的社区生态体系非常庞大,通过在小程序中引入 React 以及 React Hooks 提供的逻辑抽象能力,我们可以在小程序中直接利用 React 生态体系中大量的技术沉淀(比如:react-use、field-form)。 更完整的 TypeScript 支持。当然你也可以用 TypeScript 去写现有的小程序,但是由于小程序的架构原因,模板层跟逻辑层(也就是 Page)有天然的割裂,即使在逻辑层使用了 TypeScript,在模板层也无法享受类型检查和自动补全带来的便利。引入 React 后,我们的代码全部运行在逻辑层中,可以全程静态类型护航,给你满满的安全感。 现有的方案 目前社区中使用 React 构建小程序的方案大都使用静态编译的方式实现。所谓静态编译,就是使...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- SpringBoot2整合Redis,开启缓存,提高访问速度
- MySQL8.0.19开启GTID主从同步CentOS8
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS8编译安装MySQL8.0.19
- CentOS8安装Docker,最新的服务器搭配容器使用