一 说明
1.1 架构说明
本案例实现原理: 采用alibaba的nacos,openfegin,sentinel,gateway等组件实现熔断限流。
主要理解sentinel的@ResouceSentinel和fallback的区别联系。
@ResourceSentinel 主要是页面配置熔断限流规则;
fallback主要是针对 jvm业务io异常进行逻辑处理。
data:image/s3,"s3://crabby-images/a396d/a396d653e229ed1a285c2ce8e6a3e35b7c9fe674" alt=""
1.2 工程结构
1.消费者
data:image/s3,"s3://crabby-images/88053/88053d9a6555ed5cec71ead493ec604e6559b81b" alt=""
2.openfeginApi
data:image/s3,"s3://crabby-images/7a51b/7a51bce03625e2321ababc6d297f1976e60bc745" alt=""
3.gateway
data:image/s3,"s3://crabby-images/0727c/0727c0321bb011863716e128986a58754bd2dfc8" alt=""
4.提供者
data:image/s3,"s3://crabby-images/1f982/1f9824886b1bd44f288a5e23b584edf1c76c37a6" alt=""
1.3 注意点
openapi这里请求路径,多了一个空格,提示服务fallback,注意路径要写正确。
data:image/s3,"s3://crabby-images/f57a3/f57a36e3d700eee87f10081b73ec6cc14bdb605b" alt=""
data:image/s3,"s3://crabby-images/78e79/78e79a9c7855c18697f13abdb0337feeb324dc45" alt=""
二 实施案例
2.1 消费者
1.pom文件
data:image/s3,"s3://crabby-images/b3af0/b3af07720e9fc9545803578cfdcb548ff65e6b8e" alt=""
2.核心业务代码
data:image/s3,"s3://crabby-images/21627/21627086ba5b51cc9700475df2968273b7c9922c" alt=""
2.2 工具open-api
1.核心接口
注意: 这里@Feginclients 配置的服务为网关的服务名称:ms-alibaba-sentinel-gateway
data:image/s3,"s3://crabby-images/27dac/27dac3c031191f158114c8e977573cf061d8899b" alt=""
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次,触发网关设置限流规则。
data:image/s3,"s3://crabby-images/b9d11/b9d11661fbb8a8e26783460d2f74af29f10047f0" alt=""
3.application配置文件
2.4 服务提供者
1.核心业务代码
data:image/s3,"s3://crabby-images/adece/adecea9b4149e762dffa2518c3eac31ff084468e" alt=""
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.业务服务启动
data:image/s3,"s3://crabby-images/b2768/b2768923dcd967bdc63ea20aabd219a1a7dc862e" alt=""
2.6 验证
1.正常访问:通过8081 访问网关7777 转发到 提供端9091
http://localhost:8081/consumer/pay/nacos/sgo/444
data:image/s3,"s3://crabby-images/705a6/705a68f2186917eb267fcbcdcb68c5761c935f25" alt=""
2.频繁刷新**:触发网关配置的限流规则**
data:image/s3,"s3://crabby-images/2560c/2560c073224dc528dad8f03a942e22e81badc66f" alt=""
3.在openfeigin设置fallback策略
实现类
data:image/s3,"s3://crabby-images/05e2f/05e2f9383d11eb582e9abbd3c73c306b54cff428" alt=""
打包,重新启动业务服务:
正常访问
data:image/s3,"s3://crabby-images/4e6b6/4e6b63c62979084de073b69f412d84646208d6c5" alt=""
频繁刷新:触发fallback处理异常
data:image/s3,"s3://crabby-images/a248d/a248d9b78875b46bebb1a965438b9c3c3043aa4a" alt=""