热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Sentinel使用,处理服务的降级熔断限流

文章目录一、项目采用alibaba-Sentinel处理服务的降级熔断限流Sentinel具有以下特征:Sentinel的主要特性:二、使用1、引入POM:(父POM已经引入强依赖

文章目录

  • 一、项目采用alibaba-Sentinel处理服务的降级熔断限流
    • Sentinel 具有以下特征:
    • Sentinel 的主要特性:
  • 二、使用
    • 1、引入POM:(父POM已经引入强依赖)
    • 2、利用@ SentinelResource注解,进行资源埋点:
      • 注解包含以下属性:
    • 3、yml配置:
    • 举例
      • 在需要处理的方法上埋点,资源名为:sentinel-findById
      • 控制台就可以看到(控制台单独部署,不依赖任何)
      • 规则定义:(待完善)
      • 异常处理类:
  • 三、在Feign中使用:
    • 1、yml配置 feign打开sentinel支持(注意:这里是指客户端配置,也就是调用方)
    • 2、API模块新建fallback包,
    • 3、实现FallbackFactory接口
    • 4、在Feign接口中 添加fallbackFactory,如下图
  • 四、在spring-cloud-gateway 中集成(待完善)
一、项目采用alibaba-Sentinel处理服务的降级熔断限流

Sentinel 具有以下特征:

  • 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。
  • 完备的实时监控:Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。
  • 广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。
  • 完善的 SPI 扩展点:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。

Sentinel 的主要特性:

《Sentinel使用,处理服务的降级熔断限流》

二、使用

1、引入POM:(父POM已经引入强依赖)


com.alibaba.cloud
spring-cloud-starter-alibaba-sentinel

2、利用@ SentinelResource注解,进行资源埋点:

注解包含以下属性:

  • value:资源名称,必需项(不能为空);
  • entryType:entry 类型,可选项(默认为 EntryType.OUT)
  • blockHandler / blockHandlerClass: blockHandler 对应处理 BlockException 的函数名称,可选项。blockHandler 函数访问范围需要是 public,返回类型需要与原方法相匹配,参数类型需要和原方法相匹配并且最后加一个额外的参数,类型为 BlockException。blockHandler 函数默认需要和原方法在同一个类中。若希望使用其他类 的函数,则可以指定 blockHandlerClass 为对应的类的 Class 对象,注意对应的函数必需为 static 函数,否则无法解析。
  • fallback:fallback 函数名称,可选项,用于在抛出异常的时候提供 fallback 处理逻辑。fallback 函数可以针对所有类型的异常(除了 exceptionsToIgnore 里面排除掉 的异常类型)进行处理。fallback 函数签名和位置要求:
  • 返回值类型必须与原函数返回值类型一致;
  • 方法参数列表需要和原函数一致,或者可以额外多一个 Throwable 类型的参数用于接收对应的异常。
  • fallback 函数默认需要和原方法在同一个类中。若希望使用其他类的函数,则可以指定 fallbackClass 为对应的类的 Class 对象,注意对应的函数必需为 static 函数,否 则无法解析。
  • defaultFallback(since 1.6.0):默认的 fallback 函数名称,可选项,通常用于通用的 fallback 逻辑(即可以用于很多服务或方法)。默认 fallback 函数可以针对所 有类型的异常(除了 exceptionsToIgnore 里面排除掉的异常类型)进行处理。若同时配置了 fallback 和 defaultFallback,则只有 fallback 会生效。defaultFallback 函数签名要求:
  • 返回值类型必须与原函数返回值类型一致;
  • 方法参数列表需要为空,或者可以额外多一个 Throwable 类型的参数用于接收对应的异常。

  • defaultFallback 函数默认需要和原方法在同一个类中。若希望使用其他类的函数,则可以指定 fallbackClass 为对应的类的 Class 对象,注意对应的函数必需为 static 函数,否则无法解析。
  • exceptionsToIgnore(since 1.6.0):用于指定哪些异常被排除掉,不会计入异常统计中,也不会进入 fallback 逻辑中,而是会原样抛出。
    特别地,若 blockHandler 和 fallback 都进行了配置,则被限流降级而抛出 BlockException 时只会进入 blockHandler 处理逻辑。若未配置 blockHandler、fallback 和 defaultFallback,则被限流降级时会将 BlockException 直接抛出。

3、yml配置:

Spring:
cloud:
sentinel:
transport:
dashboard: 127.0.0.1:8080 #sentinel控制台地址
# 取消Sentinel控制台懒加载
eager: true

举例

在需要处理的方法上埋点,资源名为:sentinel-findById

@Override
@SentinelResource(value = "sentinel-findById", blockHandler = "blockExceptionHandler", blockHandlerClass = {
ExceptionUtil.class})
public ResponseResult findById(@RequestBody @Valid RequestObject<StorageSelectDTO> requestObject) {
Storage one = storageService.getOne(Wrappers.<Storage>lambdaQuery().eq(Storage::getId, requestObject.getData().getId()));
return Objects.isNull(one)?ResponseResult.fail(StorageCode.FIND_FAIL):ResponseResult.success(one);
}

控制台就可以看到(控制台单独部署,不依赖任何)

控制台点击下载
《Sentinel使用,处理服务的降级熔断限流》

规则定义:(待完善)

异常处理类:

项目中添加fallback包
《Sentinel使用,处理服务的降级熔断限流》

package cn.geek.storage.fallback;
import cn.geek.common.model.base.BaseCode;
import cn.geek.common.model.pojo.RequestObject;
import cn.geek.common.model.pojo.ResponseResult;
import com.alibaba.csp.sentinel.slots.block.BlockException;
import com.alibaba.csp.sentinel.slots.block.authority.AuthorityException;
import com.alibaba.csp.sentinel.slots.block.degrade.DegradeException;
import com.alibaba.csp.sentinel.slots.block.flow.FlowException;
import com.alibaba.csp.sentinel.slots.block.flow.param.ParamFlowException;
import com.alibaba.csp.sentinel.slots.system.SystemBlockException;
import lombok.extern.slf4j.Slf4j;
/** * @version 1.0 * @Author Z.Y * @Description 此类定义@SentinelResource的属性 blockHandler 和fallbackHandler * @Date 2020/4/22 11:19 */
@Slf4j
public class ExceptionUtil {
/** * 对应@SentinelResource的属性 blockHandler * @param requestObject * @param e * @return */
public static ResponseResult blockExceptionHandler(RequestObject requestObject, BlockException e) {
log.info("Oops: " + e.getClass().getCanonicalName());
// 不同的异常返回不同的提示语
if (e instanceof FlowException) {
log.info("接口限流了");
return ResponseResult.fail("接口限流");
} else if (e instanceof DegradeException) {
log.info("服务降级了");
return ResponseResult.fail("服务熔断降级了");
} else if (e instanceof ParamFlowException) {
log.info("热点参数限流了");
return ResponseResult.fail("热点参数限流了");
} else if (e instanceof SystemBlockException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
} else if (e instanceof AuthorityException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
}
return ResponseResult.fail(BaseCode.CALL_TIME);
}
/** * 对应@SentinelResource的属性 fallbackHandler * @param requestObject * @param e * @return */
public static ResponseResult fallbackHandler(RequestObject requestObject, Throwable e) {
log.info("Oops: " + e.getClass().getCanonicalName());
// 不同的异常返回不同的提示语
if (e instanceof FlowException) {
log.info("接口限流了");
return ResponseResult.fail("接口限流");
} else if (e instanceof DegradeException) {
log.info("服务降级了");
return ResponseResult.fail("服务熔断降级了");
} else if (e instanceof ParamFlowException) {
log.info("热点参数限流了");
return ResponseResult.fail("热点参数限流了");
} else if (e instanceof SystemBlockException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
} else if (e instanceof AuthorityException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
}
return ResponseResult.fail(BaseCode.CALL_TIME);
}
}
三、在Feign中使用:

1、yml配置 feign打开sentinel支持(注意:这里是指客户端配置,也就是调用方)

feign:
sentinel:
enabled: true

2、API模块新建fallback包,

《Sentinel使用,处理服务的降级熔断限流》

3、实现FallbackFactory接口

package cn.geek.storage.feigapi.fallback;
import cn.geek.common.model.base.BaseCode;
import cn.geek.common.model.pojo.RequestObject;
import cn.geek.common.model.pojo.ResponseResult;
import cn.geek.storage.feigapi.api.StorageApi;
import cn.geek.storage.feigapi.dto.StorageSelectDTO;
import cn.geek.storage.feigapi.entity.Storage;
import feign.hystrix.FallbackFactory;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
/** * @version 1.0 * @Author Z.Y * @Description 熔断 * @Date 2020/4/21 19:57 */
@Component
@Slf4j
public class StorageApiFallbackFactory implements FallbackFactory<StorageApi> {
@Override
public StorageApi create(Throwable throwable) {
return new StorageApi() {
@Override
public ResponseResult findById(RequestObject<StorageSelectDTO> requestObject) {
log.info("findById熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult insert(RequestObject<Storage> requestObject) {
log.info("insert熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult deleteById(RequestObject<Storage> requestObject) {
log.info("deleteById熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult update(RequestObject<Storage> requestObject) {
log.info("update熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult findPage(RequestObject<StorageSelectDTO> requestObject) {
log.info("findPage熔断!",throwable);
return ResponseResult.fail("服务熔断降级!");
}
};
}
}

4、在Feign接口中 添加fallbackFactory,如下图

《Sentinel使用,处理服务的降级熔断限流》

四、在spring-cloud-gateway 中集成(待完善)
推荐阅读
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
author-avatar
mobiledu2502861197
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有