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

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



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




3.Sentinel------快速入门

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

powershell 复制代码
java -Dserver.port=8090 -Dcsp.sentinel.dashboard.server=localhost:8090 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar

http://localhost:8090 访问sentinel

cart服务整合sentinel

xml 复制代码
<!--sentinel-->
<dependency>
    <groupId>com.alibaba.cloud</groupId> 
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
yaml 复制代码
spring:
  cloud: 
    sentinel:
      transport:
        dashboard: localhost:8090
yaml 复制代码
spring:
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8090
      http-method-specify: true # 开启请求方式前缀

4.Sentinel------请求限流

用户信息

5.Sentinel------线程隔离



6.Sentinel------Fallback

java 复制代码
@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中进行声明

java 复制代码
    @Bean
    public ItemClientFallback itemClientFallback(){
        return new ItemClientFallback();
    }
java 复制代码
@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);
}
yaml 复制代码
feign:
  okhttp:
    enabled: true # 开启OKHttp功能
  sentinel:
    enabled: true

![

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

7.Sentinel------服务熔断

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

相关推荐
墨痕诉清风23 分钟前
java漏洞集合工具(Struts2、Fastjson、Weblogic(xml)、Shiro、Log4j、Jboss、SpringCloud)
xml·java·struts·安全·web安全·spring cloud·log4j
程序员阿鹏25 分钟前
SpringBoot自动装配原理
java·开发语言·spring boot·后端·spring·tomcat·maven
老华带你飞32 分钟前
工会管理|基于springboot 工会管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
没有bug.的程序员1 小时前
微服务中的数据一致性困局
java·jvm·微服务·架构·wpf·电商
⑩-1 小时前
SpringCloud-Feign客户端实战
后端·spring·spring cloud
qq_12498707532 小时前
基于springboot的幼儿园家校联动小程序的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·spring·微信小程序·小程序
拾忆,想起2 小时前
设计模式三大分类完全解析:构建高质量软件的基石
xml·微服务·设计模式·性能优化·服务发现
后端小张2 小时前
【Java 进阶】深入理解Redis:从基础应用到进阶实践全解析
java·开发语言·数据库·spring boot·redis·spring·缓存
楠枬3 小时前
Nacos
java·spring·spring cloud·微服务
bailaoshi6663 小时前
Spring WebFlux整合reactor-rabbitmq
spring·rabbitmq·java-rabbitmq