spring cloud gateway整合sentinel实现网关限流
这篇文章主要介绍了springcloudgateway整合sentinel实现网关限流,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
说明:sentinel可以作为各微服务的限流,也可以作为gateway网关的限流组件。springcloudgateway有限流功能,但此处用sentinel来作为替待。
说明:sentinel流控可以放在gateway网关端,也可以放在各微服务端。
1,以父工程为基础,创建子工程
2,添加pom依赖
org.springframework.cloud spring-cloud-starter-gateway com.alibaba.cloud spring-cloud-starter-alibaba-sentinel com.alibaba.cloud spring-cloud-alibaba-sentinel-gateway com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery
2,添加配置项
server: port:9092 spring: cloud: nacos: discovery: register-enabled:false server-addr:localhost:8848 namespace:c22e5019-0bee-43b1-b80b-fc0b9d847501 sentinel: transport: dashboard:localhost:8080 port:8719 scg: fallback: mode:response response-status:455 response-body:error! gateway: routes: -id:demo_route uri:lb://demo predicates: -Path=/demo/** -id:demo2_test uri:lb://demo2 predicates: -Path=/user/** application: name:gateway-sentinel
scg.fallback为sentinel限流后的响应配置
3,启动类
@SpringBootApplication @EnableDiscoveryClient publicclassGatewaySentinelApplication{ publicstaticvoidmain(String[]args){ SpringApplication.run(GatewaySentinelApplication.class,args); } }
4,启动后,在sentinel控制台可以看到gateway-sentinel应用,可以通过控制台设置流控规则。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。