SpringCloud(8):Sentinel:Sentinel概述

一、服务熔断Hystrix的替换方案

(1) 概述

     Spring Cloud官方尤其着重指出ribbonhystrix 和 zuulSpring Cloud 2020.0正式版发布后将不再被Spring Cloud支持。

(2)替换方案介绍

  • Sentinel是阿里开源的一款熔断器的实现,目前在Spring Cloud的孵化器项目Spring Cloud Alibaba中的一员Sentinel本身在阿里内部已经被大规模采用,非常稳定。因此,可以作为一个很好的替代品。
  • Resilience4J是一款轻量、简单,并且文档非常清晰、丰富的熔断工具,这也是Hystri官方推荐的替代产品。不仅如此,Resilience4J还原生支持SpringBoot 1.x/2.x,而且监控也不像Hystrix一样弄Dashboard/Hystrix等一堆轮子,而是支持和micrometer、prometheus以及Dropwizard metrics进行整合。

二、Sentinel概述

    中文官网home

(1)Sentinel是什么?

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

  • Sentinel 具有以下特征:

  • 丰富的应用场景:Sentinel 承接了阿里巴巴近10年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。
  • 完备的实时监控:Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。
  • 广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入Sentinel。
  • 完善的 SPI 扩展点:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。

(2)能干嘛?

SpringCloud(8):Sentinel:Sentinel概述_第1张图片

三、安装和运行Sentinel Dashboard(控制面板)

(1) Sentinel的组成

    Sentinel 的组成可以分为两个部分:

  • 核心库(Java 客户端):不依赖任何框架/库,能够运行于 Java 7 及以上的版本的运行时环境,同时对 Dubbo / Spring Cloud 等框架也有较好的支持(见 主流框架适配)。主流框架的适配 · alibaba/Sentinel Wiki · GitHub
  • 控制台(Dashboard):控制台主要负责管理推送规则、监控、集群限流分配管理、机器发现等。

(2)安装和运行步骤

    下载地址https://github.com/alibaba/Sentinel/releases,下载完jar包后运行命令:

# -Dserver.port=8080用于指定Sentinel控制台端口为8080
java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.0.jar

    Sentinel的登录界面(访问地址默认是http://localhost:8080/,用户名和密码为sentinel/sentinel):

SpringCloud(8):Sentinel:Sentinel概述_第2张图片

 SpringCloud(8):Sentinel:Sentinel概述_第3张图片

(3)开启nacos

 SpringCloud(8):Sentinel:Sentinel概述_第4张图片

四、在服务提供者中加入Sentinel

(1)使用provider-8101中添加依赖



    
        springcloud
        com.buba
        1.0-SNAPSHOT
    
    4.0.0

    provider-8101

    
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-nacos-discovery
        
        
        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-sentinel
        
    

(3)在application.yml中添加Sentinel配置

server:
  port: 8101
spring:
  application:
    name: provider
  cloud:
    # nocos注册中心
    nacos:
      discovery:
        server-addr: localhost:8848
    sentinel:
      transport:
        # 配置Sentinel Dashboard地址
        dashboard: 127.0.0.1:8080
        # 默认8719端口,假设被占用会自动从8719开始依次加1扫描,直到找到没有被占用的端口
        port: 8719
        # 取消懒加载
      eager: true
management:
  endpoints:
    web:
      exposure:
        include: "*"

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