Spring Cloud Sentinel
是什么
随着微服务的流行,服务和服务之间的稳定性变得越来越重要。Sentinel
以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
Sentinel
具有以下特征:
- 丰富的应用场景:
Sentinel
承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。 - 完备的实时监控:
Sentinel
同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。 - 广泛的开源生态:
Sentinel
提供开箱即用的与其它开源框架/库的整合模块,例如与Spring Cloud
、Dubbo
、gRPC
的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入Sentinel
。 - 完善的 SPI 扩展点:
Sentinel
提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。
Sentinel
的主要特性:
Sentinel
的开源生态:
安装
Sentinel
分为两个部分:
- 核心库(Java 客户端)不依赖任何框架/库,能够运行于所有
Java
运行时环境,同时对Dubbo
/Spring Cloud
等框架也有较好的支持。 - 控制台(
Dashboard
)基于Spring Boot
开发,打包后可以直接运行,不需要额外的 Tomcat 等应用容器。
环境配置:Java
环境必须是JDK1.8
及以上,并且8080端口不能被占用!
下载当前时间对应的最新版本sentinel-dashboard-1.7.2.jar
,并通过命令java -jar sentinel-dashboard-1.7.2.jar
启动。
通过访问sentinel
管理界面http://localhost:8080
,如下:
能够看到以上界面则代表sentinel
启动成功,默认的账号密码是sentinel
,登录进去后能够看到如下界面:
编码
新建项目cloudalibba-sentinel-service
1 | <!--pom.xml 引入相关依赖--> |
1 | #application.yml |
1 |
|
通过启动项目注册到nacos
和sentinel
中,并登陆sentinel
页面查看是否注册成功,结果如下:
界面空空如也的原因是因为sentlnel
默认采用的是懒加载机制,需要先触发一次接口:http://localhost:8401/testA
和http://localhost:8401/testB
。
再次查看sentinel
控制台,结果如下:
最后更新: 2020年11月12日 12:24
原始链接: https://midkuro.gitee.io/2020/06/28/springcloud-sentinel/