spring 熔断机制

简介: spring 熔断机制

Spring Cloud Hystrix(服务容错保护)


熔断的目的:


为了保证服务高可用,不能因为系统中的一个小服务不可用,从而导致整个系统的崩溃。


熔断的原理:


对于使用相关注解的类或者方法,系统会监控其错误,如果多次出现同一错误,而且达到阈值,则打开熔断开关,熔断开关打开后,不在访问远程服务器,而是直接调用预先准备的失败方法。当熔断开关过期后、会尝试访问远程服务,这个时候的熔断开关是半开半闭状态的,有些服务直接失败,有些会继续访问远程服务。


熔断是微服务必须的,可我不用熔断,系统好像也能正常的工作,那为什么说它是必须的呢?


正常工作室没有问题的,那发生异常了呢?某个服务挂了或者网络不通的时候发生什么?


那就是调用它的微服务这个服务抛出异常,一直到最上层,这个每一会HTTp请求都会开启一个新的线程。而下游的服务器挂了或者网络不可达,通常线程会堵塞住直到timeOut,如果并发量多了,这些堵塞的线程就会占用大量的资源,很有可能把自己本身的微服务所在的机器资源耗尽,导致自己也挂掉。


服务降级


服务降级利用fallback实现,例如在fegin中接口实现fallback指定的错误请求方法,使得这次请求不进入正常系统的处理逻辑,而去执行指定的fallback方法,返回error操作,就比如常见的错误友好页面,让它不去卡你的系统


Hystrix有三种状态分别是 关闭、开启和半开

@HystrixCommand(fallbackMethod = "fallbackGet")
    Object get(String url, Map params, Map header) {
        def start = System.currentTimeMillis()
        HttpHeaders headers = handleHeader(header)
        Map<String, String> p = handleParams(params)
        url = handUrl(url)
        Object result = loadBalancedRestTemplate.getForObject(url, new HttpEntity<String>(null, headers), Object.class, p)
        debug(HttpMethod.GET, url, params, header, result, (System.currentTimeMillis() - start))
        return result
    }
Object fallbackGet(String url, Map params, Map header, Throwable e) {
        return fallback(url, "GET", e)
    }
 
 
    Object fallback(String url, String method, Throwable e) {
        logger.info("{}请求[{}]熔断 {}", method, url, e?.message)
        return ["resCode": CommonConstant.RE_SERVICE_DOWN]
    }
目录
相关文章
|
监控 Java 微服务
Spring cloud 之熔断机制
Spring cloud组件的熔断机制
|
11月前
|
Java Spring 容器
SpringBoot自动配置的原理是什么?
Spring Boot自动配置核心在于@EnableAutoConfiguration注解,它通过@Import导入配置选择器,加载META-INF/spring.factories中定义的自动配置类。这些类根据@Conditional系列注解判断是否生效。但Spring Boot 3.0后已弃用spring.factories,改用新格式的.imports文件进行配置。
1392 0
|
12月前
|
人工智能 Java 测试技术
Spring Boot 集成 JUnit 单元测试
本文介绍了在Spring Boot中使用JUnit 5进行单元测试的常用方法与技巧,包括添加依赖、编写测试类、使用@SpringBootTest参数、自动装配测试模块(如JSON、MVC、WebFlux、JDBC等),以及@MockBean和@SpyBean的应用。内容实用,适合Java开发者参考学习。
1265 0
|
前端开发 Java 数据库
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——Thymeleaf 介绍
本课介绍Spring Boot集成Thymeleaf模板引擎。Thymeleaf是一款现代服务器端Java模板引擎,支持Web和独立环境,可实现自然模板开发,便于团队协作。与传统JSP不同,Thymeleaf模板可以直接在浏览器中打开,方便前端人员查看静态原型。通过在HTML标签中添加扩展属性(如`th:text`),Thymeleaf能够在服务运行时动态替换内容,展示数据库中的数据,同时兼容静态页面展示,为开发带来灵活性和便利性。
563 0
|
8月前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
621 4
|
8月前
|
Java 测试技术 数据库连接
【SpringBoot(四)】还不懂文件上传?JUnit使用?本文带你了解SpringBoot的文件上传、异常处理、组件注入等知识!并且带你领悟JUnit单元测试的使用!
Spring专栏第四章,本文带你上手 SpringBoot 的文件上传、异常处理、组件注入等功能 并且为你演示Junit5的基础上手体验
1148 3
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于 xml 的整合
本教程介绍了基于XML的MyBatis整合方式。首先在`application.yml`中配置XML路径,如`classpath:mapper/*.xml`,然后创建`UserMapper.xml`文件定义SQL映射,包括`resultMap`和查询语句。通过设置`namespace`关联Mapper接口,实现如`getUserByName`的方法。Controller层调用Service完成测试,访问`/getUserByName/{name}`即可返回用户信息。为简化Mapper扫描,推荐在Spring Boot启动类用`@MapperScan`注解指定包路径避免逐个添加`@Mapper`
1043 0
|
Java 测试技术 微服务
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——少量配置信息的情形
本课主要讲解Spring Boot项目中的属性配置方法。在实际开发中,测试与生产环境的配置往往不同,因此不应将配置信息硬编码在代码中,而应使用配置文件管理,如`application.yml`。例如,在微服务架构下,可通过配置文件设置调用其他服务的地址(如订单服务端口8002),并利用`@Value`注解在代码中读取这些配置值。这种方式使项目更灵活,便于后续修改和维护。
387 0
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
1513 0
|
缓存 NoSQL Java
基于SpringBoot的Redis开发实战教程
Redis在Spring Boot中的应用非常广泛,其高性能和灵活性使其成为构建高效分布式系统的理想选择。通过深入理解本文的内容,您可以更好地利用Redis的特性,为应用程序提供高效的缓存和消息处理能力。
1495 79