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

springboot整合sentinel

一、准备

  • docker安装好sentinel-dashboard(sentinel控制台),参考docker安装好各个组件的命令
  • 启动sentinel-dashboard,我的虚拟机ip为192.168.200.131,sentinel-dashboard的端口为8858

二、整合sentinel的主要工作

  • 在需要监控的服务中引入spring-cloud-starter-alibaba-sentinel依赖
  • bootstrap.yml中设置好sentinel-dashboardip:port

在我的项目中,给order-serviceproduct-service都引入了sentinel

# pom.xml
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency># bootstrap.yml
spring:cloud:sentinel:transport:dashboard: 192.168.200.131:8858

三、查看sentinel控制台

  • 启动两个服务
  • docker启动sentinel控制台
    • 浏览器输入:http://192.168.200.131:8858/
    • 输入默认账号密码都是sentinel

刚开始控制台左边只能看到sentinel-dashboard,只有当我们第一次访问过后,相应的服务和请求才会在左边(和簇点链路)中出现

在这里插入图片描述

四、控制台基础功能

4.1 流量控制

4.2 熔断降级

(1)当未配置熔断降级功能时
product-service/product/getByObj限流为QPS=10,超过10则迅速失败

在这里插入图片描述使用jmeter进行压测,QPS为20,访问接口为http://127.0.0.1:8081/order/get2,发现20个请求里有10个请求访问失败,浏览器报500错误

在这里插入图片描述
此外,idea控制台报异常

feign.FeignException$TooManyRequests: [429] during [POST] to [http://product-service/product/getByObj] [IProductClient#getByObj(ProductDTO)]: [Blocked by Sentinel (flow limiting)]

sentinel控制台显示有10个请求被拒绝

在这里插入图片描述

(2)给IProductClient配置熔断降级功能
IProductClient这个feign接口为例,当这个接口对应的http请求被限流阻断时,启用一个新的IProductClient对服务进行降级(实际项目中比如:"当前请求繁忙,请稍后访问"或者推荐别的页面)。
步骤如下:

  • sd-api模块的com.hdl.api.client.product包下建一个fallback包,用来存放feignclient的请求调用被熔断时降级处理的类
  • 在该包下建ProductClientFallback
  • IProductClient@FeignClient注解上配置fallbackFactory = ProductClientFallback.class
  • 需要将ProductClientFallback类放入ioc容器,因此在com.hdl.api.config包下建一个FallbackConfig,用来生产ProductClientFallbackbean,同时将FallbackConfig放到·spring.factories·文件里

http://www.mrgr.cn/news/36410.html

相关文章:

  • 聊聊nodejs mysql版本
  • 【HTTP协议详解-Fiddler抓包工具安装详解-HTTP报文格式-URL详解】
  • Robot Operating System——带有时间戳和坐标系信息的三维向量
  • PySimpleGUI:简化 Python 中的 GUI 开发
  • 基于遗传优化算法的多AGV栅格地图路径规划matlab仿真
  • 数据结构 - 数组
  • 车位租赁系统的设计与实现
  • 我刚刚测试了Gemini-1.5-Pro-002和Gemini-1.5-Flash-002模型——你需要知道的事项!
  • 美团一面:给定两棵二叉树 `A` 和 `B`,判断 `B` 是否是 `A` 的子结构?
  • 【Tourism】Yuncheng(4)
  • Dubbo入门案例
  • 通信工程学习:什么是PNF物理网络功能
  • 集合ArrayList常用方法
  • 进阶SpringBoot之 Dubbo 及 Zookeeper 安装
  • Netty简介
  • 基于Python大数据的音乐推荐及数据分析可视化系统
  • [Redis][主从复制][上]详细讲解
  • Java内存模型?
  • 客户端数JSON据库SQL操作功能实现代码-———未来之窗行业应用跨平台架构
  • 16.面试算法-树的层次遍历与相关面试题