springcloud第4季 springcloud-alibaba之nacos+openfegin+gateway+sentinel熔断限流【经典案例】

一 说明

1.1 架构说明

本案例实现原理: 采用alibaba的nacos,openfegin,sentinel,gateway等组件实现熔断限流。

主要理解sentinel的@ResouceSentinel和fallback的区别联系。

@ResourceSentinel 主要是页面配置熔断限流规则;

fallback主要是针对 jvm业务io异常进行逻辑处理。

1.2 工程结构

1.消费者

2.openfeginApi

3.gateway

4.提供者

1.3 注意点

openapi这里请求路径,多了一个空格,提示服务fallback,注意路径要写正确。

二 实施案例

2.1 消费者

1.pom文件

2.核心业务代码

2.2 工具open-api

1.核心接口

注意: 这里@Feginclients 配置的服务为网关的服务名称:ms-alibaba-sentinel-gateway

2.3 网关Gateway

1.pom配置

复制代码
  <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-transport-simple-http</artifactId>
            <version>1.8.6</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-spring-cloud-gateway-adapter</artifactId>
            <version>1.8.6</version>
        </dependency>
        <dependency>
            <groupId>javax.annotation</groupId>
            <artifactId>javax.annotation-api</artifactId>
            <version>1.3.2</version>
            <scope>compile</scope>
        </dependency>
        <!--nacos-discovery-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--   一定要加这个依赖,否则 网关配置lb://服务名  不起作用  -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-loadbalancer</artifactId>
        </dependency>
        <!--openfeign-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

2.核心业务代码: 这里配置请求,1s超过2次,触发网关设置限流规则。

3.application配置文件

2.4 服务提供者

1.核心业务代码

2.5 启动服务

1.nacos

E:\nacos-server2.2.3\bin>startup.cmd -m standlone

2.sentinel

F:\>java -jar sentinel-dashboard-1.8.6.jar

3.业务服务启动

2.6 验证

1.正常访问:通过8081 访问网关7777 转发到 提供端9091

http://localhost:8081/consumer/pay/nacos/sgo/444

2.频繁刷新**:触发网关配置的限流规则**

3.在openfeigin设置fallback策略

实现类

打包,重新启动业务服务:

正常访问

频繁刷新:触发fallback处理异常

相关推荐
jinanwuhuaguo30 分钟前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
xmjd msup1 小时前
spring security 超详细使用教程(接入springboot、前后端分离)
java·spring boot·spring
952361 小时前
SpringBoot统一功能处理
java·spring boot·后端
Lyyaoo.2 小时前
优惠券秒杀业务分析
java·开发语言
消失的旧时光-19432 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法
勿忘初心12212 小时前
Java 国密 SM4 加密工具类实战(Hutool + BouncyCastle)|企业级数据加密 + 兼容 JDK8
java·数据安全·数据加密·后端开发·企业级开发·国密 sm4
庞轩px2 小时前
第8篇:原子类与CAS底层原理——无锁并发的实现
java·cas·乐观锁·aba·无锁编程·自旋
rleS IONS2 小时前
SpringBoot中自定义Starter
java·spring boot·后端
苍煜2 小时前
慢SQL优化实战教学
java·数据库·sql
AI进化营-智能译站3 小时前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai