Spring Cloud入门教程-熔断器-Hystrix

这里说一下熔断器,开始之前先了解两个概念:

1.什么是Hystrix?

在分布式系统中,服务与服务之间的依赖错综复杂,一种不可避免的情况就是某些服务会出现故障,导致依赖于它们的其他服务出现远程调度的线程阻塞。 Hystrix是 Netflix公司开源的一个项目,它提供了熔断器功能,能够阻止分布式系统中出现联动故障。 Hystrix是通过隔离服务的访问点阻止联动故障的,并提供了故障的解决方案,从而提高了整个分布式系统的弹性。

2.雪崩效应

在高并发的情况下,单个服务的延迟会导致整个请求都处于延迟状态,可能在几秒钟就使整个服务处于线程负载饱和的状态。某个服务的单个点的请求故障会导致用户的请求处于阻塞状态,最终的结果就是整个服务线资源消耗尽,由于服务的依赖性,会导致依赖于该故障服务的其他服务也处于线程阻塞,整最终导致这些服务的线程资源消耗殆尽,直到不可用,从而导致整个服务系统不可用,即雪崩效应。

为了防止雪崩效应,因而产生了熔断器模型。 Hystrix是在业界表现非常好的一个熔断器模型实现的开源组件,它是 Spring Cloud组件不可缺少的一部分。

Hystrix的设计原则:

a.防止单个服务的故障耗尽整个服务的Seet容器(例如 Tomcat)的线程资源

b.快速失败机制,如果某个服务出现了故障,则调用该服务的请求快速失败,而不是线程等待。

c.提供回退( fallback)方案,在请求发生故障时,提供设定好的回退方案。

d.使用熔断机制,防止故障扩散到其他服务。

e.提供熔断器的监控组件 Hystriⅸ Dashboard,可以实时监控熔断器的状态。

怎样在RestTemp 上使用熔断器


在之前的eureka-client-ribbon 项目上进行改造:

首先增加依赖:

org.springframework.cloud

spring-cloud-starter-netflix-hystrix

在启动类EurekaClientRibbonApplication上添加@EnableHystrix注解

@EnableHystrix

@EnableEurekaClient

@SpringBootApplication

@ComponentScan(“com.springcloud.demo.eurekaclientribbon”)

public class EurekaClientRibbonApplication {

public static void main(String[] args) {

SpringApplication.run(EurekaClientRibbonApplication.class, args);

}

}

修改RibbonService 在main()方法上添加@HystrixCommand

@Service

public class RibbonService {

@Autowired

RestTemplate restTemplate;

@HystrixCommand(fallbackMethod = “errorFallbackMsg”)

public int main(){

return restTemplate.getForObject(“http://eureka-client/main”,Integer.class);

}

public int errorFallbackMsg(){

return -2;

}

}

fallbackMethod参数是在熔断器打开时,即远程服务调用失败时执行的方法名。

启动eureka-client-ribbon ,关闭两个eureka-client 实例,请求http://localhost:8795/main

返回-2,熔断器生效。

在Feign上使用熔断器


添加依赖

org.springframework.cloud

spring-cloud-starter-netflix-hystrix

**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

分享一些系统的面试题,大家可以拿去刷一刷,准备面试涨薪。

这些面试题相对应的技术点:

  • JVM
  • MySQL
  • Mybatis
  • MongoDB
  • Redis
  • Spring
  • Spring boot
  • Spring cloud
  • Kafka
  • RabbitMQ
  • Nginx

大类就是:

  • Java基础
  • 数据结构与算法
  • 并发编程
  • 数据库
  • 设计模式
  • 微服务
  • 消息中间件

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?

程序员,每个月给你发多少工资,你才会想老板想的事?
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
YReSl-1713394732535)]

[外链图片转存中…(img-RxM7riTk-1713394732535)]

[外链图片转存中…(img-7buTmJyx-1713394732536)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 24
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值