服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - Java教程 - SpringCloud微服务之Hystrix组件实现服务熔断的方法

SpringCloud微服务之Hystrix组件实现服务熔断的方法

2021-09-08 10:17知了一笑 Java教程

微服务架构特点就是多服务,多数据源,支撑系统应用。这样导致微服务之间存在依赖关系。这篇文章主要介绍了SpringCloud微服务之Hystrix组件实现服务熔断的方法,需要的朋友可以参考下

一、熔断器简介

服务架构特点就是多服务,多数据源,支撑系统应用。这样导致微服务之间存在依赖关系。如果其中一个服务故障,可能导致系统宕机,这就是所谓的雪崩效应。

1、服务熔断

微服务架构中某个微服务发生故障时,要快速切断服务,提示用户,后续请求,不调用该服务,直接返回,释放资源,这就是服务熔断。

熔断生效后,会在指定的时间后调用请求来测试依赖是否恢复,依赖的应用恢复后关闭熔断。

2、服务降级

服务器高并发下,压力剧增的时候,根据当业务情况以及流量,对一些服务和页面有策略的降级(可以理解为关闭不必要的服务),以此缓解服务器资源的压力以保障核心任务的正常运行。

双十一期间,支付宝很多功能都会提示,[双十一期间,保障核心交易,某某服务数据延迟]。

3、核心依赖

?
1
2
3
4
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>

4、核心注解

•@EnableHystrix 启动类注解控制熔断功能。
•@HystrixCommand 方法注解,熔断控制配置。

5、案例模块描述

演示基于Ribbon服务的熔断
node03-consume-8001
演示基于Feign服务的熔断
node03-consume-8002
Eureka注册中心
node03-eureka-7001
两个服务提供方
node03-provider-6001
node03-provider-6002

二、基于Ribbon服务熔断

1、熔断执行方法

?
1
2
3
4
5
6
/**
 * 服务熔断调用方法
 */
public String getDefaultInfo (){
  return "服务被熔断" ;
}

2、简单案例

?
1
2
3
4
5
6
7
8
/**
 * 简单配置
 */
@RequestMapping("/showInfo1")
@HystrixCommand(fallbackMethod = "getDefaultInfo")
public String showInfo1 (){
  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}

Hystrix默认的超时时间是1秒,超时时间内部响应,就会执行熔断,进入fallback程序。由于Spring的懒加载机制,首次请求往往比较慢,可以通过配置Hystrix超时时间解决。

3、复杂案例

•配置超时、并发、线程池、指定异常熔断忽略

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/**
 * 复杂配置
 */
@RequestMapping("/showInfo2")
@HystrixCommand(
    fallbackMethod = "getDefaultInfo",
    commandProperties={
        // 降级处理超时时间设置
        @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),
        // 任意时间点允许的最高并发数。超过该设置值后,拒绝执行请求。
        @HystrixProperty(name = "fallback.isolation.semaphore.maxConcurrentRequests", value = "1000"),
    },
    // 配置执行的线城池
    threadPoolProperties = {
        @HystrixProperty(name = "coreSize", value = "20"),
        @HystrixProperty(name = "maxQueueSize", value = "-1"),
    },
    // 该异常不执行熔断,去执行该异常抛出的自己逻辑
    ignoreExceptions = {ServiceException.class}
)
public String showInfo2 (){
  String value = "" ;
  // 测试配置异常不熔断
  // 响应:{"code":500,"msg":"运行异常"}
  if (value.equals("")){
    throw new ServiceException("运行异常") ;
  }
  // 该异常被熔断
  // if (value.equals("")){
  //   throw new RuntimeException("抛出错误") ;
  // }
  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}

4、启动类注解

•@EnableHystrix

三、基于Feign服务熔断

1、Jar包说明

通过观察Fegin依赖的JAR可知,Fegin的Jar下包含Hystrix需要的Jar包,这里不用再次导入依赖。

2、熔断配置

Feign用接口实现的声明式Rest请求,所以配置也就在接口上面了。

1)、接口代码

?
1
2
3
4
5
@FeignClient(value = "NODE02-PROVIDER",fallback = FallbackService.class)
public interface GetAuthorService {
  @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET)
  String getAuthorInfo (@PathVariable("authorId") String authorId) ;
}

2)、熔断执行代码

?
1
2
3
4
5
6
7
@Component
public class FallbackService implements GetAuthorService {
  @Override
  public String getAuthorInfo(String authorId) {
    return "服务被熔断"+authorId;
  }
}

3)、配置文件

•开启熔断功能

?
1
2
3
feign:
 hystrix:
  enabled: true

3、服务类注解

由于上面的接口和熔断代码是在不同的Jar模块中,所以要在启动类@SpringBootApplication注解中扫描,如下。

?
1
2
3
4
5
6
7
8
9
10
@SpringBootApplication(scanBasePackages = {"cloud.node02.consume","cloud.block.code.service"})
@EnableEurekaClient  // 本服务启动后会自动注册进eureka服务中
@EnableDiscoveryClient
// 因为包名路径不同,需要加basePackages属性
@EnableFeignClients(basePackages={"cloud.block.code.service"})
public class Application_8002 {
  public static void main(String[] args) {
    SpringApplication.run(Application_8002.class,args) ;
  }
}

四、源代码说明

GitHub地址:知了一笑
https://github.com/cicadasmile/spring-cloud-base
码云地址:知了一笑
https://gitee.com/cicadasmile/spring-cloud-base

总结

以上所述是小编给大家介绍的SpringCloud微服务之Hystrix组件实现服务熔断的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

原文链接:https://www.cnblogs.com/cicada-smile/archive/2019/08/02/11286451.html

延伸 · 阅读

精彩推荐
  • Java教程SpringBoot Web 应用源码解析:综合实战和整体总结

    SpringBoot Web 应用源码解析:综合实战和整体总结

    本文将基于对前端模板框架 Thymeleaf 的集成,逐步向大家演示如何自定义 ViewResolver以及如何进一步 扩展 Spring MVC 配置。...

    今日头条2542020-10-31
  • Java教程Hibernate的各种保存方式的区别详解

    Hibernate的各种保存方式的区别详解

    今天小编就为大家分享一篇关于Hibernate的各种保存方式的区别详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随...

    徐刘根4842021-07-27
  • Java教程Java是自学好还是参加培训班好?

    Java是自学好还是参加培训班好?

    这篇文章主要介绍了Java是自学好还是参加培训班好这一问题,给大家介绍了哪些人适合自学java,哪些人适合java培训班学习,大家可以看看内容详情...

    程序员学习指南6172021-04-22
  • Java教程Java解压zip文件的关键代码

    Java解压zip文件的关键代码

    本文给大家分享一段java解压zip文件的关键代码,代码简单易懂,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧...

    梦想、编织着青春5262020-06-18
  • Java教程Kotlin + Retrofit + RxJava简单封装使用详解

    Kotlin + Retrofit + RxJava简单封装使用详解

    这篇文章主要介绍了Kotlin + Retrofit + RxJava简单封装使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    zsgnaw8372021-05-14
  • Java教程SpringMVC 传日期参数到后台的实例讲解

    SpringMVC 传日期参数到后台的实例讲解

    下面小编就为大家分享一篇SpringMVC 传日期参数到后台的实例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    tianxia_096672021-03-05
  • Java教程基于字符串常用API(详解)

    基于字符串常用API(详解)

    下面小编就为大家带来一篇基于字符串常用API(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    Java教程网3572020-11-13
  • Java教程详谈Lock与synchronized 的区别

    详谈Lock与synchronized 的区别

    下面小编就为大家带来一篇详谈Lock与synchronized 的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    Java教程网3062020-09-22