栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

了解spring-cloud-alibaba-sentinel

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

了解spring-cloud-alibaba-sentinel

spring-cloud-alibaba-sentinel.jar是sentinel在springboot下的包装

meta-INF下 spring.factories说明了相关的自动加载类,

SentinelWebAutoConfiguration

  • 根据web环境SERVLET的情况加载, @ConditionalOnWebApplication(type=Type.Servlet)
  • 依赖于CommonFilter来源(sentinel的jar),
  • 默认spring.cloud.sentinel.enabled为true
  • 加载SentinelProperties
  • 类中加载引用之前所述的 UrlCleaner UrlBlockHandler RequestOriginParaser
  • 并通过spring FilterRegistrationBean注册CommonFilter,来实现对url请求前后添加Sphu.entry方法实现加载sentinel的限流。 CommonFilter中包含了对UrlCleaner UrlBlockHandler RequestOriginParaser的使用

SentinelFeignAutoConfiguration

添加对Feign的限流包装,主要通过Feign-> 实现invocationHandlerFactory的create方法,通过jdk的InvocationHandler的invoke方法中添加Sphu.entry的sentinel限流

SentinelWebFluxAuoConfiguration

在spring-gateway(应用了springwebFlux框架)中添加限流

SentinelAutoConfiguration

对配置的加载(支持db等),声明SentinelBeanPostProcessor通过MergedBeanDefinitionPostProcessor实现对SentinelRestTemplate注解限流配置的使用,beanDefinitionPostProcessor判断是否为RestTemplate对象且添加了Sentinel注解,after方法中添加RestTemplate的interceptor拦截SentinelProtectInterceptor。

spring-configuration-metada.json对配置属性作了对应的注解,初次引入框架可以详细查看metadata的内容,即便不熟悉,也能较快的应用到项目中。

jar简洁清晰,便于了解springboot的加载及如何模块化编程,通过不同的方式实现对各种场景下的限流加载。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/284600.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号