点击上方“方志朋”,选择“置顶公众号”

技术文章第一时间送达!

什么是Sentinel

Sentinel,中文翻译为哨兵,是为微服务提供流量控制、熔断降级的功能,它和Hystrix提供的功能一样,可以有效的解决微服务调用产生的“雪崩”效应,为微服务系统提供了稳定性的解决方案。随着Hytrxi进入了维护期,不再提供新功能,Sentinel是一个不错的替代方案。通常情况,Hystrix采用线程池对服务的调用进行隔离,Sentinel才用了用户线程对接口进行隔离,二者相比,Hystrxi是服务级别的隔离,Sentinel提供了接口级别的隔离,Sentinel隔离级别更加精细,另外Sentinel直接使用用户线程进行限制,相比Hystrix的线程池隔离,减少了线程切换的开销。另外Sentinel的DashBoard提供了在线更改限流规则的配置,也更加的优化。

从官方文档的介绍,Sentinel 具有以下特征:

  • 丰富的应用场景: Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、实时熔断下游不可用应用等。

  • 完备的实时监控: Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。

  • 广泛的开源生态: Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。

  • 完善的 SPI 扩展点: Sentinel 提供简单易用、完善的 SPI 扩展点。您可以通过实现扩展点,快速的定制逻辑。例如定制规则管理、适配数据源等。

如何在Spring Cloud中使用Sentinel

Sentinel作为Spring Cloud Alibaba的组件之一,在Spring Cloud项目中使用它非常的简单。现在以案例的形式来讲解如何在Spring Cloud项目中使用Sentinel。本项目是在之前nacos教程的案例基础上进行改造。在工程的pom文件加上sentinel的Spring Cloud起步依赖,代码如下:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId><version>0.9.0.RELEASE</version>
</dependency>

在工程的配置文件application.yml文件中配置,需要新增2个配置:

  • spring.cloud.sentinel.transport.port: 8719 ,这个端口配置会在应用对应的机器上启动一个 Http Server,该 Server 会与 Sentinel 控制台做交互。比如 Sentinel 控制台添加了1个限流规则,会把规则数据 push 给这个 Http Server 接收,Http Server 再将规则注册到 Sentinel 中。

  • spring.cloud.sentinel.transport.dashboard: 8080,这个是Sentinel DashBoard的地址。

server:port: 8762
spring:application:name: nacos-providercloud:nacos:discovery:server-addr: 127.0.0.1:8848sentinel:transport:port: 8719dashboard: localhost:8080

写一个RestController,在接口上加上SentinelResource注解就可以了。

@RestController
public class ProviderController {@GetMapping("/hi")@SentinelResource(value="hi")public String hi(@RequestParam(value = "name",defaultValue = "forezp",required = false)String name){return "hi "+name;}
}

关于@SentinelResource 注解,有以下的属性:

  • value:资源名称,必需项(不能为空)

  • entryType:entry 类型,可选项(默认为 EntryType.OUT)

  • blockHandler / blockHandlerClass: blockHandler 对应处理 BlockException 的函数名称,可选项

  • fallback:fallback 函数名称,可选项,用于在抛出异常的时候提供 fallback 处理逻辑。

启动Nacos,并启动nacos-provider项目。文末有源码下载链接。

Sentinel DashBoard

Sentinel 控制台提供一个轻量级的控制台,它提供机器发现、单机资源实时监控、集群资源汇总,以及规则管理的功能. Sentinel DashBoard下载地址:https://github.com/alibaba/Sentinel/releases

下载完成后,以以下的命令启动

java -jar sentinel-dashboard-1.6.1.jar

默认启动端口为8080,可以-Dserver.port=8081的形式改变默认端口。启动成功后,在浏览器上访问localhost:8080,就可以显示Sentinel的登陆界面,登陆名为sentinel,密码为sentinel。

登陆sentinel dashboard成功后,并多次访问nacos-provider的localhost:8080/hi接口,在nacos访问信息如下:

sentinel dashboard显示了nacos-provider的接口资源信息。

在/hi资源处设置接口的限流功能,在“+流控”按钮点击开设置界面如下,设置阈值类型为 qps,单机阈值为2。

设置成功后可以在流控规则这一栏进行查看,如图所示:

测试

多次快速访问nacos-provider的接口资源http://localhost:8762/hi,可以发现偶尔出现以下的信息:

Blocked by Sentinel (flow limiting)

正常的返回逻辑为

hi forezp

由以上可只,接口资源/hi的限流规则起到了作用。

在FeignClient中使用Sentinel

Hystrix默认集成在Spring Cloud 的Feign Client组件中,Sentinel也可以提供这样的功能。现以案例的形式来讲解如何在FeignClient中使用Sentinel,z本案例是在之前的nacos教程案例的nacos-consumer工程上进行改造,除了引入spring-cloud-starter-alibaba-sentinel,还需要引入spring-cloud-starter-openfeign,代码如下:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId><version>0.9.0.RELEASE</version></dependency>

在配置文件中需要加上sentinel.transport. dashboard配置外,还需要加上feign.sentinel.enabled的配置,代码如下:

server:port: 8763
spring:application:name: nacos-consumercloud:nacos:discovery:server-addr: 127.0.0.1:8848sentinel:transport:port: 8719dashboard: localhost:8080
feign.sentinel.enabled: true

写一个FeignClient,调用nacos-provider的/hi接口:

@FeignClient("nacos-provider")
public interface ProviderClient {@GetMapping("/hi")String hi(@RequestParam(value = "name", defaultValue = "forezp", required = false) String name);
}

写一个RestController调用ProviderClient,代码如下:

@RestController
public class ConsumerController {@AutowiredProviderClient providerClient;@GetMapping("/hi-feign")public String hiFeign(){return providerClient.hi("feign");}
}

在FeignClient中,Sentinel为Feign调用生成了资源名策略定义,定义规则为httpmethod:protocol://requesturl。启动nacos-consumer工程,在Sentinel DashBoard生成了如下的资源信息:

添加流控,QPS为2,在浏览器上快速多次点击访问http://localhost:8763/hi-feign,浏览器在正常情况下是能够正常返回如下的信息:

hi feign

在被限流的时候返回错误信息。

需要注意的是,被限流的时候FeignClient并不会调用nacos-provider的接口,而是在nacos-consumer工程里直接报错。

源码下载

https://github.com/forezp/SpringCloudLearning/tree/master/springcloud-alibaba/nacos-discovery-sentinel

参考资料

https://github.com/alibaba/Sentinel/releases

https://github.com/alibaba/Sentinel/tree/master/sentinel-dashboard

https://github.com/spring-cloud-incubator/spring-cloud-alibaba/wiki/Sentinel

https://github.com/alibaba/Sentinel/wiki/%E6%8E%A7%E5%88%B6%E5%8F%B0

热门内容:

  • 你的Redis怎么持久化的

  • 工作发狂:Mybatis 中$和#千万不要乱用!

  • 淘宝服务端高并发分布式架构演进之路

  • 有没有想过,手写一个连接池?

  • 一个Java对象到底有多大?

  • Spring Cloud Alibba教程:如何使用Nacos作为配置中心

  • Spring Cloud Alibaba教程:使用Nacos作为服务注册中心

感谢搓一下“在看

Spring Cloud Alibba教程:Sentinel的使用相关推荐

  1. Spring Cloud Alibba教程:如何使用Nacos作为配置中心

    点击上方"方志朋",选择"置顶公众号" 技术文章第一时间送达! 在上一篇文章中讲解了如何使用Nacos作为服务注册中心注册.Nacos除了可以作为服务注册中心, ...

  2. sentinel 端口_Spring Cloud Alibba教程:Sentinel的使用

    来源公众号:方志朋 什么是Sentinel Sentinel,中文翻译为哨兵,是为微服务提供流量控制.熔断降级的功能,它和Hystrix提供的功能一样,可以有效的解决微服务调用产生的"雪崩& ...

  3. 6.Spring Cloud Alibaba教程:Sentinel流量防卫兵的介绍与基本使用

    官网 https://sentinelguard.io/ 服务雪崩 微服务中各个服务之间通过http/rpc互相调用,假设其中1个服务因为网络或自身原因出现问题,调用这个服务就会出现线程堵塞,此时若有 ...

  4. springcloud gateway ribbon使用_Github点赞接近 70k 的Spring Cloud学习教程+实战项目推荐!牛批!...

    这篇文章继续来推荐 Spring Cloud 的教程和实战项目了!想必不用不多说,大家都知道 Spring Cloud 的重要程度.几乎稍微有点规模的公司,一般都离不开要和微服务打交道.同时,Spri ...

  5. Github点赞接近 70k 的Spring Cloud学习教程+实战项目推荐!牛批!

    本文已经收录进:awesome-java (Github 上非常棒的 Java 开源项目集合) 这篇 Guide 来推荐 Spring Cloud 的教程和实战项目了!想必不用不多说,大家都知道 Sp ...

  6. Spring Cloud基础教程

    Spring Cloud基础教程  2017-04-04 被围观 90375 次 该教程内容不定时更新,如您对这些内容感兴趣,可以关注我的博客或微信公众号! 本教程示例代码: GitHub:https ...

  7. Spring Cloud入门教程(二):客户端负载均衡(Ribbon)

    对于大型应用系统负载均衡(LB:Load Balancing)是首要被解决一个问题.在微服务之前LB方案主要是集中式负载均衡方案,在服务消费者和服务提供者之间又一个独立的LB,LB通常是专门的硬件,如 ...

  8. 【云原生微服务>SCG网关篇十二】Spring Cloud Gateway集成Sentinel API实现多种限流方式

    文章目录 一.前言 二.Gateway集成Sentinel API 0.集成Sentinel的核心概念 1)GatewayFlowRule 和 ApiDefinition 2)GatewayFlowR ...

  9. 使用Nacos实现服务注册与发现(spring cloud 组件教程大全四)

    使用Nacos实现服务注册与发现(spring cloud 组件教程大全四) idea 创建maven父子工程(spring cloud 组件教程大全 一) windows下nacos的安装及Mysq ...

最新文章

  1. 云脑人力资源管理软件EHR选型手记(即时连载)
  2. 计算机IP地址与子网掩码如何进行AND运算
  3. AI理论知识整理(18)-内积与范数
  4. python爬虫科研数据提取_python爬虫数据提取四之pyquery
  5. antd vue表单上传文件_vue+axios+antD的上传图片踩坑
  6. maven aspectj_使用Spring AspectJ和Maven进行面向方面的编程
  7. Weblogic 10.3.5在64位Windows系统下的安装和配置
  8. ES6学习(四)—字符串的新增方法
  9. ORACLE常用的一些特殊SQL,收藏收藏,下次需要的时候就不用再翻箱倒柜了
  10. javaweb后台管理系统
  11. unity开宝箱动画_Unity动画库插件iTween介绍
  12. 《创新思维训练》2021网课章节测验及答案
  13. 自定义向PE启动映像WIM中添加驱动方法
  14. 对于解决新版unity5.x的license error 问题
  15. SpringBoot中通过Redis的setnx和自定义注解@Idempotent实现API幂等处理
  16. 【剑指 Offe】剑指 Offer 17. 打印从1到最大的n位数
  17. k8s和docker区别
  18. 教你认识系统进程_电脑维修啦 PCWXL.com
  19. android 小米键盘输入法,Facemoji输入法小米版
  20. 08【mmaction2 行为识别商用级别】自定义ava数据集 之 将视频裁剪为帧

热门文章

  1. bzoj 1787 紧急集合
  2. Kindeditor学习中的那些坑
  3. String,StringBuffer
  4. J2EE 中的服务器 tomcat6.0 配置
  5. 从某一日期开始过day天的日期
  6. 抽象工厂与工厂模式例子
  7. 转载:用 Tomcat 和 Eclipse 开发 Web 应用程序
  8. 【组队学习】【31期】 吃瓜教程——西瓜书+南瓜书
  9. 【Codeforces】1093C Mishka and the Last Exam
  10. 【数据结构】邻接表的储存结构 建立图的邻接表算法