SpringCloud 集成Sentinel

一、Seninel简介SpringCloud 集成Sentinel_第1张图片

 SpringCloud 集成Sentinel_第2张图片

Sentinel和Hystrix的区别

SpringCloud 集成Sentinel_第3张图片 三、sentinel可视化界面安装

下载对应版本的sentinel的jar包,通过终端命令:

java -jar jar包名

 启动SpringCloud 集成Sentinel_第4张图片

  访问对应路径:控制台如下:SpringCloud 集成Sentinel_第5张图片

四、在springcloudalibaba中整合sentinel

(1)添加依赖

        
        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-sentinel
        

 (2)配置yml

server:
  port: 8002
 
spring:
  application:
    name: WXL-DEV-SERVICE-2
  cloud:
    sentinel:
      transport:
        dashboard: 127.0.0.1:8080

(3)启动服务,再访问服务后,观察控制台:因为访问接口以后才会注册到sentinel当中。SpringCloud 集成Sentinel_第6张图片

五、流控规则

(1)实时监控,可用于查看接口访问情况SpringCloud 集成Sentinel_第7张图片

 (2)簇点链路,可以对对应的资源流控降级SpringCloud 集成Sentinel_第8张图片

可以设置阀值来流控:

(3)QPS流控SpringCloud 集成Sentinel_第9张图片

 可以看到当每秒超过2次时被流控:SpringCloud 集成Sentinel_第10张图片

  流控文字可自定义:

    @GetMapping("/world")
    @SentinelResource(value = "helloWorld",blockHandler = "helloBlock")
    public String helloWorld() {
        return "Hello world";
    }
 
    public String helloBlock(BlockException e){
        return "你已被流控";
    }

value将该方法定义为sentinel的资源,blockHandler是流控时调用的方法。SpringCloud 集成Sentinel_第11张图片

  (4)线程流控SpringCloud 集成Sentinel_第12张图片

 (5)关联限流SpringCloud 集成Sentinel_第13张图片

这里的意思是如果/hello/add接口一秒钟之内访问超过2次,则/hello/query会被限流。

(6)熔断降级SpringCloud 集成Sentinel_第14张图片

 也要设置熔断时长,熔断时长过完之后会进入半开状态,即若下一次请求为慢请求则再次熔断,直到第一次请求不是慢请求才会恢复正常状态。

六、OpenFeign整个Sentinel

(1)导入依赖:

        
        
            org.springframework.cloud
            spring-cloud-starter-openfeign
        

(2)调用者开发整合配置:

feign:
  sentinel:
    enabled: true #开启openFeign对sentinel的整合

(3)添加openFeign调用接口

package com.wxl.feign;
 
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
 
@FeignClient(name = "WXL-DEV-SERVICE-2", path = "/hello",fallback = ServiceFailFeign.class)
public interface Service1HelloInterface {
    @GetMapping("/world")
    String helloWorld();
}

并且这里添加参数fallback值为失败时回调的实现类。

实现类如下:

package com.wxl.feign;
 
import org.springframework.stereotype.Component;
 
@Component
public class ServiceFailFeign implements Service1HelloInterface{
    public String helloWorld() {
        return "降级了!!!";
    }
}

请求该消费者服务接口:

SpringCloud 集成Sentinel_第15张图片

七、规则持久化

(1)引入依赖

        
        
            com.alibaba.csp
            sentinel-datasource-nacos
        

(2)为nacos添加配置SpringCloud 集成Sentinel_第16张图片

SpringCloud 集成Sentinel_第17张图片

SpringCloud 集成Sentinel_第18张图片

 


[{
  "resource": "payment-gary",
  "count": 1000,
  "timeWindow": 5,
  "grade": 0,
  "minRequestAmount": 2,
  "slowRatioThreshold": 0.2,
  "statIntervalMs": 10000
}]

SpringCloud 集成Sentinel_第19张图片

 

参考详见:

sentinel配置 持久化到nacos_yueF_L的博客-CSDN博客_sentinel持久化到nacos

Sentinel安装使用和配置,sentinel-dashboard安装使用和配置 - jiaoqing。 - 博客园

Gateway整合Sentinel熔断降级_小脑斧学技术的博客-CSDN博客_gateway整合sentinel降级

你可能感兴趣的:(spring,cloud,sentinel,java)