当前位置: 首页 > news >正文

Spring Boot 整合 Sentinel 实现流量控制

在微服务架构中,流量控制是保障系统稳定性和高可用性的关键技术之一。阿里巴巴开源的 Sentinel 是一款面向分布式系统的流量防护组件,旨在从流量控制、熔断降级、系统负载保护等多个维度保障服务的稳定性。本文将详细介绍如何在 Spring Boot 项目中整合 Sentinel 实现流量控制。

1. Sentinel 简介

Sentinel 是阿里巴巴开源的一个轻量级流量控制框架,主要用于保护分布式服务的稳定性。其核心功能包括:

  • 实时监控:通过控制台可以实时查看系统的流量、响应时间等数据。

  • 流量控制:可以针对不同的资源设定不同的流量控制规则。

  • 熔断降级:在服务不稳定或出现故障时,自动进行熔断降级处理。

  • 系统自适应保护:根据系统的运行状况,自动调整流量控制策略。

2. Spring Boot 项目初始化

首先,我们需要创建一个 Spring Boot 项目。可以通过 Spring Initializr 创建项目,选择合适的依赖,如 Spring Web 等。

mvn archetype:generate -DgroupId=com.example -DartifactId=sentinel-demo -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=falsecd sentinel-demo

在 pom.xml 中添加 Spring Boot 相关依赖:

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>2.6.3</version>
</parent>
<dependencies>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-web</artifactId>    </dependency>
</dependencies>

3. 引入 Sentinel 依赖

在 pom.xml 中添加 Sentinel 依赖:

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

4. 配置 Sentinel

在 application.yml 文件中进行 Sentinel 的基本配置:

spring:  cloud:   sentinel:      transport:        dashboard: localhost:8080  # Sentinel 控制台地址        port: 8719  # 客户端向控制台上报信息的端口

启动 Sentinel 控制台,下载 Sentinel 控制台 jar 包并启动:

java -jar sentinel-dashboard-1.8.0.jar

5. 实现流量控制

5.1 定义资源

在 Spring Boot 中,可以使用 Sentinel 提供的注解来定义受保护的资源。创建一个简单的控制器:

package com.example.sentineldemo.controller;
import com.alibaba.csp.sentinel.annotation.SentinelResource;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;@RestControllerpublicclass TestController {@GetMapping("/hello")@SentinelResource("helloResource")public String hello() {return "Hello, Sentinel!";}}

在上述代码中,我们使用 @SentinelResource 注解将 /hello 接口标记为一个受保护的资源,资源名为 helloResource。

5.2 配置规则

可以通过编程的方式或在控制台上配置流量控制规则。以下是通过编程的方式配置流量控制规则的示例:

 package com.example.sentineldemo.config;
import com.alibaba.csp.sentinel.slots.block.RuleConstant;import com.alibaba.csp.sentinel.slots.block.flow.FlowRule;import com.alibaba.csp.sentinel.slots.block.flow.FlowRuleManager;
import javax.annotation.PostConstruct;import java.util.ArrayList;import java.util.List;@Configurationpublicclass SentinelConfig {@PostConstructpublic void initFlowRules() {List<FlowRule> rules = new ArrayList<>();FlowRule rule = new FlowRule();rule.setResource("helloResource");rule.setGrade(RuleConstant.FLOW_GRADE_QPS);rule.setCount(1); // 限制 QPS 为 1        rules.add(rule);        FlowRuleManager.loadRules(rules);    }}

上述代码中,在@PostConstruct方法中配置了流量控制规则,限制 helloResource 资源的 QPS 为 1。

6. 控制台监控

在启动 Spring Boot 项目后,可以通过 Sentinel 控制台查看流量控制效果。打开浏览器访问 http://localhost:8080,在控制台中可以看到受保护的资源和相关的监控数据。

7. 实践中的一些建议

  1. 合理设置流量控制规则:根据实际业务需求和系统性能设置合理的流量控制规则,避免过度限制或保护不足。

  2. 结合熔断降级机制:在流量控制的基础上,结合熔断降级机制,进一步提高系统的稳定性和可用性。

  3. 监控和报警:及时监控系统的运行状况,设置报警机制,及时发现和处理异常情况。

  4. 性能优化:定期进行性能测试和优化,确保系统能够在高并发场景下稳定运行。

8. 总结

本文详细介绍了在 Spring Boot 项目中整合 Sentinel 实现流量控制的步骤,包括项目初始化、引入依赖、配置 Sentinel、定义受保护的资源以及配置流量控制规则。通过合理设置流量控制规则和结合熔断降级机制,可以有效保障系统的稳定性和高可用性。Sentinel 作为一款强大的流量控制框架,能够在分布式系统中发挥重要作用。

相关文章:

Spring Boot 整合 Sentinel 实现流量控制

在微服务架构中&#xff0c;流量控制是保障系统稳定性和高可用性的关键技术之一。阿里巴巴开源的 Sentinel 是一款面向分布式系统的流量防护组件&#xff0c;旨在从流量控制、熔断降级、系统负载保护等多个维度保障服务的稳定性。本文将详细介绍如何在 Spring Boot 项目中整合 …...

Elasticsearch倒排索引

什么是倒排索引 倒排索引&#xff08;Inverted Index&#xff09;是一种将文档中的每个单词映射到包含该单词的文档列表上的数据结构 倒排索引的构建过程 文档1: “我爱吃苹果” 文档2: “我爱吃香蕉” 文档3: “我喜欢苹果和香蕉” 文档分词&#xff1a;将文档中的文本内容…...

速盾:ddos常用防御方法是什么?

DDoS攻击是一种通过向网络资源发送大量请求或大流量数据来使其过载的攻击手段。为了应对这种攻击&#xff0c;常用的防御方法可以分为三个层次&#xff1a;流量清洗、服务器升级和高防CDN。 流量清洗是一种基础的防御手段&#xff0c;它通过过滤和识别恶意流量来阻止DDoS攻击。…...

二分算法入门(简单题)

习题1 704. 二分查找 给定一个 n 个元素有序的&#xff08;升序&#xff09;整型数组 nums 和一个目标值 target &#xff0c;写一个函数搜索 nums 中的 target&#xff0c;如果目标值存在返回下标&#xff0c;否则返回 -1。 示例 1: 输入: nums [-1,0,3,5,9,12], targ…...

在使用React Hooks中,如何避免状态更新时的性能问题?

在React Hooks中避免状态更新时的性能问题&#xff0c;可以采取以下一些最佳实践&#xff1a; 避免不必要的状态更新&#xff1a; 使用React.memo、useMemo、和useCallback来避免组件或其子组件进行不必要的渲染。 使用useMemo&#xff1a; 对于基于状态或props的复杂计算&…...

Pytest插件pytest-selenium-让自动化测试更简洁

在现代Web应用的开发中&#xff0c;自动化测试成为确保网站质量的重要手段之一。而Pytest插件 pytest-selenium 则为开发者提供了简单而强大的工具&#xff0c;以便于使用Python进行Web应用的自动化测试。本文将深入介绍 pytest-selenium 插件的基本用法和实际案例&#xff0c;…...

视觉语言模型(VLMs)知多少?

最近这几年&#xff0c;自然语言处理和计算机视觉这两大领域真是突飞猛进&#xff0c;让机器不仅能看懂文字&#xff0c;还能理解图片。这两个领域的结合&#xff0c;催生了视觉语言模型&#xff0c;也就是Vision language models (VLMs) &#xff0c;它们能同时处理视觉信息和…...

重新修改 Qt 项目的 Kit 配置

要重新修改 Qt 项目的 Kit 配置&#xff0c;你可以按照以下步骤进行操作&#xff1a; 1. 打开 Qt Creator 首先&#xff0c;启动 Qt Creator&#xff0c;确保你的项目已经打开。 2. 进入项目设置 在 Qt Creator 中&#xff0c;点击菜单栏的 “Projects” 标签&#xff08;通…...

【Spring Boot 3】【Web】自定义响应状态码

【Spring Boot 3】【Web】自定义响应状态码 背景介绍开发环境开发步骤及源码工程目录结构背景 软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是要花费…...

Locksupport凭证的底层原理

LockSupport的凭证&#xff08;通常称为“许可”或“permit”&#xff09;的底层原理主要涉及到Java的Unsafe类以及系统级的线程同步机制。LockSupport是Java 6&#xff08;JSR166-JUC&#xff09;引入的一个类&#xff0c;提供了基本的线程同步原语&#xff0c;其核心功能是通…...

Elasticsearch 再次开源

作者&#xff1a;来自 Elastic Shay Banon [D.N.A] Elasticsearch 和 Kibana 可以再次被称为开源了。很难表达这句话让我有多高兴。我真的激动得跳了起来。Elastic 的所有人都是这样的。开源已经融入我的 DNA&#xff0c;也融入了 Elastic 的 DNA。能够再次将 Elasticsearch 称…...

对称密码学

1. 使用OpenSSL 命令行 在 Ubuntu Linux Distribution (发行版&#xff09;中&#xff0c; OpenSSL 通常可用。当然&#xff0c;如果不可用的话&#xff0c;也可以使用下以下命令安装 OpenSSL: $ sudo apt-get install openssl 安装完后可以使用以下命令检查 OpenSSL 版本&am…...

正则表达式优化建议

文章目录 优化正则表达式代码示例&#xff1a;注意事项&#xff1a; 一些常见的正则表达式陷阱 优化正则表达式是提高文本处理效率和准确性的重要步骤。以下是一些优化正则表达式的方法&#xff1a; 以下是整理归纳后的正则表达式优化技巧&#xff1a; 优化正则表达式 一、预…...

Oracle RAC关于多节点访问同一个数据的过程

一、说明 Oracle RAC 存在多个计算节点&#xff0c;但是使用的共享存储。那么多个节点共同访问同一个资源&#xff0c;怎么保证一致性。 白文的逻辑理解简述&#xff1a; 用户1访问rac1 &#xff0c;通过rac1获取AA数据块后&#xff0c;会加上latch锁。用户2通过rac2访问AA数据…...

IPC$漏洞多位密码爆破方法

虽然不应该将其用于非法的密码破解行为,但从代码修改角度来说,如果要破解多位密码(比如 n 位),你可以按照以下方式调整: 破解多位纯数字密码 如果你想破解 6 位纯数字密码: FOR /L %%i IN (100000,1,999999) DO (net use \\target - ip\ipc$ /user:weak %%i &&…...

计算机网络(八股文)

这里写目录标题 计算机网络一、网络分层模型1. TCP/IP四层架构和OSI七层架构⭐️⭐️⭐️⭐️⭐️2. 为什么网络要分层&#xff1f;⭐️⭐️⭐️3. 各层都有那些协议&#xff1f;⭐️⭐️⭐️⭐️ 二、HTTP【重要】1. http状态码&#xff1f;⭐️⭐️⭐️2. 从输入URL到页面展示…...

Docker打包镜像

Docker打包镜像 前置工作 1.虚拟机中配置好docker环境&#xff0c;并导入nginx&#xff0c;mysql&#xff0c;jdk的镜像 2.下载docker for windows 用idea打包镜像和创建容器需要这个东西支持 下载安装包后执行&#xff0c;无脑回车即可 3.idea中配置docker连接 完成配置后&…...

RabbitMQ 基础架构流程 数据隔离 创建用户

介绍 publisher&#xff1a;消息发送者-exchange&#xff1a;交换机&#xff0c;复制路由的消息-queue&#xff1a;队列&#xff0c;存储消息consumer&#xff1a;消息的消费者 工作流程 publisher消息发送者 -> exchange 交换机 -> queue 队列 -> consumer 消息的消…...

win10系统下openssl证书生成和单向认证

文章目录 前言一、安装openssl二、创建证书目录和必要文件1、创建sslcertTest文件夹2、创建openssl.cnf文件3、创建必要文件 三、创建密钥和证书1、创建根证书私钥ca.key2、创建根证书请求文件ca.csr3、创建自签根证书ca.crt4、创建服务端私钥server.key5、创建服务端证书请求文…...

动态规划的解题思想

1. 从斐波那契数列说起 斐波那契数 &#xff08;通常用 F(n) 表示&#xff09;形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始&#xff0c; &#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0, F(2) 1 F&#xff08;n&#xff09; F&…...

LeetCode单词拆分:动态规划详解,Apache介绍和安装。

单词拆分问题概述 单词拆分&#xff08;Word Break&#xff09;是LeetCode上经典的动态规划问题&#xff0c;题目要求判断给定字符串是否可以被拆分为字典中的单词。例如&#xff0c;给定字符串"leetcode"和字典["leet", "code"]&#xff0c;返回…...

指针精要:从入门到精通,嵌入式开发学习日志32——stm32之PWM。

指针的基本概念 指针是编程中用于存储内存地址的变量&#xff0c;它指向另一个变量的位置。通过指针可以直接访问或修改内存中的数据&#xff0c;提升程序的灵活性和效率。 在C/C中&#xff0c;指针的声明方式为&#xff1a; int *ptr; // 声明一个整型指针指针的类型决定了…...

C语言函数指针与回调函数实战指南

1. 函数指针&#xff1a;C语言的瑞士军刀在C语言的世界里&#xff0c;指针堪称是这门语言的灵魂所在。我们熟悉整型指针、字符指针、结构体指针&#xff0c;但函数指针这个强大的工具却常常被开发者忽视。实际上&#xff0c;函数指针是理解回调函数的基础&#xff0c;也是实现C…...

nuviot嵌入式物联网库:GP001平台端到端连接方案

1. nuviot 嵌入式物联网开发库深度解析&#xff1a;面向 GP001 硬件平台的端到端连接方案1.1 库定位与工程价值nuviot 是一套专为嵌入式物联网终端设计的轻量级 C 语言库集合&#xff0c;其核心目标并非提供通用 IoT 协议栈&#xff0c;而是在 GP001 硬件平台&#xff08;NuvIo…...

一文搞懂计算机网络基础!

对于想入门网络安全、IT 运维、云计算的同学来说&#xff0c;计算机网络是绕不开的核心基础。但一堆晦涩的概念、复杂的分类&#xff0c;常常让新手望而却步。今天我们就用一张思维导图&#xff0c;把计算机网络基础的核心知识点全部拆解&#xff0c;从定义、作用、类型、核心设…...

如何快速将网页转换为Figma设计稿:5分钟完成HTML到Figma的无缝转换

如何快速将网页转换为Figma设计稿&#xff1a;5分钟完成HTML到Figma的无缝转换 【免费下载链接】figma-html Convert any website to editable Figma designs 项目地址: https://gitcode.com/gh_mirrors/fi/figma-html HTML到Figma转换工具是一款能够将任何网站转换为可…...

10、Ansible 生产级故障排查与运维最佳实践

Ansible 生产级故障排查与运维最佳实践 一、Ansible 生产常见故障类型&#xff08;高频&#xff09; SSH 连接类故障&#xff08;占 60%&#xff09;sudo/权限类故障网络、端口、防火墙Python 环境缺失/版本不兼容Fact 采集慢、超时、卡死文件权限、临时目录权限变量、模板、加…...

PHP脚本设置无限执行时间的四种方法

为 PHP 脚本设置无限执行时间是一个在特定场景下可能需要的操作&#xff0c;比如执行长时间运行的后台任务、数据迁移、大批量数据处理等。然而&#xff0c;值得注意的是&#xff0c;设置无限执行时间并不是一种推荐的做法&#xff0c;因为它可能导致服务器资源被长时间占用&am…...

保姆级教程:用Python和Paho-MQTT库5分钟搭建你的第一个物联网通信Demo

5分钟实战&#xff1a;用PythonPaho-MQTT构建物联网通信原型 在智能家居设备突然向你手机推送报警消息时&#xff0c;在共享单车锁车后立即完成计费时&#xff0c;背后都是MQTT协议在高效运作。作为物联网领域的"HTTP协议"&#xff0c;MQTT凭借其轻量级和发布/订阅模…...

用Python+OpenCV重构九点标定:抛弃Halcon的轻量化视觉方案

PythonOpenCV九点标定实战&#xff1a;从原理到嵌入式部署的全栈指南 引言&#xff1a;为什么选择开源方案替代Halcon&#xff1f; 在工业视觉领域&#xff0c;九点标定作为连接像素坐标与物理坐标的桥梁&#xff0c;直接影响着定位精度和系统稳定性。传统方案多依赖Halcon等商…...