码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Spring Cloud项目(六)——使用sentinel作为流控管理


    代码部分(在consumer模块中改)

    1、pom文件

            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
            </dependency>
    
    • 1
    • 2
    • 3
    • 4

    2、启动类
    在这里插入图片描述

    3、yml配置
    在这里插入图片描述

    4、controller
    在这里插入图片描述

    测试结果

    sentinel是懒加载,需要浏览器访问

    http://(ip+port)/consumer/findById/2
    
    • 1

    在这里插入图片描述

    什么是sentinel

    随着微服务的流行,服务和服务之间的稳定性变得越来越重要。Sentinel 是面向分布式服务架构的轻量级流量控制产品,主要以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度来帮助您保护服务的稳定性。

    sentinel的可视化管理

    1、下载地址:https://github.com/alibaba/Sentinel/releases

    在这里插入图片描述

    2、执行命令:java -jar sentinel-dashboard-1.7.1.jar

    在这里插入图片描述

    流控规则

    在这里插入图片描述

    1、资源名:唯一名称,默认请求路径
    2、针对来源:Sentinel可以针对调用者进行限流,填写微服务名,指定对哪个微服务进行限流 ,默认default(不区分来源,全部限制)
    3、阈值类型:

    • QPS(每秒钟的请求数量):当调用该接口的QPS达到了阈值的时候,进行限流;
    • 线程数:当调用该接口的线程数达到阈值时,进行限流

    4、是否集群:不需要集群

    5、流控模式:

    • 直接:接口达到限流条件时,直接限流
    • 关联:当关联的资源达到阈值时,就限流自己
    • 链路:只记录指定链路上的流量(指定资源从入口资源进来的流量,如果达到阈值,就可以限流)[api级别的针对来源]

    6、流控效果

    • 快速失败:直接失败
    • Warm Up:即请求 QPS 从 threshold / 3 开始,经预热时长逐渐升至设定的 QPS 阈值
    • 排队等待
    具体介绍

    QPS(Queries-per-second):单纯的代表每秒的访问次数,只要访问次数到达一定的阈值,则进行 限流操作
    线程数:代表的是每秒内访问改api接口的线程数,如果该接口的操作比较长,当排队的线程数到达阈值的时候,进行限流操作,相反的如果接口的操作快,即是没秒内的操作很快,同样不会进
    行限流操作

    直接:对当前资源的流量控制

    关联:当关联的资源达到阈值时,限流自己。如支付接口达到阈值时限流订单接口。
    快速失败:限流的时候直接提示
    warm up:即QPS阈值 从 threshold / 3 开始,经预热时长逐渐升至设定的 QPS 阈值。这种情况主要是为了保护系统,例如在秒杀系统;
    排队等待:即/testA每秒1次请求,超过的话就排队等待,等待的超时时间为10ms,目的是为了匀速处理请求,保证服务的均匀性,而不是一会处理大量的请求,一会有没有请求可处理。

    在这里插入图片描述

    结语

    下面关于Spring Cloud学习系列的博客的连接有的是不能使用的,因为博主还在努力创作中,敬请期待

    附:Spring Cloud学习系列

    Spring Cloud项目(一)——集成Nacos作为注册中心
    Spring Cloud项目(二)——集成Nacos作为配置中心
    Spring Cloud项目(三)——实现Nacos数据信息持久化到MySQL
    Spring Cloud项目(四)——使用Ribbon作为负载均衡
    Spring Cloud项目(五)——使用openFeign作为服务调用
    Spring Cloud项目(六)——使用sentinel作为流量管理
    Spring Cloud项目(七)——使用sentinel作为限流和熔断
    Spring Cloud项目(八)——使用gateway作为服务网关

  • 相关阅读:
    软件设计不是CRUD(17):低耦合模块设计理论——总结
    图书管理系统(SpringBoot+SpringMVC+Mybatis)
    QT—基于http协议的网络文件下载
    前端性能测试工具WebPagetest
    点云 3D 数据 读取、保存 - pypcd 包
    Linux系统下压缩与解压命令
    nginx搭建域名访问环境(反向代理配置)(练习用)
    金融壹账通香港上市:市值63亿港元 叶望春称守正笃实,久久为功
    Vue2.0源码理解(4) - 合并配置
    【学习笔记62】判断数据类型的方法
  • 原文地址:https://blog.csdn.net/weixin_45974176/article/details/126425728
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号