码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • SpringCloud 集成Sentinel


    目录

    一、Seninel简介

    ??二、Sentinel和Hystrix的区别

    三、sentinel可视化界面安装

    四、在springcloudalibaba中整合sentinel

    (1)添加依赖

    (2)配置yml

    (3)启动服务,再访问服务后,观察控制台:因为访问接口以后才会注册到sentinel当中。

    五、流控规则

    (1)实时监控,可用于查看接口访问情况

    (2)簇点链路,可以对对应的资源流控降级

    (3)QPS流控

    ?(4)线程流控

    (5)关联限流

    (6)熔断降级

    六、OpenFeign整个Sentinel

    (1)导入依赖:

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

    (3)添加openFeign调用接口

    七、规则持久化

    (1)引入依赖

    (2)为nacos添加配置


    一、Seninel简介

    二、Sentinel和Hystrix的区别

    三、sentinel可视化界面安装

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

    java -jar jar包名
    
    • 1

    启动

    访问对应路径:控制台如下:

    四、在springcloudalibaba中整合sentinel

    (1)添加依赖

            
            
                com.alibaba.cloud
                spring-cloud-starter-alibaba-sentinel
            
    
    • 1
    • 2
    • 3
    • 4
    • 5

    (2)配置yml

    server:
      port: 8002
    
    spring:
      application:
        name: WXL-DEV-SERVICE-2
      cloud:
        sentinel:
          transport:
            dashboard: 127.0.0.1:8080
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    (3)启动服务,再访问服务后,观察控制台:因为访问接口以后才会注册到sentinel当中。

    五、流控规则

    (1)实时监控,可用于查看接口访问情况

    (2)簇点链路,可以对对应的资源流控降级

    可以设置阀值来流控:

    (3)QPS流控

    可以看到当每秒超过2次时被流控:

    流控文字可自定义:

        @GetMapping("/world")
        @SentinelResource(value = "helloWorld",blockHandler = "helloBlock")
        public String helloWorld() {
            return "Hello world";
        }
    
        public String helloBlock(BlockException e){
            return "你已被流控";
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    value将该方法定义为sentinel的资源,blockHandler是流控时调用的方法。

    (4)线程流控

    (5)关联限流

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

    (6)熔断降级

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

    六、OpenFeign整个Sentinel

    (1)导入依赖:

            
            
                org.springframework.cloud
                spring-cloud-starter-openfeign
            
    
    • 1
    • 2
    • 3
    • 4
    • 5

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

    feign:
      sentinel:
        enabled: true #开启openFeign对sentinel的整合
    
    • 1
    • 2
    • 3

    (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();
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

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

    实现类如下:

    package com.wxl.feign;
    
    import org.springframework.stereotype.Component;
    
    @Component
    public class ServiceFailFeign implements Service1HelloInterface{
        public String helloWorld() {
            return "降级了!!!";
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    当接口请求失败时便会调用失败类里的该方法。

    这里我们为了使用效果,在服务生产者的接口里故意写入报错代码:

        @GetMapping("/world")
        public String helloWorld() {
            int i=1/0;
            return "Hello world";
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    请求该消费者服务接口:

    调用了失败回调方法!

    七、规则持久化

    (1)引入依赖

            
            
                com.alibaba.csp
                sentinel-datasource-nacos
            
    
    • 1
    • 2
    • 3
    • 4
    • 5

    (2)为nacos添加配置

    更多见:

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

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    Python 中的滚动赫斯特指数-可视化市场节奏
    docker系列持续更新中
    【Django | 开发】 Rest Framework 开放API
    OpenAI发布ChatGPT:程序员瞬间不淡定了
    Bug解决:出现C++:internal compiler error: killed(program cc1plus)
    python-django美食数据爬取及分析系统
    集团建筑公司安全风险调度数字化管理系统
    ClickHouse学习笔记之MaterializeMySQL引擎
    企业电子文档管理系统哪个好?怎么选?
    [go][转载]vscode配置完go跑个helloworld例子
  • 原文地址:https://blog.csdn.net/m0_67392661/article/details/126116220
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号