SpringCloudsentinel如何实现接口限流的方法-创新互联

这篇文章给大家分享的是有关SpringCloud sentinel如何实现接口限流的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

创新互联建站"三网合一"的企业建站思路。企业可建设拥有电脑版、微信版、手机版的企业网站。实现跨屏营销,产品发布一步更新,电脑网络+移动网络一网打尽,满足企业的营销需求!创新互联建站具备承接各种类型的做网站、网站建设项目的能力。经过10年的努力的开拓,为不同行业的企事业单位提供了优质的服务,并获得了客户的一致好评。

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如何实现接口限流的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!


当前文章:SpringCloudsentinel如何实现接口限流的方法-创新互联
URL分享:http://pcwzsj.com/article/djhipg.html