单体转微服务:微服务保护和分布式事务(上)

一.微服务中的缓存雪崩

由于微服务链路中的某个服务故障,导致整个链路级联失败,这就是微服务雪崩

1.产生原因:

<1>服务提供者阻塞或者故障
<2>服务调用者没有做好异常处理
<3>整个链路级联失败,导致集群故障

2.解决方案

<1>请求限流

使用一个限流器,当调用某个服务时,先经过限流器,使得同一时间服务请求的并发数小于或者等于限流器的阙值

<2>线程隔离

为不同服务设立最大可用线程,这样一个服务出现故障便不会影响其他服务

<3>服务熔断

编写服务降级逻辑,当服务出现故障或者访问过慢的时候,可以抛异常,也可以发送提示或者数据,当某个业务异常比例过高的时候,证明该服务出现故障,直接实现服务降级

二.运用Sentinel实现微服务保护

1.引入依赖

复制代码
<!--sentinel-->
<dependency>
    <groupId>com.alibaba.cloud</groupId> 
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

2.配置控制台

复制代码
spring:
  cloud: 
    sentinel:
      transport:
        dashboard: localhost:8090

3.微服保护

<1>请求限流
<2>线程隔离
<4>服务熔断
1.编写Fallback实现请求降级

<1>创建Itemclient类实现FallbackFactory

复制代码
@Slf4j
public class ItemClientFallbackFactory implements FallbackFactory<ItemClient>{
    @Override
    public ItemClient create(Throwable cause) {
        return new ItemClient() {
            @Override
            public Set<ItemDTO> queryItemByIds(Set<Long> ids) {
                log.error("查询商品信息失败", cause);
                return Set.of();
            }
        };
    }
}

<2>编写配置类注入Bean对象

复制代码
@Configuration
public class ItemClientConfig {
    @Bean
    public ItemClientFallbackFactory itemFallbackFactory() {
        return new ItemClientFallbackFactory();
    }
}

<3>使用ItemClientFallbackFactory

复制代码
@FeignClient(value = "item-service",fallback = ItemClientFallbackFactory.class)
public interface ItemClient {
    @GetMapping("/items")
    Set<ItemDTO> queryItemByIds(Set<Long> ids);
}
2.实现服务熔断
3.熔断原理

熔断是依靠断位器来实现的

断路器有三个状态 close open half-open

断路器一开始处于open状态,当慢请求或者异常请求达到所设置的阙值的时候,就会进入close状态,close是一个临时状态,当达到一定时间后会进入half-oepn状态,这时会向服务发送一个请求,如果服务正常则会进入close状态,否则进行open状态。像这样不断循环。

相关推荐
念何架构之路1 小时前
分布式详解
分布式
Flittly1 小时前
【日常小问】解决 Jenkins 部署 Spring Cloud 微服务到 Docker 容器启动失败的问题
运维·笔记·docker·微服务·jenkins
小杍随笔2 小时前
【Rust桌面革命:Tauri×Dioxus——架构对决、实战拆解与2026选型杀招】
开发语言·架构·rust
The Open Group2 小时前
AI智能体时代,如何构建数字化架构以实现持续成功
大数据·人工智能·架构
Elastic 中国社区官方博客2 小时前
将 Logstash Pipeline 从 Azure Event Hubs 迁移到 OTel Collector Kafka Receiver
大数据·数据库·人工智能·分布式·elasticsearch·搜索引擎·kafka
切糕师学AI2 小时前
Dashboard 技术综述:定义、架构、分类与设计最佳实践
架构·dashboard
倒流时光三十年2 小时前
第1篇:你真的了解 Kafka 吗?—— 破冰篇
spring boot·分布式·kafka·linq
坤岭2 小时前
企业级AI应用落地的三重架构与实战解析
人工智能·架构
aXin_ya2 小时前
微服务第十一天 MQ相关问题
java·微服务·架构