sentinel简单使用

核心demo:

1 引入依赖:

复制代码
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-core</artifactId>
    <version>1.8.0</version>
</dependency>

2  核心代码:

3 限流保护代码:

以上就是sentinel最核心的代码使用逻辑。可以在代码中硬编码需要保护的资源,然后在调用资源之前使用Api做限流保护。

在实际使用过程中,几乎不会使用如上方式做资源保护:代码侵入性强,不能动态扩展需要保护的资源

使用注解完成资源定义(springboot中):

1 引入依赖:

复制代码
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-core</artifactId>
    <version>1.8.0</version>
</dependency>

2 核心代码:

使用注解可以减少代码的侵入性,但是不能动态的扩展(限流规则还是需要硬编码提前处理)

springboot + sentinel + sentinel dashboard

1 下载sentinel dashboard jar包

sentinel-dashboard-1.8.0.jar(当然也可以通过docker下载镜像启动)

2 添加启动参数完成dashbaord的启动

-Dserver.port=8718 -Dcsp.sentinel.dashboard.server=localhost:8718 -Dproject.name=sentinel-dashboard -Dcsp.sentinel.api.port=8719

其中:server.port=8719 表示dashbaord的http端口号

-Dcsp.sentinel.dashboard.server=localhost:8718 表示dashboard把自己本身也注册到dashboard上显示

-Dproject.name=sentinel-dashboard 显示的项目名称

-Dcsp.sentinel.api.port=8719 客户端通信端口

3 sprongboot应用中连接到sentinel dashboard上

a 依赖

b 添加启动命令

-Dcsp.sentinel.dashboard.server=192.168.56.102:8858 ---dashbaord地址

-Dproject.name=webDemo2 ---客户端限制名称

-Dcsp.sentinel.api.port=8719 ---通信端口号

c 配置:

复制代码
        

d 通过调用接口:http://localhost:8112/getStr

此时可以在dashboard的仪表盘上看到接入的应用了:

在spring cloud中的应用接入:

1 依赖:

2 配置

添加如上依赖和配置之后,无需额外配置就可在dashboard上看到相关的应用信息

至于:sentinel核心代码的源码分析和dashboard通信机制在后面的源码分析会补上

相关推荐
空中海4 天前
第六篇:可靠性篇 — Sentinel 熔断限流与 Seata 分布式事务
分布式·sentinel
JAVA面经实录9174 天前
如何选择适合项目的「限流 / 熔断 / 降级」方案
java·spring·kafka·sentinel·guava
蓝眸少年CY6 天前
(第十五篇)spring cloud之Sentinel实现熔断与限流
数据库·spring cloud·sentinel
无风听海8 天前
Python 哨兵值模式(Sentinel Value Pattern)深度解析
开发语言·python·sentinel
空中海9 天前
Redis 原理深度解析:持久化 × 主从复制 × Sentinel × Cluster × 性能排查全攻略
数据库·redis·sentinel
接着奏乐接着舞11 天前
Sentinel
sentinel
随风,奔跑11 天前
Spring Boot Alibaba(三)----Sentinel
spring boot·后端·sentinel
武超杰11 天前
Sentinel 安装启动 + 全规则详解 + Feign 整合 + 持久化
sentinel
青槿吖11 天前
Sentinel 进阶实战:Feign 整合 + 全局异常 + Nacos 持久化,生产环境直接用
java·开发语言·spring cloud·微服务·云原生·ribbon·sentinel
StackNoOverflow11 天前
Sentinel服务保护框架完全指南:从原理到实践
java·数据库·sentinel