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

Sentinel介绍及搭建

分布式流量防护

服务雪崩

服务提供者不可用导致服务调用者也跟着不可用,以此类推引起整个链路中的所有微服务都不可用

分布式流量防护

在分布式系统中,服务之间的相互调用会生成分布式流量。如何通过组件进行流量防护,并有效控制流量,是分布式系统的技术挑战之一

服务保护技术

在SpringCloud当中支持多种服务保护技术Hystrix/Sentinel/Resilience4J

Sentinel

Sentinel

Sentinel是阿里开源的项目,提供了流量控制、熔断降级、系统负载保护等来保障服务之间的稳定性

主要特性

丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。

完备的实时监控:Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。

广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。

完善的 SPI 扩展点:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。

linux环境安装

网址

https://github.com/alibaba/Sentinel/releases

软件

sentinel-dashboard-1.8.3.jar

Linux启动(jar包所在目录,记得修改ip)

java -Dserver.port=8858 \-Dcsp.sentinel.dashboard.server=192.168.66.101:8858 \-Dproject.name=sentinel-dashboard \-jar ./sentinel-dashboard-1.8.3.jar

访问(最好谷歌)

192.168.66.101:8858

账号密码【sentinel/sentinel

使用docker安装

拉取镜像

docker pull docker.io/bladex/sentinel-dashboard

创建容器自启动,记得修改端口号

docker run --name sentinel --restart=always -d  -p 8858:8858 docker.io/bladex/sentinel-dashboard

访问

192.168.66.101:8858

账号密码【sentinel/sentinel

在项目中集成

创建maven项目子模块cloud-providerSentinel9003

pom.xml

<dependencies><!--     sentinel依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency><!--nacos-discovery--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!--SpringMVC--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--Actuator--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><!--Lombook--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>
</dependencies>

Yaml配置文件

server:port: 9003
spring:application:name: cloud-providerSentinel9003cloud:nacos:discovery:# Nacos地址server-addr: 192.168.66.101:8848sentinel:transport:# Sentinel 控制台地址dashboard: 192.168.66.101:8858# sentinel api端⼝,默认8719port: 8719

启动类

@SpringBootApplication
public class providerSentinel9003 {public static void main(String[] args) {SpringApplication.run(providerSentinel9003.class,args);}
}


测试类

@RequestMapping("/providerSentinel9003")
@RestController
public class ProviderSentinel9003Controller {@GetMapping("testA")public String testA(){return "------------testA";}
}

测试

http://localhost:9003/providerSentinel9003/testA

http://www.lryc.cn/news/62478.html

相关文章:

  • 最受信任的低代码平台排行榜
  • Django框架之创建项目、应用并配置数据库
  • 软件测试之基础概念学习篇(需求 + 测试用例 + 开发模型 + 测试模型 + BUG)
  • Windows下版本控制器(SVN) - 1、开发中的实际问题+2、版本控制简介
  • Learning Dynamic Facial Radiance Fields for Few-Shot Talking Head Synthesis 笔记
  • SpringBoot 项目整合 Redis 教程详解
  • 3ASC25H214 DATX130以力控制为基础的装配应用方面已经形成了一个解决方案
  • Java的位运算
  • FastDFS分布式文件存储
  • Android的AAC架构
  • 高功率激光切割中不良现象的排除技巧
  • MySQL-----复合查询
  • 10.Yarn概述
  • MFC实现背景透明,控件不透明的对话框,且点击图片有事件响应
  • 案例01-tlias智能学习辅助系统01-增删改查+参数传递
  • Spring之Bean的配置与实例
  • “不保留活动”打开,导致app返回前台崩溃问题解决
  • 解读vue3源码(3)——watch
  • 优秀简历的HR视角:怎样打造一份称心如意的简历?
  • 系统集成项目管理工程师——考试重点(三)项目管理一般知识
  • 为什么医疗保健需要MFT来帮助保护EHR文件传输
  • 对项目总体把控不足,项目经理应该怎么办?
  • 【学习笔记】CF603E Pastoral Oddities
  • 如何使用ESP32-CAM构建一个人脸识别系统
  • JavaWeb分页条件查询参数特殊字符处理
  • ubuntu18服务安装
  • 这些使用工具大推荐,现在知道不晚
  • 【Java|golang】1048. 最长字符串链
  • Hive基础和使用详解
  • c/c++:栈帧,传值,传址,实参传值给形参,传地址指针给形参