专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

Sentinel限流实践

Sentinel是什么

Sentinel的官方标题是:分布式系统的流量防卫兵。从名字上来看,很容易就能猜到它是用来作服务稳定性保障的。对于服务稳定性保障组件,如果熟悉Spring Cloud的用户,第一反应应该就是Hystrix。但是比较可惜的是Netflix已经宣布对Hystrix停止更新。那么,在未来我们还有什么更好的选择呢?除了Spring Cloud官方推荐的resilience4j之外,目前Spring Cloud Alibaba下整合的Sentinel也是用户可以重点考察和选型的目标。

Sentinel的功能和细节比较多,一篇内容很难介绍完整。所以下面我会分多篇来一一介绍Sentinel的重要功能。本文就先从限流入手,说说如何把Sentinel整合到Spring Cloud应用中,以及如何使用Sentinel Dashboard来配置限流规则。通过这个简单的例子,先将这一套基础配置搭建起来。

1.启动Sentinel Dashboard

下载地址:sentinel

启动方式:java -Dserver.port=8888 -jar sentinel-dashboard-1.6.0.jar

可以通过-Dserver.port=8888来切换启动的端口,-Dserver.servlet.session.timeout=7200: 用于指定 Spring Boot 服务端 session 的过期时间,如 7200 表示 7200 秒;60m 表示 60 分钟,默认为 30 分钟;

这里我碰到一个问题:使用最新的sentinel Dashboard 1.7.1.jar会出现问题

Sentinel Dashboard界面新增流控规则时报错:失败:invalid type

主要问题是Sentinel Dashboard的jar包版本过高,导致代码里的sentinel-code版本与dashboard的版本不一致,最终报错。

github上的issue:github.com/alibaba/Sen…

启动后输入账号密码,全部为sentinel,进入主页面

61_1.png61_2.png

到此sentinel dashboard的启动就完成了,接下来启动项目

pom中加入

<dependency>
      <groupId>com.alibaba.cloud</groupId>
      <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
      <version>2.1.1.RELEASE</version>
</dependency>

61_3.png

在配置文件中加入相关配置

spring 
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8080

61_4.png

在项目中写一个简单接口

 @GetMapping("/unLock")
 public String lock() throws Exception {
     return "success";
 }

61_5.png

启动项目就可以了,在dashboard查看前,先调用接口几次,不然dashboard上可能看不到,这里我用jmeter请求了500次

61_6.png61_7.png

接下来测试限流的作用,点击簇点链路,选择要限流的接口,点击流控

61_8.png61_9.png

使用jmeter发起500次请求

61_10.png61_11.png

限流生效

文章永久链接:https://tech.souyunku.com/41146

未经允许不得转载:搜云库技术团队 » Sentinel限流实践

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们