Springboot整合Sentinel

本文详细介绍了如何将Sentinel与Springboot进行整合,用于服务的流量控制、熔断和降级。Sentinel提供了丰富的应用场景,如秒杀,具备实时监控功能,并能与Spring Cloud、Dubbo等框架无缝集成。在Sentinel的安装部分,提到了服务端和客户端的启动及连接方式。客户端接入部分分别阐述了基于Spring Cloud和原生客户端的接入步骤,最后展示了客户端如何使用Sentinel进行手工和注解方式的流量控制。
摘要由CSDN通过智能技术生成

Sentinel简介

随着微服务的流行,服务和服务之间的稳定性变得越来越重要。 Sentinel 以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
Sentinel具有如下特性:

  • 丰富的应用场景:承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀,可以实时熔断下游不可用应用;
  • 完备的实时监控:同时提供实时的监控功能。可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况;
  • 广泛的开源生态:提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合;
  • 完善的 SPI 扩展点:提供简单易用、完善的 SPI 扩展点。您可以通过实现扩展点,快速的定制逻辑。

Sentinel安装

Sentinel包括服务端和客户端,服务端有可视化界面,客户端需引入jar后即可和服务端通信并完成限流功能。

  • 下载
    从官网下载Sentinel,下载地址:https://github.com/alibaba/Sentinel/releases, 这里下载的是sentinel-dashboard-1.6.3.jar文件

  • 启动
    通过命令启动sentinel服务端:java -jar sentinel-dashboard-1.6.3.jar,默认启动8080端口。启动成功之后,通过如下地址可以进行访问:http://localhost:8080,默认登录账号密码均为sentinel。
    在这里插入图片描述
    此时因为我们并没有启动客户端,所以界面是空的。

客户端接入

客户端接入,这里分两种方式,一种是基于Spring Cloud的方式接入,另外一种是基于原生客户端的方式接入。

####Spring Cloud接入
首先,maven中引入:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
    <version>0.9.0.RELEASE</version>
</dependency>

然后,在yml配置文件里面,配置服务端地址:

spring:
  application:
    name: sentinel
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8080
        heartbeat-interval-ms:500
        eager:true

接着,编写测试用例:

@RestController
public class HelloController {
   

    @GetMapping(value = "/hello")
    @SentinelResource("hello")
    public String hello() {
   
        return "Hello,Sentinel";
    }
}

SentinelResource注解里的值是资源标识符,可以为这个资源标识符指定限流,熔断规则等,在浏览器里请求这个地址,然后查看sentinel控制台:
在这里插入图片描述
在这里插入图片描述

客户端接入

首先,maven中引入:

<properties>
	<java.version>1.8</java.version>
	<sentinel.version>1.6.3</sentinel.version>
</properties>
<!-- 适配dubbo -->
<dependency>
	<groupId>com.alibaba.csp</groupId>
	<artifactId>sentinel-dubbo-adapter</artifactId>
	<version>${
   sentinel.version}</version>
</dependency>

<!-- 开启注解 -->
<dependency>
	<groupId>com.alibaba.csp</groupId>
	<artifactId<
Spring BootSentinel是两个独立的开源项目,可以通过一些配置和依赖来实现它们的整合。下面是一个简单的步骤: 1. 在你的Spring Boot项目中,添加Sentinel的依赖。你可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.alibaba.csp</groupId> <artifactId>sentinel-spring-webmvc-adapter</artifactId> <version>x.x.x</version> </dependency> ``` 2. 创建一个配置类,用于配置Sentinel的相关参数。在该类上添加`@Configuration`注解,并使用`@PostConstruct`注解来初始化Sentinel的相关配置。例如: ```java import org.springframework.context.annotation.Configuration; @Configuration public class SentinelConfig { @PostConstruct public void init() { // 初始化Sentinel的相关配置,例如规则的加载等 } } ``` 3. 在你的Controller类上使用`@SentinelResource`注解来定义资源,并配置对应的限流规则。例如: ```java import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/api") public class MyController { @GetMapping("/hello") @SentinelResource(value = "hello", blockHandler = "handleBlock") public String hello() { return "Hello, Sentinel!"; } public String handleBlock(BlockException ex) { return "Blocked by Sentinel"; } } ``` 在上面的例子中,`@SentinelResource`注解用于定义一个资源,其中`value`属性指定资源名称,`blockHandler`属性指定当资源被限流时的处理方法。 4. 最后,启动你的Spring Boot应用程序,并访问定义的API进行测试。 这只是一个简单的示例,你可以根据自己的需要在Spring Boot项目中进行更多的配置和调整。希望对你有所帮助!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值