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

微服务保护:Sentinel

home | Sentinel https://sentinelguard.io/zh-cn/

微服务保护的方案有很多,比如:

  • 请求限流

  • 线程隔离

  • 服务熔断

服务故障最重要原因,就是并发太高!解决了这个问题,就能避免大部分故障。当然,接口的并发不是一直很高,而是突发的。因此请求限流,就是限制或控制接口访问的并发流量,避免服务因流量激增而出现故障。

当一个业务接口响应时间长,而且并发高时,就可能耗尽服务器的线程资源,导致服务内的其它接口受到影响。所以我们必须把这种影响降低,或者缩减影响的范围。线程隔离正是解决这个问题的好办法。 

线程隔离虽然避免了雪崩问题,但故障服务依然会拖慢(服务调用方)的接口响应速度。而且故障依然会导致查询功能出现故障,业务也变的不可用了。

这些方案或多或少都会导致服务的体验上略有下降,比如请求限流,降低了并发上限;线程隔离,降低了可用资源数量;服务熔断,降低了服务的完整度,部分服务变的不可用或弱可用。因此这些方案都属于服务降级的方案。但通过这些方案,服务的健壮性得到了提升,

Sentinel 的使用可以分为两个部分:

  • 核心库(Jar包):不依赖任何框架/库,能够运行于 Java 8 及以上的版本的运行时环境,同时对 Dubbo / Spring Cloud 等框架也有较好的支持。在项目中引入依赖即可实现服务限流、隔离、熔断等功能。

  • 控制台(Dashboard):Dashboard 主要负责管理推送规则、监控、管理机器信息等。

一、下载jar包

Releases · alibaba/Sentinel https://github.com/alibaba/Sentinel/releases二、运行jar包

 将jar包放在任意非中文、不包含特殊字符的目录下,重命名为sentinel-dashboard.jar

然后运行如下命令启动控制台:

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

三、访问

访问http://localhost:8090 http://localhost:8080页面,就可以看到sentinel的控制台了:

账号密码都是:sentinel

整合到微服务中:

依赖:

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

 配置:

spring:
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8090
      http-method-specify: true # 开启请求方式前缀

启动服务sentinel就会自动监控服务

 


http://www.kler.cn/a/577659.html

相关文章:

  • 双网卡电脑,IP地址漂移
  • 揭开AI-OPS 的神秘面纱 第八讲 AI-Ops 架构 用户界面|数据中台 分析
  • 【Hadoop】详解HDFS
  • elk单机版安装
  • 【实战ES】实战 Elasticsearch:快速上手与深度实践-3.2.3 案例:新闻搜索引擎的相关性优化
  • electron + vue3 + vite 渲染进程到主进程的双向通信
  • 大语言模型从理论到实践(第二版)-学习笔记(绪论)
  • 将本地已有的项目上传至仓库
  • 聚簇索引 VS 非聚簇索引
  • matlab和FPGA联合仿真时读写.txt文件数据的方法
  • react拖曳组件react-dnd的简单封装使用
  • 物联网设备接入系统后如何查看硬件实时数据?
  • RAGflow升级出错,把服务器灌满了
  • 结合 Pandas 使用 SQLite3 实战
  • 国产编辑器EverEdit - 安装扩展功能的方式
  • 定时器Tim输出比较(output compare)
  • C语言单链表头插法
  • 步进电机软件细分算法解析与实践指南
  • 批量插入对比-mysql-oracle-sqlserver
  • android paging使用教程