温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SpringCloud sentinel如何实现接口限流的方法

发布时间:2020-10-19 17:44:01 来源:亿速云 阅读:513 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关SpringCloud 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:https://github.com/alibaba/Sentinel/issues/1236#issuecomment-571907232


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

SpringCloud sentinel如何实现接口限流的方法

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

pom中加入

      com.alibaba.cloudspring-cloud-starter-alibaba-sentinel2.1.1.RELEASE

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

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

在项目中写一个简单接口

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

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

SpringCloud sentinel如何实现接口限流的方法

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

SpringCloud sentinel如何实现接口限流的方法

使用jmeter发起500次请求

SpringCloud sentinel如何实现接口限流的方法

限流生效

感谢各位的阅读!关于SpringCloud sentinel如何实现接口限流的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI