微服务架构sentinel

Sentinel是一款用于流量控制、熔断和系统保护的开源中间件,广泛应用于秒杀、抢购等高并发场景。通过限流、降级和熔断策略,Sentinel能确保系统在流量激增时保持稳定。本文介绍了Sentinel的安装、配置及限流模式,包括直接模式、关联模式和链路模式,并展示了如何在Spring Cloud中集成Sentinel进行流量控制。
摘要由CSDN通过智能技术生成

Sentinel简介

背景分析

       在我们日常生活中,经常会在淘宝、天猫、京东、拼多多等平台上参与商品的秒杀、抢购以及一些优惠活动,也会在节假日使用12306 手机APP抢火车票、高铁票,甚至有时候还要帮助同事、朋友为他们家小孩拉投票、刷票,这些场景都无一例外的会引起服务器流量的暴涨,导致网页无法显示、APP反应慢、功能无法正常运转,甚至会引起整个网站的崩溃。
       我们如何在这些业务流量变化无常的情况下,保证各种业务安全运营,系统在任何情况下都不会崩溃呢?我们可以在系统负载过高时,采用限流、降级和熔断,三种措施来保护系统,由此一些流量控制中间件诞生。例如Sentinel。

Sentinel概述

        Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景, 例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。

安装Sentinel服务

第一步:打开sentinel下载网址

https://github.com/alibaba/Sentinel/releases

第二步:下载Jar包
在这里插入图片描述
第三步:在sentinel 对应目录,打开命令行(cmd),启动运行sentinel

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

访问Sentinal服务

在这里插入图片描述

默认账号密码都是sentinel

Sentinel限流

限流的目的防止恶意请求流量、恶意攻击,或者防止流量超过系统峰值。

Sentinel集成

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

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

配置yml

spring:
  cloud:
    sentinel:
      transport:
         port: 8099 #跟sentinel控制台交流的端口,随意指定一个未使用的端口即可
         dashboard: localhost:8180 # 指定sentinel控制台地址。

设置限流模式

在这里插入图片描述

  1. 直接模式

_QPS:每秒请求的次数
_单机阈值:允许每秒请求的次数
_Sentinel默认的流控处理就是【直接->快速失败】。

在这里插入图片描述

反复刷新访问消费端端服务,检测是否有限流信息输出,如图所示:
在这里插入图片描述

  1. 关联模式

当关联的资源达到阈值,就限流自己

在这里插入图片描述
3. 链路模式

链路模式只记录指定链路入口的流量。也就是当多个服务对指定资源调用时,假如流量超出了指定阈值,则进行限流。被调用的方法用@SentinelResource进行注解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值