SpringCloud03 Ribbon知识点、 Feign知识点、利用RestTemplate+Ribbon调用远程服务提供的资源、利用feign调用远程服务提供的资源、熔断...
1 远程服务资源的调用
1.1 古老的套路
在微服务出现之前,所有的远程服务资源必须通过RestTemplate或者HttpClient进行;但是这两者仅仅实现了远程服务资源的调用,并未提供负载均衡实现,所以程序员必须自己实现负载均衡功能;而且当远程服务是集群部署时,利用RestTemplate或者HttpClient封装的客户端必须配置好远程服务的先关信息。
技巧01:利用Spring5.X 提供的WebClient可以实现响应式访问远程服务资源
技巧02:利用RestTemplate和WebClient封装客户端的参考博文:参考博文01 参考博文02
缺点01:需要自己实现负载均衡功能
绝点02:封装客户端时必须配置好远程服务的信息,如果远程服务是集群部署时工作量时巨大的;而且一旦远程服务信息变动,客户端也必须进行变动
1.2 微服务套路
微服务出现过后,封装的客户端不需要配置远程服务的信息,因为这些信息都有注册中心统一帮我们进行管理,也不需要自己实现负载均衡功能;基于SpringCloud的微服务之间的通讯方式主要通过 ribbon + restTemplate 或者 feign 实现
技巧01:利用 ribbon + restTemplate 实现时其实和只用RestTemplate实现的区别就在于不用配置远程服务的信息,而且提供了负载均衡功能
技巧02:ribbon 负责获取注册中心的远程服务信息以及提供负载均衡功能
2 Ribbon知识点
daigengxin.......
3 Feign知识点
待更新........
4 项目准备
4.1 注册中心 Eureka Server
创建一个单例的服务注册中心
4.2 服务提供者 Eureka Client
4.3 服务消费者 Eureka Client
5 利用 Ribbon + RestTemplate 实现
利用 Ribbon + RestTemplate 调用远程服务资源
技巧01:先启动服务注册中心
5.1 创建远程服务Restful API
在服务提供的服务中提供一个Restful API接口供服务消费方调用
5.2 集群部署服务提供方
将服务提供方打包后在不同的端口启动即可,本案例直接利用IDEA进行集群部署
5.2.1 打开应用配置
5.2.2 复制一份原来的配置
5.2.3 修改配置信息
只需要修改配置名称和启动端口即可
5.2.4 分别启动两个配置即可
技巧01:每个配置启动前可以修改相关的内容信息,这样做的目的是为了开发阶段可以看到效果;生产中时不能更改内容信息的,因为时集群嘛,内容肯定需要保持一致
技巧02:如果项目中利用了devtools依赖,请注释掉,并关闭IDEA的自动编译功能
5.2.5 到注册中心控制面板查看信息
可以看到一个应用在两个端口启动了
5.2.6 分别访问restful API
5.3 编写远程调用控制类
在服务消费方利用RestTemplate调用服务提供方提供的资源数据,参考文档
》配置RestTemplate的Bean
》利用RestTemplate调用
技巧01:远程服务的信息直接利用远程服务的应用名代替,应用名就是spring.application.name的值
5.4 通过消费者服务调用远程资源测试
技巧01:ribbon默认使用轮询来实现负载均衡功能
6 利用 Feign 实现
技巧01:feign默认集成了ribbon
技巧02:在需要使用feign的服务中需要引入feign依赖并在启动类上添加@EnableFeignClients注解
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-openfeign --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency>
6.1 创建远程服务Restful API
请参见5.1
6.2 编写远程调用接口
6.3 编写远程调用的控制层
6.4 通过消费者服务调用远程资源测试
6.5 熔断
参考博文
7 本博文源代码
点击前往
转载于:https://www.cnblogs.com/NeverCtrl-C/p/9537751.html
SpringCloud03 Ribbon知识点、 Feign知识点、利用RestTemplate+Ribbon调用远程服务提供的资源、利用feign调用远程服务提供的资源、熔断...相关推荐
- Spring Cloud第二篇:服务消费者RestTemplate+Ribbon
在上一篇文章,讲了服务的注册和发现.在微服务架构中,业务都会被拆分成一个独立的服务,服务与服务的通讯是基于http restful的.Spring cloud有两种服务调用方式,一种是ribbon+r ...
- openfeign ribbon 负载_SpringCloud教程(三)声明式访问Feign、负载均衡Ribbon
0-前言 eureka实际上已经集成了负载均衡调度框架Ribbon: 我们有了各个微服务了,那怎么来调用他们呢,一种方法是可以使用 RestTemplate(如:String str= restTem ...
- Ribbon负载均衡原理,Feign是如何整合Ribbon的?
文章目录 1. 什么是负载均衡? 2. Ribbon的使用 ①:自定义负载均衡策略 ②:Ribbon的饥饿加载 3. Ribbon的负载均衡原理 ①:收集带有@LoadBalanced注解的RestT ...
- 实战系列-Spring Cloud微服务中三把利器Feign、Hystrix、Ribbon
导语 在之前的分享中分享过关于Fegin的底层实现原理,以及Spring Cloud OpenFegin的启动原理.在这次的分享中主要总结一下Spring Cloud 微服务架构的三把利器.对于F ...
- 怎么用feign远程调用别人的接口_Feign - HTTP接口调用- 单独使用 - 实战
目录 疯狂创客圈 Java 分布式聊天室[ 亿级流量]实战系列之 -26[ 博客园 总入口 ] 写在前面 ? 大家好,我是作者尼恩.目前和几个小伙伴一起,组织了一个高并发的实战社群[疯狂创客圈].正在 ...
- ETH:Windows搭建ETH(区块链技术)利用Web端和小程序端两种方式调用ETH上的SC智能合约
ETH:Windows搭建ETH(区块链技术)利用Web端和小程序端两种方式调用ETH上的SC智能合约 目录 1.Geth安装.配置文件.与ETH节点交互 1.1.下载并安装好geth客户端 1.2. ...
- 利用宝塔linux面板+苹果CMS搭建电影网站(二)网站的配置+电影资源的爬取上传
在利用宝塔linux面板+苹果CMS-----从0搭建一个电影网站(一)里已经初始创建了一个电影网站的雏形 接下来需要对网站进行编辑修改上传电影资源 达到这一种效果; 网站修改编辑 进入网站后台 ip ...
- 还怕GPU资源不够用?多实例GPU MIG助攻资源利用难题
从农业时代的锄头镰刀,到工业时代蒸汽机发电机,每个时代都有每个时代的象征符.在迈向工业 4.0 智能化时代的现在,转战 GPU.使能并行计算.扩展云上算力...... 数字世界的每一个关键词无一不是围 ...
- 如何利用matlab做BP神经网络分析(包括利用matlab神经网络工具箱)
如何利用matlab做BP神经网络分析(包括利用matlab神经网络工具箱) 转载:https://blog.csdn.net/xgxyxs/article/details/53265318 最近一段 ...
最新文章
- ACMMM2017 | 电子科大斩获最佳论文!中科院自动化所多媒体计算组获得IEEE期刊最佳论文!
- bootstraptable 列隐藏_bootstrapTable 隐藏某一列
- 我自己写的3D图形数学库。。。有点乱!
- python logging模块使用
- webwork2.2.4+spring配制方式总结
- java总结:double取两位小数的多种方法
- 报错:content type application/x-www-form-urlencoded;
- 剑三哪些插件是必备的_盘点那些年用过的神级CAD插件,每一款都舍不得卸载
- html静态页面留言板,html静态留言板
- 把谷歌主题背景图片保存下来
- 如何选择工业相机(转载)
- 怎样用office Word2003打开docx格式文档???
- 技术文档 | 5G系统连接管理:CM空闲和CM已连接
- pc机串口通讯实验c语言,单片机实验六 单片机与PC机串口通讯
- Sklearn之KMeans算法
- 优必选将推出家庭守卫机器人——“第一军团风暴兵”机器人
- springboot 通过javaCV 实现mp4转m3u8 上传oss
- OpenCV之canny()函数,边缘检测,高斯平滑滤波的理解
- python mssql github_GitHub 标星 1.6w+项目 HelloGitHub,让开发更简单的开源启蒙手册!...
- 基于Detectron2模型和深度学习方法的改进森林火灾检测方法
热门文章
- asp删除mysql_asp php 清空access mysql mssql数据库的代码
- plsql存过声明游标_plsql--游标用法
- 回溯算法背包问题迭代c语言,回溯法解决0_1背包问题(迭代和递归)
- access集团和abm_abm年度盛典,12月份,中国、澳大利亚、新西兰三地同时举办,abm各渠道运营商从全球各地赶来参会!...
- react 前端解析二进制流_一年半前端跳槽面试经验(头条、微信、shopee)
- python 剪切一行内容到另一个文件
- LeetCode 1147. 段式回文(贪心)
- LeetCode 473. 火柴拼正方形(回溯)
- LeetCode 1221. 分割平衡字符串
- LeetCode 1346. 检查整数及其两倍数是否存在(哈希)