【黑马SpringCloud微服务开发与实战】(五)微服务保护

1.雪崩问题——原因分析

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.雪崩问题——解决方案

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

3.Sentinel——快速入门

在这里插入图片描述

本地启动:从资料里面获取jar包并且把版本后缀去掉和命令的名称一致

java -Dserver.port=8090 -Dcsp.sentinel.dashboard.server=localhost:8090 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar

在这里插入图片描述
http://localhost:8090 访问sentinel

cart服务整合sentinel

<!--sentinel-->
<dependency>
    <groupId>com.alibaba.cloud</groupId> 
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
spring:
  cloud: 
    sentinel:
      transport:
        dashboard: localhost:8090

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

spring:
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8090
      http-method-specify: true # 开启请求方式前缀

在这里插入图片描述

4.Sentinel——请求限流

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

用户信息
在这里插入图片描述
在这里插入图片描述

5.Sentinel——线程隔离

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

6.Sentinel——Fallback

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

@Slf4j
public class ItemClientFallback implements FallbackFactory<ItemClient> {
    @Override
    public ItemClient create(Throwable cause) {
        return new ItemClient() {
            @Override
            public List<ItemDTO> queryItemByIds(Collection<Long> ids) {
                log.error("远程调用ItemClient#queryItemByIds方法出现异常,参数:{}", ids, cause);
                // 查询购物车允许失败,查询失败,返回空集合
                return CollUtils.emptyList();
            }

            @Override
            public void deductStock(List<OrderDetailDTO> items) {
                // 库存扣减业务需要触发事务回滚,查询失败,抛出异常
                throw new BizIllegalException(cause);
            }
        };
    }
}

放置DefaultFeignConfig中进行声明

    @Bean
    public ItemClientFallback itemClientFallback(){
        return new ItemClientFallback();
    }
@FeignClient(value = "item-service",
        configuration = DefaultFeignConfig.class,
        fallbackFactory = ItemClientFallback.class)
public interface ItemClient {

    @GetMapping("/items")
    List<ItemDTO> queryItemByIds(@RequestParam("ids") Collection<Long> ids);

    @PutMapping("/items/stock/deduct")
    void deductStock(@RequestBody List<OrderDetailDTO> items);
}

feign:
  okhttp:
    enabled: true # 开启OKHttp功能
  sentinel:
    enabled: true

在这里插入图片描述

![

在这里插入图片描述
](https://i-blog.csdnimg.cn/direct/a0e64688bd644f5881334da5a2866c37.png)

7.Sentinel——服务熔断

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

20s后熔断结束后会发送一个请求看商品服务查询是否正常,如果不正常继续熔断,反之。。。。。。

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值