sentinel基于Nacos数据持久化

sentinel基于Nacos数据持久化

1.引入依赖

java 复制代码
<!-- 持久化用到 -->
<dependency>
   <groupId>com.alibaba.csp</groupId>
   <artifactId>sentinel-datasource-nacos</artifactId>
</dependency>

2.yml配置

java 复制代码
server:
 port: 8091
 tomcat:
   max-threads: 10   #最大线程数设置为10,默认200
spring:
 application:
   name: service-order
 datasource:
   driver-class-name: com.mysql.cj.jdbc.Driver
   url: jdbc:mysql://localhost:3306/shop?serverTimezone=Asia/Shanghai
   username: root
   password: 123456
 jpa:
   hibernate:
     ddl-auto: update
 cloud:
   nacos:
     discovery:
       server-addr: localhost:8848
   sentinel:
     transport:
       dashboard: localhost:8080 #提交数据到控制台
       port: 9999  #设置通信端口,任意一个未被使用的端口
     datasource: # 规则持久化
       ds1:
         nacos:
           server-addr: localhost:8848 #nacos地址
           dataId: service-order  #微服务名称
           groupId: DEFAULT_GROUP  #默认分组
           data-type: json #数据格式
           rule-type: flow #流控规则
service-product: #服务提供者名称 负载均衡的策略
 ribbon:
   NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule

3.Nacos添加配置

点击加+号

配置内容

java 复制代码
[
 {
    "resource": "/msg1",
    "limitApp": "default",
    "count": 1,
    "grade": 1,
    "strategy": 0,
    "controlBehavior": 0,
    "clusterMode": false
 }
]

配置内容解释

java 复制代码
resource:资源名称;
limitApp:来源应用;
grade:阈值类型,0表示线程数,1表示QPS;
count:单机阈值;
strategy:流控模式,0表示直接,1表示关联,2表示链路;
controlBehavior:流控效果,0表示快速失败,1表示Warm Up,2表示排队等待;
clusterMode:是否集群。

其实就是Sentinel控制台如下配置:

演示结果

重启服务流控信息存在。

相关推荐
小马爱记录3 天前
sentinel规则持久化
java·spring cloud·sentinel
小马爱记录3 天前
Sentinel微服务保护
spring cloud·微服务·架构·sentinel
爱编程的张同学6 天前
OpenFeign和Gateway集成Sentinel实现服务降级
spring cloud·sentinel
运维老曾6 天前
Redis-6.2.9 Sentinel 哨兵配置
redis·sentinel
曼彻斯特的海边6 天前
spring-cloud-alibaba-sentinel-gateway
gateway·sentinel·springcloud
xujinwei_gingko6 天前
微服务-Sentinel
微服务·sentinel
_r0bin_11 天前
Sentinel
sentinel
LL小蜗牛11 天前
Alibaba Sentinel 入门教程:从理论到实战
sentinel
飞飞98711 天前
spring sentinel
java·spring·sentinel
cui_hao_nan11 天前
Sentinel限流熔断机制实战
java·sentinel