当前位置: 首页 > news >正文

Sentinel 流控-链路模式

链路模式

A B C 三个服务

A 调用 C

B 调用 C

C 设置流控 ->链路模式 -> 入口资源是 A

A、B 服务

package com.learning.springcloud.order.controller;import com.learning.springcloud.order.service.BaseService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/*** 链路模式:*    条件:*      - A —> C; B -> C*      - C 设置流控规则 入口资源是A*/
@RestController
@RequestMapping("/lianlu")
public class LianLuController {@AutowiredBaseService baseService;@RequestMapping("/A")public Object A() {String s = baseService.queryC();return "hi, A;" + s;}@RequestMapping("/B")public Object B() {String s = baseService.queryC();return "hi, B;" + s;}}

C 服务

package com.learning.springcloud.order.service;public interface BaseService {public String queryC();
}
package com.learning.springcloud.order.service.impl;import com.alibaba.csp.sentinel.annotation.SentinelResource;
import com.alibaba.csp.sentinel.slots.block.BlockException;
import com.learning.springcloud.order.service.BaseService;
import org.springframework.stereotype.Service;@Service
public class BaseServiceImpl implements BaseService {@Override@SentinelResource(value = "queryC")public String queryC() {return "查询C";}
}

控制台

设置链路收集

server:port: 8061spring:application:name: order-sentinelcloud:sentinel:transport:dashboard: 127.0.0.1:8080web-context-unify: false # 默认请求链路进行收敛

设置流控规则

  • 链路 入口 A

访问

问题:为啥没有流控处理的消息而是访问报错???

问题解决

分析:

       1.  使用 注解 @SentinelResource 则无法使用全局异常处理

       2. 增加注解 blockHandler 属性以及方法

package com.learning.springcloud.order.service.impl;import com.alibaba.csp.sentinel.annotation.SentinelResource;
import com.alibaba.csp.sentinel.slots.block.BlockException;
import com.learning.springcloud.order.service.BaseService;
import org.springframework.stereotype.Service;@Service
public class BaseServiceImpl implements BaseService {@Override@SentinelResource(value = "queryC", blockHandler = "blockHandlerForQueryC")public String queryC() {return "查询C";}public String blockHandlerForQueryC(BlockException be) {return "queryC 被流控了!!!";}
}
  • 再次访问 可以正常返回流控处理消息

http://www.lryc.cn/news/299893.html

相关文章:

  • Vue中@change、@input和@blur的区别及@keyup介绍
  • 洛谷: P7910 [CSP-J 2021] 插入排序
  • Lua weak表
  • DS:二叉树的顺序结构及堆的实现
  • python从入门到精通(十九):python的多线程详细使用
  • 【More Effective C++】条款19:了解临时对象的来源
  • 站在C/C++的肩膀速通Java面向对象
  • 【AI视野·今日Robot 机器人论文速览 第七十八期】Wed, 17 Jan 2024
  • flask cors 跨域问题解决
  • 18 19 SPI接口的74HC595驱动数码管实验
  • 计算机网络概述习题拾遗
  • 你的电脑关机吗
  • flask+python儿童福利院管理系统pycharm毕业设计项目
  • React:高阶组件|ref转发
  • AI:127-基于卷积神经网络的交通拥堵预测
  • MongoDB聚合操作符:$abs
  • 【element-ui】输入框组件el-input输入数字/输出Number类型:type=“number“、v-model.number用法
  • 算法与数据结构
  • C++动态规划-线性dp算法
  • 基于 Python 深度学习的电影评论情感分析系统,附源码
  • 如何查看Apple Watch的步数?这里提供几个方法
  • 解决‘vue‘ 不是内部或外部命令,也不是可运行的程序(设置全局变量)
  • JavaWeb学习|i18n
  • 数据库日志已经很大了,比如200多G,不能收缩到几兆,实际操作过只能到30G
  • docker常用容器命令
  • 蓝桥杯(Web大学组)2022省赛真题:冬奥大抽奖
  • 单调队列 单调栈
  • Java基础-泛型
  • Vue 全组件 局部组件
  • 几个经典金融理论