为什么要有微服务保护?
微服务保护是为了避免微服务雪崩而出现的,每个微服务能处理的请求是有限的,如果一个微服务出现问题导致一个请求进入微服务的时间太久,就会导致大量去请求停滞在微服务内部,这样就会过分占用系统资源从而影响到其他的微服务,针对者一问题,Alibaba提供了一个组件----sentinel。
什么是sentinel?
sentinel为我们提供了多种方式去保护我们的微服务安全,比如请求限流、线程隔离、断路器等。
请求限流:通过控制QPS来降低微服务的访问次数,从而达到保护微服务的目的
线程隔离:通过控制Thread线程数量来保证微服务的安全
断路器:当一个微服务的访问频率达到了一定的阈值就会将这个微服务给阻断,在一定的时间之内是禁止访问的。
安装sentinel
下载sentinel安装包
运行sentinel
注册到微服务
查看控制台
1. 下载sentinel
2. 本地启动sentinel
将安装包放置非中文目录,并重命名为
sentinel-dashboard.jar通过cmd启动sentinel
XMLjava -Dserver.port=8090 -Dcsp.sentinel.dashboard.server=localhost:8090 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar3. 访问sentinel控制台
XMLlocalhost:8090将sentinel部署到项目
依赖
XML<!--sentinel--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency>配置文件
XMLspring: cloud: sentinel: transport: dashboard: localhost:8090 # sentinel控制台地址 http-method-specify: true # 开启对http 访问前缀的支持比如GET、PUT
微服务保护-sentinel
小汤猿人类2024-12-30 8:54
相关推荐
暮色妖娆丶39 分钟前
不过是吃了几年互联网红利罢了,我高估了自己NE_STOP1 小时前
MyBatis-参数处理与查询结果映射狂奔小菜鸡2 小时前
Day40 | Java中的ReadWriteLock读写锁SimonKing3 小时前
JetBrains 用户狂喜!这个 AI 插件让 IDE 原地进化成「智能编码助手」狂奔小菜鸡3 小时前
Day39 | Java中更灵活的锁ReentrantLockNE_STOP16 小时前
MyBatis-配置文件解读及MyBatis为何不用编写Mapper接口的实现类后端AI实验室21 小时前
用AI写代码,我差点把漏洞发上线:血泪总结的10个教训程序员清风1 天前
小红书二面:Spring Boot的单例模式是如何实现的?belhomme1 天前
(面试题)Redis实现 IP 维度滑动窗口限流实践Be_Better1 天前
学会与虚拟机对话---ASM

