springCloud - 第5篇 - 断路器 Hystrix ( Feign 、Ribbon )
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。
一、为什么要有熔断
在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用。为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,Servlet容器的线程资源会被消耗完毕,导致服务瘫痪。服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是服务故障的 “雪崩” 效应。
为了解决这个问题,业界提出了断路器模型 。
以上出自:https://blog.csdn.net/forezp/article/details/81040990
二、熔断实现
1. 首先 启动 注册中心 eureka 工程、服务生产者 see-param 工程(8803端口)、
服务消费者 feign 工程(8702端口)、服务消费者 ribbon 工程(8701 端口)。
(生产者和消费者这 2 个概念是相对的。在不同的业务场景中,2 者身份可互换。或多服务时,同一服务可兼具 2 个身份。)
分别访问 生产者:
2. feign 中熔断器实现。
配置文件中开启熔断:
# 开启断熔器: ( Feign 自带断路器,但默认为不开启: false)
feign.hystrix.enabled=true
在 SeeParamService 类中 @FeignClient 注解中加上参数 fallback ,并指明熔断方法实现类。
书写 熔断方法实现类:
package com.feign.servicefeign;import org.springframework.stereotype.Component;/*** @author yujiang* @description 迷断回调方法类* @date 2019/7/24 9:39*/// 注入IOC容器中,把本类交给 spring 管理
@Component
public class SeeParamError implements SeeParamService {@Overridepublic String seeParam(String param) {return " 乖乖加班吧,服务挂了,搬砖,搬砖 ... ";}}
此时, 关闭服务生产者 see-param 工程,并再访问其服务:
至此,feign 熔断生效 。
3. ribbon 中熔断器实现。
ribbon 并不自带迷断功能,故要引入依赖:
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId></dependency>
工程启动类加注解 @EnableHystrix ,开启熔断。
SeeParamService 类中,在要实现熔断的方法上加注解:@HystrixCommand(fallbackMethod = "熔断实现方法名"),如:
package com.ribbon.serviceribbon;import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;/*** @author yujiang* @description* @date 2019/7/22 11:45*/
@Service
public class SeeParamService {@AutowiredRestTemplate restTemplate;/*** 注解 @HystrixCommand :* 开启熔断器,指定熔断时回调方法为 seeParamError** @param param* @return*/@HystrixCommand(fallbackMethod = "seeParamError")public String seeService(String param) {return restTemplate.getForObject("http://see-param/seeParam?param=" + param, String.class);}/*** 熔断 调用此方法** @return*/public String seeParamError(String param) {return " 哎,别瞅了,别瞅了,服务已经 go die ...";}}
此时, 关闭服务生产者 see-param 工程,并再访问其服务:
至此,ribbon 熔断生效 。
--------------------------------------------------------------
下一篇:springCloud - 第6篇 - 网关的实现:ZUUL
源码见:https://gitee.com/FJ_WoMenDeShiJie/springcloud-feign
https://gitee.com/FJ_WoMenDeShiJie/springcloud-ribbon
--------------------------------------------------------------
PS:这个系列不定时更新,只是个人的学习分享,
内容全程参考书目:
《Spring Cloud 与 Docker 微服务架构空实战 》、
《Spring Cloud 微服务实战》及此书作者博客:http://blog.didispace.com/spring-cloud-learning/
《深入理解 Spring Cloud 与微服务构建》及此书作者博客:https://blog.csdn.net/forezp/article/details/70148833
--------------------------------------------------------------
springCloud - 第5篇 - 断路器 Hystrix ( Feign 、Ribbon )相关推荐
- springCloud - 第12篇 - 服务监控 Hystrix 面板
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 前面有用过 Hystrix 熔断,在多服务运行时.可以通过 Hystrix 的监控面板来实时观察各个 ...
- springCloud - 第4篇 - 消费者调用服务 ( Feign )
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 一.新建 ribbon 工程: 1. file - new - module 2. spring I ...
- SpringCloud版本Hoxton SR5 --- 第三讲:Ribbon 、Ribbon与Feign配合使用
传送门:SpringCloud版本Hoxton SR5 --- 第一讲:认识 先看Ribbon.Fegin可以完成的功能,或者说他在项目中的定位和作用. 上篇文章主要讲:功能和作用都是用大白话,主要是 ...
- [SpringCould篇]之断路器(Hystrix)
1.背景 在微服务架构中,服务间根据业务拆分成多个,并且服务之间相互调用. 为了保证高可用,服务通常会集群部署,但是由于网络或自身原因,服务并不能保证100%可用.若某个服务出现问题,调用就会出现阻塞 ...
- 史上最简单的SpringCloud教程 | 第四篇:断路器(Hystrix)
转:https://blog.csdn.net/forezp/article/details/69934399 最新版本: 史上最简单的SpringCloud教程 | 第四篇:断路器(Hystrix) ...
- SpringCloud教程 | 第四篇:断路器(Hystrix)
SpringCloud教程 | 第四篇:断路器(Hystrix) 在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTempl ...
- 史上最简单的SpringCloud教程 | 第四篇:断路器(Hystrix)--有BUG,注意看我的备注
转载请标明出处: http://blog.csdn.net/forezp/article/details/69934399 本文出自方志朋的博客 在微服务架构中,根据业务来拆分成一个个的服务,服务 ...
- 史上最简单的SpringCloud教程 | 第四篇:断路器(Hystrix)--里面有BUG,所以我转载改一下
017年04月09日 21:14:05 阅读数:271535 转载请标明出处: http://blog.csdn.net/forezp/article/details/69934399 本文出自方 ...
- SpringCloud微服务基础 Eureka、Feign、Ribbon、Zuul、Hystrix、配置中心的基础使用
1.单点系统架构 传统项目架构 传统项目分为三层架构,将业务逻辑层.数据库访问层.控制层放入在一个项目中. 优点:适合于个人或者小团队开发,不适合大团队开发. 分布式项目架构 根据业务需求进行拆分成N ...
最新文章
- POJ 1724 二维费用最短路
- 各种排序实现以及稳定性分析
- React手稿 - Context
- 【Python】20个小技巧,让数据可视化图表更专业!
- 智慧屏鸿蒙系统的优势,荣耀智慧屏成热点 搭载的鸿蒙系统有何优势?
- asp.net EF+MVC2实战2
- 网盘用户分享独播剧链接 百度未及时封禁一审被判赔偿百万余元
- python猴子选大王讲解_关于猴子选大王的面试题
- sql server 锁定_关于锁定SQL Server的全部
- 【Vegas原创】ProC环境搭建
- WSL2之kali从C盘迁移到E盘
- 算法编程-不定时更新
- 二蛋和培训机构斗智斗勇的血泪史
- 大学生网页制作期末作业——HTML+CSS+JavaScript制作成都旅游网页设计与实现12个页面 web前端课程设计代码 web课程设计 HTML网页制作代码
- Ass代理转实模/Convert ass proxy to model
- python读书心得体会范文_读书心得体会范文五篇-读书心得体会
- linux中编辑jar包的内容
- 亮屏流程 - 安卓R
- c++中 #defin的基本意思
- vsto下开发wps插件
热门文章
- python settings模块导入不了_python settings 中通过字符串导入模块
- 【git下载安装与配置】
- python剪切文件如何恢复_用python实现的可以拷贝或剪切一个文件列表中的所有文件...
- php 跳转qq群代码_邪少xml论坛qqxml代码—QQ音乐可播放框架QQ群任意跳转个人网站链接引流...
- 【CodeForces - 518D】Ilya and Escalator(概率dp,数学期望)
- 【POJ - 2752】Seek the Name, Seek the Fame (KMP,公共前缀后缀长度及个数)
- ANSI X9.19 MAC算法介绍
- python菜鸟100例精选
- linux用户登录实验,Linux用户和组相关命令及实验
- java 强制清除缓存_IDEA强制清除Maven缓存的方法示例