sentinel 不显示项目_Sentinel+Nacos实现资源流控、降级、热点、授权

本文同名博客老炮说Java:https://www.laopaojava.com/,每天更新Spring/SpringMvc/SpringBoot/实战项目等文章资料

Sentinel+Nacos 是微服务环境搭建必不可少的两个组件,这里给大家推荐一套微服务教程:

SpringCloud微服务电商项目教程 - 老炮说Java-程序员编程资料和编程经验分享平台​www.laopaojava.com
08a456be5c1384be7e23d49774b6d8c8.png

教程主要包含下面内容:

0cb03439a4122161e3f1d763c57a7812.png

Sentinel 可以简单的分为 Sentinel 核心库和 Dashboard。核心库不依赖 Dashboard,但是结合 Dashboard 可以取得最好的效果。

这篇文章主要介绍 Sentinel 引入和规则配置等使用方法。 我们说的资源,可以是任何东西,服务,服务里的方法,甚至是一段代码。

因为Sentinel控制台配置的规则是在内存中的,所以我们需要Nacos来存储规则实现持久化。

本文主要分为四个部分:

  • Sentinel代码方式示例效果
  • Sentinel控制台安装
  • Springboot项目接入Sentinel控制台配置规则
  • 使用Nacos存储规则并实时更新

Sentinel代码方式示例效果

在讲解如何使用nacos存储规则之前,我们先来看下直接代码定义规则和资源的使用方式,这部分不是本文重点。

Sentinel的使用步骤大致可以分为三步:

  1. 引入依赖
  2. 定义资源
  3. 定义规则

我们先来看下Sentinel文档上的一段代码。

1.引入依赖

<dependency><groupId>com.alibaba.csp</groupId><artifactId>sentinel-core</artifactId><version>1.8.0</version>
</dependency>

2.定义资源

public static void main(String[] args) {// 配置规则.initFlowRules();while (true) {// 1.5.0 版本开始可以直接利用 try-with-resources 特性,自动 exit entrytry (Entry entry = SphU.entry("HelloWorld")) {// 被保护的逻辑System.out.println("hello world");} catch (BlockException ex) {// 处理被流控的逻辑System.out.println("blocked!");}}
}

在这里我们定义了一个“HelloWorld”的资源,不断打印hello world。

3.定义规则

private static void initFlowRules(){List<FlowRule> rules = new ArrayList<>(); //定义规则列表FlowRule rule = new FlowRule(); //定义一个规则rule.setResource("HelloWorld"); //什么资源应用此规则rule.setGrade(RuleConstant.FLOW_GRADE_QPS);rule.setCount(20); //没秒只能20次请求rules.add(rule);//加入该规则FlowRuleManager.loadRules(rules); //载入规则列表
}

这里定义了资源“HelloWorld”每秒只能通过20个请求。

运行该main方法,可以看到控制台输出以下内容。

ed9cada863c2a4c871abe023e29d1ac8.png

Sentinel代码方式示例效果

可以看到请求通过20次打印hello world后再请求会阻塞打印blocked!,等到下一秒才会继续打印hello world。

这是一个简单的示例用于说明下Sentinel的作用,下面我们会介绍Sentinel控制台的使用以及搭配Nacos存储规则并实时更新规则。

Sentinel控制台安装

Sentinel控制台提供web可视化页面配置规则,我们需要下载官方提供的jar包安装启动该服务。

1.jar包下载

可以在官网github上下载:https://github.com/alibaba/Sentinel/releases

拉到每个版本信息区块的最下方有jar文件的下载地址。

6b8120f5dd55eade3cda234b9dcc0d82.png

jar文件的下载地址

2.启动脚本

注意根据下载的jar包修改文件名

java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.0.jar

d6133ae0d78986e47b8ce58dc29fcb8f.png

启动Sentinel控制台

3.访问Sentinel控制台

地址和账号密码 http://localhost:8080 账号:sentinel 密码:sentinel

2207834099b39d83a6abb44ea273ee86.png

访问Sentinel控制台

aa094273eb3725bc764f162a0f874e6a.png

访问Sentinel控制台

控制台已经启动完成,可以看到左边首页下面显示了一个sentinel-dashboard的项目,项目包含了监控、链路、各种规则配置和机器列表等菜单可以管理该项目规则,如果有新项目连接到控制台,这里会出现新的项目菜单。

springboot项目接入Sentinel控制台配置规则

1.引入依赖

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

注意我这里没有写版本,因为我在父项目的pom文件中指定了阿里巴巴的依赖版本,子项目的相关依赖会自动寻找版本。

<dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Hoxton.SR8</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.3.RELEASE</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>

2.配置yml

接下去我们可以在项目中连接到该控制台,这样项目里的资源就可以被控制台管理了。

spring:application:name: sentinelcloud:sentinel:transport:port: 8719dashboard: localhost:8080  #启动本项目后需要请求一次才能向sentinel控制台注册

注意:启动项目后需要请求一次项目才能向sentinel控制台注册。

启动项目后我们请求一下项目随便一个接口,然后在控制台可以看到多了一个新项目的菜单了。

53fc391c5043c5cef12093f525614c68.png

新项目的菜单

3.控制台配置项目资源规则

我在项目里写了一个简单的接口如下:

@RequestMapping("/")
public String test(){return "ok";
}

可以在控制台的簇点链路菜单看到这个接口资源。

90415e840c90e83b449237e989d745e9.png

簇点链路菜单

可以看到表格右边有四个按钮,可以对该资源进行流控、降级、热点、授权的配置。

  • 流控 流量控制,可以在流控中设置主要三块内容:阈值类型+阈值、流控模式、流控效果。

585df337ea1a96178b4b923289e27d32.png

流控

阈值类型+阈值:可以设置QPS的阈值,代表每秒最多允许请求多少次资源;可以设置线程数,代表可以同时运行的线程数量。 流控模式:有直接、关联、链路三种。 --直接:代表超过阈值直接限流 --关联:代表关联的资源达到阈值时也进行限流(比如支付接口不行了把下单接口也限流掉)。 --链路:代表当服务到达阈值时,所有使用该服务的服务也限流。 流控效果:有快速失败、Warm Up、排队等待三种。 --快速失败:直接限流操作。 --Warm Up:冷启动,需要配置预热时长,意思是当突然有大量请求时慢慢的放一些请求通过,预热时长过后恢复到正常限流状态,达到阈值时再进行限流。 --排队等待:让限流的请求排队等待系统空闲时再通过,需要配置超时时间,过了超时时间再拒绝请求。

  • 降级 降级有慢调用比例、异常比例、异常数三种熔断策略。

22938a7e8d6180d9c9111413941f4576.png

降级

--慢调用比例:需要设置最大RT(最大的响应时间)和比例阈值(0.0至1.0之间),请求大于最大RT的判定为慢调用,当慢调用比例到达比例阈值时进行熔断降级。 --异常比例:需要设置一个比例阈值,当异常比例达到该阈值时进行熔断降级。 --异常数:需要设置一个异常数,达到该异常数时进行熔断降级。 降级需要设置一个熔断时长和最小请求数,代表熔断持续的时间,当大于最小请求数时降级规则才生效。

  • 热点 热点即经常访问的数据, 很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。对请求中携带的参数进行判断是否是热点数据,是热点数据则根据规则限流。需要设置参数所有和阈值,参数所有从0开始代表请求的第几个参数是热点参数。
  • 授权 授权其实就是黑白名单的设置,黑名单模式代表黑名单里的不允许访问,白名单模式代表白名单里的才允许访问。需要设置对应的应用名称。

4.示例配置

我们以流控操作来做个示例,我们在根请求接口的资源上配置一个流控规则。

d88d5ff60b22022d577860513d1f4e1f.png

示例配置

设置阈值类型为QPS,阈值为1,代表每秒只能通过1个请求。我们来看看效果。

浏览器请求接口,然后按F5不停刷新,可以看到每秒会出现一次返回一次正确信息,其他都会返回限流信息。

9564a2db6fb31ee8a57c8605831de874.png

返回正确信息

196bd611204f8329f02474047e3c1ce1.png

返回限流信息

项目接入控制台部分就讲到这了,需要注意的是这里的控制台配置是存在内存中的,如果你的项目重新启动配置的规则就没了,所以我们需要一个可以持久化配置规则的地方,接下去我们介绍下Nacos来持久化存储Sentinel配置规则。

使用Nacos存储规则并实时更新

Sentinel提供了多种数据源的支持,包括Nacos、Zookeeper、文件数据源等。

ec0926fa1337db5162be25d6cf43f40a.png

使用Nacos存储需要先安装Nacos,可以看我的另外一篇Nacos安装教程文章。

1.引入Nacos依赖

<dependency><groupId>com.alibaba.csp</groupId><artifactId>sentinel-datasource-nacos</artifactId>
</dependency>

2.配置Nacos数据源

安装完Nacos后我们首先在项目中配置Sentinel的数据源为Nacos。

spring:application:name: sentinelcloud:sentinel:transport:port: 8719dashboard: localhost:8080  #启动本项目后需要请求一次才能向sentinel控制台注册datasource: ds2:nacos: server-addr: 192.168.67.129:8848data-id: sentinelgroup-id: Sentinel:Demodata-type: jsonrule-type: flow

ds2是数据源名称,其他主要配置下:

  • Nacos的地址
  • data-id和group-id:等会需要在Nacos控制台新增一个同样的配置才能生效
  • data-type:配置规则数据类型
  • rule-type:flow代表流控类型

3.在Nacos控制台配置规则内容

我们在Nacos控制台的配置列表新增一个配置。

37298ea78ab21bea1d7228631b4cf961.png

新增一个配置

7788e92ea6d1bcb52be1993e02ff809e.png

新增一个配置

配置内容部分如下:

[{"resource": "/","limitApp": "default","grade": 1,"count": 2,"strategy": 0,"controlBehavior": 0,"clusterMode": false}
]

resource:资源名,资源名是限流规则的作用对象

count:限流阈值grade:限流阈值类型,QPS 模式(1)或并发线程数模式(0)

limitApp:流控针对的调用来源

strategy:调用关系限流策略:直接、链路、关联

controlBehavior:流控效果(直接拒绝/WarmUp/匀速+排队等待),不支持按调用关系限流

clusterMode:是否集群限流

4.效果

启动项目,配置好Nacos后,我们可以直接在Sentinel控制台看到nacos的配置已经同步到Sentinel控制台了,并且规则已经生效了,以后该规则只需要在Naocs配置规则就能实时生效了。

1d4dd1b9b6287fd6b711370d19c46459.png

Nacos规则同步到Sentinel控制台

需要注意的是,目前只支持Nacos规则同步到Sentinel控制台,不支持在Sentinel控制台配置规则同步到Nacos。

好了,今天的内容就讲到这里了,希望本文对你有所帮助。

来源:https://www.toutiao.com/i6893111350684287496
作者:程序员柳大侠

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398243.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

斗地主你什么时候才会托管?(.NET中的托管于非托管)

文章部分引自《.NET4.0面向对象编程漫谈&#xff08;基础篇&#xff09;》第1章.NET面向对象编程基础&#xff08;作者&#xff1a;金旭亮&#xff09; 无意间看到一位四五岁左右小朋友在玩斗地主&#xff0c;总开始到结束&#xff0c;她一直都在使用“提示”&#xff08;托管&…

英特尔固态硬盘540s开卡_英特尔Z490主板绝配?技嘉PCIe 3.0 x8固态硬盘测试:6.5GB/s读速...

PCIe 4.0为高端NVMe固态硬盘提供了更广阔的提升空间&#xff0c;而暂时与PCIe 4.0无缘的英特尔平台就比较尴尬。技嘉推出的AORUS RAID SSD似乎正是为此而生&#xff0c;它以PCIe 3.0 x8接口提供6500MB/s顺序读取和6000MB/s顺序写入速度&#xff0c;足以媲美尚未面世的第二代PCI…

李洪强-C语言2-字符串

C语言字符串 一、字符串基础 注意&#xff1a;字符串一定以\0结尾。 Printf(“yang\n”); 其中yang为字符串常量&#xff0c;“yang”‘y’‘a’‘n’‘g’‘\0’。字符串由很多的字符组成&#xff0c;通常使用字符数组来存储字符串&#xff0c;如char name[10]“yang”;也可以…

【练习5.9】图像掩码、礼帽、cvCopy、图像融合、cvCvtColor

提纲题目要求程序代码结果图片要言妙道题目要求&#xff1a; 读入一副风景图&#xff0c;然后将其转化为灰度图像 a、对图像进行形态学“礼帽”操作&#xff0c;并显示结果 b、将结果图像转化为8位的掩码 c、复制灰度值到礼帽块中&#xff0c;显示结果→我的理解是&#xff0c;…

div超出不换行_文字超出显示点点点之ellipsis 设置

一般情况下一行文字在一定区域显示的话如果不限定高度&#xff0c;那么在内容超过的宽度的话就会换行显示&#xff0c;为了页面的美观&#xff0c;目前的通用做法就是在最后显示…&#xff0c;然后鼠标悬浮显示完整内容&#xff0c;具体设置如下:height: 40px; overflor: hidde…

Kali源库配置和拼音安装

2019独角兽企业重金招聘Python工程师标准>>> 版本&#xff1a;kali-linux-2016.1-i386 0、对kali进行系统更新或者软件安装&#xff0c;直接通过国内网络访问境外主网网络不稳定&#xff0c;不如改成国内资源站点。 1、修改以下文档 vim /etc/apt/sources.list 2、文…

java中审核订单流程图_Java 后端横扫阿里、滴滴、美团总结的面试经验!

这次面试的公司有一点点多&#xff0c;主要是因为毕业后前两份工作找的都很草率&#xff0c;这次换工作就想着&#xff0c;emm&#xff0c;毕业三年了&#xff0c;该找个工作好好沉淀几年了。先说下这次面试的结果吧&#xff1a;到 hr 面的&#xff1a;阿里、美团、滴滴、金山云…

产品铭牌要求_AMPULM:电力变压器铭牌有哪些主要技术参数,你都知道吗?

电力变压器电力变压器是供配电系统中关键的一个环节&#xff0c; 它起到电力系统中电压等级的变换&#xff0c;同时连接不同电压等级的电网&#xff0c;以利于电能的输送、分配和使用。认识变压器铭牌图片为一台电力变压器上的铭牌&#xff0c;从铭牌上可以看到变压器的哪些信息…

python 学习资源收集汇总

2019独角兽企业重金招聘Python工程师标准>>> Python是一种面向对象、直译式计算机程序设计语言。它的语法简捷和清晰&#xff0c;尽量使用无异义的英语单词&#xff0c;与其它大多数程序设计语言使用大括号不一样&#xff0c;它使用縮进来定义语句块。与Scheme、Rub…

一年月份大小月口诀_怎么看自己的日柱 公式 推算口诀 最简便计算方法

日柱指的是我们农历干支出生的那一天&#xff0c;通过日柱我们可以看出自己命运的轨迹和走向&#xff0c;从风水学上来讲日柱是八字算命中举足轻重的一部分&#xff0c;那么如何知道自己的日柱呢&#xff1f;通过本期的四柱预测&#xff0c;给大家介绍一种最简便的推算口诀和日…

delphi excel取批注所在的行列_35个Excel使用技巧

技巧1、单元格内强制换行在单元格中某个字符后按alt回车键&#xff0c;即可强制把光标换到下一行中。技巧2、锁定标题行选取第2行&#xff0c;视图 - 冻结窗格 - 冻结首行(或选取第2行 - 冻结窗格)冻结后再向下翻看时标题行始终显示在最上面。技巧3、打印标题行如果想在打印时每…

如何接收串口数据_UART IDLE 中断使用接收不定长串口数据

前言在串口通信应用中&#xff0c;我们常使用接受和发送中断&#xff0c;相信大家都不陌生。这里有个非常有用的中断可能被大家所忽略&#xff0c;即总线IDLE中断。当一帧数据传输结束之后&#xff0c;总线会维持高电平状态&#xff0c;此时&#xff0c;就可以触发MCU的IDLE中断…

MFC 进度条CProgressCtrl

2019独角兽企业重金招聘Python工程师标准>>> SetStep(1);//设置步长 SetRange32(0, total);//设置范围 SetPos(_cur);//设置当前 进度 StepIt();进步一次 转载于:https://my.oschina.net/kkkkkkkkkkkkk/blog/688392

css限制字体三行_讲道理,仅3行核心css代码的rate评分组件,我被自己秀到头皮发麻...

(给100素材网点亮★号&#xff0c;提升开发技能)像rate评分组件一般都用javascript写&#xff0c;所以这次将是一个全新的尝试&#xff0c;用css实现一个rate评分 ❗ 核心代码也就三行?01效果图02原理主要是借助radio单选框&#xff0c;梳理如下&#xff1a;去找个好看的iconf…

matlab GUI之自定义菜单小结

自定义菜单 1.uimenu对象 huimenu(PropertyName,ProperValue) huimenu(parent,PropertyName,ProperValue) 常见属性&#xff1a; 1.1标签 label uimenu(label,&Open) 1.2快捷键 Accelerator uimenu(Accelerator,E) 快捷键位 ctrlE 注意以下三个是系统保留的Accelerator…

把cpp编译为so_基于VSCode和CMake进行C/C++开发第三讲GCC编译器

3.0 本讲目录本系列视频&#xff0c;B站首发&#xff0c;up主: xiaobing1016前言&#xff1a;GCC 编译器支持编译 Go、Objective-C&#xff0c;Objective-C &#xff0c;Fortran&#xff0c;Ada&#xff0c;D 和 BRIG(HSAIL)等程序&#xff1b;Linux 开发C/C 一定要熟悉 GCCVS…

CSS快速入门-箭头和图标

一、三步搞懂箭头产生的原理 在前面的盒子模型一文中&#xff0c;我们已经知道了一个元素空间占位。为了弄明白箭头的产生&#xff0c;我们可以三步走&#xff1a; #demo12 {border: 100px solid;border-color:green blue orange red;width:100px;height:100px;}<div id&quo…

自动清理归档日志_从MYSQL 数据库归档 到 归档设计

到数据归档&#xff0c;很多人的第一个概念就是&#xff0c;不就是无用的数据&#xff0c;换个地方放吗&#xff0c;直接拷贝&#xff0c;删除不就得了&#xff0c;有那么麻烦。我见到过的&#xff0c;听到过的数据库归档的方法有以下几种1 数据通过人工的手段来进行清理&…

Android支付宝SDK开发笔记

一、准备工作 〉1、下载开发包 https://b.alipay.com/order/productDetail.htm?productId2014110308141993&tabId4#ps-tabinfo-hash 压缩包下的“支付宝钱包支付接口开发包”中即有Andoid使用支付宝的JAR和Demo 〉2、创建支付宝应用 在支付宝开放平台申请创建应用 https:/…

一天一个类,一点也不累之HashSet

最近忙着一个小项目结题&#xff0c;故没能按时完成【一天一个类&#xff0c;一点也不累】&#xff0c;还好项目优秀&#xff0c;算是对自己一点点的安慰和鼓励。~~~ 今天要说的是HashSet 既然是继承自Set&#xff0c;那么就必须有Set的一些属性&#xff0c;比如不能容许有相同…