博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
阿里流控中间件sentinel的思考,主要分析下hytrix的优势
阅读量:6565 次
发布时间:2019-06-24

本文共 1857 字,大约阅读时间需要 6 分钟。

hot3.png

优势官网上已经说了很多,本篇主要想分析下hytrix的一些优势

 

先说sentinel, 简单说下,个人感觉比较有用的功能

sentinel的优势:

  1. 友好的控制面板,支持实时监控
  2. 多种限流。支持QPS限流,线程数限流,多种限流策略,如:直接拒绝,匀速模式(漏斗),冷启动(如设置限制1000,延迟10秒,那第一秒pass100, 第二秒200,递增,适应于缓存保护)
  3. 多种降级模式,支持按平均返回时间降级,按多种异常数降级,按异常比率降级
  4. 方便扩展开发,支持SPI模式对chain进行扩展
  5. 支持链路的关联,按链路统计限流,系统保护,热门资源保护等等

如果远见点,看到阿里后面也开始弄全家桶了  

https://github.com/spring-cloud-incubator/spring-cloud-alibaba 

也是可以持续集成的

当然最终的是hytrix也已经停止维护了。 

 

hytrix的优势

  • hytrix支持异步调用,支持线程池级别的隔离

这种方式就是通过rxJava进行调用,等待完成后进行异步通知调用,但在http这种请求中,主线程还是阻塞在等待中。带来的收益,无非就是hytrix能对超时进行控制。

但坏处也很明显,如果是每个接口创建一个线程池的话,如果接口过多,机器中会创建大量线程,而在java中,线程是属于轻量级的进程,对应是内核线程,进而造成线程的切换。成本还是挺高。

再者每个线程也得需要-Xxs的大小,如果线程数目过多也是一笔不小的花销。

 

  • hytrix支持百分比+连续错误比率的条件进行降级

这部分,确实比sentinel单纯的统计异常率,或异常数更精细,得看业务去取舍。

 

sentinel的局限性:

1, CircuitBreakerRequestVolumeThreshold参数在sentinel里是被关闭了,代码里加了个默认值是5, 也就是说1s请求超过5次请求就会统计。否则不会

2,sentinel所有的统计都是基于QPS的,也就是1s位单位,包括统计异常率,只适合大并发请求的场景.  而hytrix这个时间窗口是可以配置的 (metrics.rollingStats.timeInMilliseconds,metrics.rollingStats.numBuckets)

sentinel熔断的判断方式:

5cafec80ac3a6867c555b71ac7e01338eb1.jpg

 

3, 被熔断后,sentinel没做半打开的状态,放1个流量去试探,而是打开一秒时间重新统计5个

来自hytrix官网,也测试过

After some amount of time (HystrixCommandProperties.circuitBreakerSleepWindowInMilliseconds()), the next single request is let through (this is the HALF-OPEN state). If the request fails, the circuit-breaker returns to the OPEN state for the duration of the sleep window. If the request succeeds, the circuit-breaker transitions to CLOSED and the logic in 1. takes over again.

但sentinel由于只是进去5个,并不是要等返回,故虽然不是放入1个,最多也是放入5个请求就是

 

4,sentinel种所谓融合了dubbo,spring boot/spring cloud,其实只是为每个项目做了个适配器,比如  dubbo 只是扩展了dubbo的filter, spring boot只是添加了spring mvc的过滤器代码添加资源

 

 

总结: 正如阿里自己比较的,sentinel侧重于流控, 而熔断的话hytrix更灵活和专业的,虽然停止开发了。

但一般情况下用sentinel代替hytrix也是足够的了的。 看场景了。 

目前选择了sentinel

 

本想发公司wiki,想想和工作关系没那么大,更多是研究对比,还是发博客这

 

附上阿里自己的对比文档:

https://yq.aliyun.com/articles/623424

 

公众号:

0948edb526f45a71f6f42c334b60afaac8b.jpg

何锦彬 2018.11.21

转载于:https://my.oschina.net/u/867417/blog/2990996

你可能感兴趣的文章
SVN高速新手教程
查看>>
session cookie
查看>>
ZBar之ZBarReaderViewController
查看>>
Nuget~管理自己的包包~丢了的包包快速恢复
查看>>
$.extend({},defaults, options) --(初体验三)
查看>>
maven的一些依赖
查看>>
jQuery hover() 方法
查看>>
android 一步一步教你集成tinker(热修复)
查看>>
到底有多少内存
查看>>
centos7.3 安装ovirt-engine4.0 版本
查看>>
Jenkins+git+tomcat 自动化持续部署
查看>>
项目log日志打印
查看>>
Openstack的环境的Mitaka部署环境服务,实例(1)
查看>>
文档的压缩与打包
查看>>
python3 在不同操作系统安装第三方库方法
查看>>
redhat5.8+mfs(提供软件包文档)
查看>>
python编写登录接口
查看>>
MySQL高可用方案之多级复制
查看>>
OVS 中的各种网络设备 - 每天5分钟玩转 OpenStack(128)
查看>>
Python火车票代码
查看>>