1、什么情况下会触发 fallback 方法

名字 描述 触发fallback
EMIT 值传递 NO
SUCCESS 执行完成,没有错误 NO
FAILURE 执行抛出异常 YES
TIMEOUT 执行开始,但没有在允许的时间内完成 YES
BAD_REQUEST 执行抛出HystrixBadRequestException NO
SHORT_CIRCUITED 断路器打开,不尝试执行 YES
THREAD_POOL_REJECTED 线程池拒绝,不尝试执行 YES
SEMAPHORE_REJECTED 信号量拒绝,不尝试执行 YES

2、fallback 方法在什么情况下会抛出异常

名字 描述 抛异常
FALLBACK_EMIT Fallback值传递 NO
FALLBACK_SUCCESS Fallback执行完成,没有错误 NO
FALLBACK_FAILURE Fallback执行抛出出错 YES
FALLBACK_REJECTED Fallback信号量拒绝,不尝试执行 YES
FALLBACK_MISSING 没有Fallback实例 YES

3、Hystrix Dashboard 界面监控参数

4、Hystrix 常用配置信息

  4.1 超时时间(默认1000ms,单位:ms)

    • hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds:在调用方配置,被该调用方的所有方法的超时时间都是该值,优先级低于下边的指定配置
    • hystrix.command.HystrixCommandKey.execution.isolation.thread.timeoutInMilliseconds:在调用方配置,被该调用方的指定方法(HystrixCommandKey 方法名)的超时时间是该值

4.2 线程池核心线程数

    • hystrix.threadpool.default.coreSize:默认为 10

4.3 Queue

    • hystrix.threadpool.default.maxQueueSize:最大排队长度。默认 -1,使用 SynchronousQueue。其他值则使用 LinkedBlockingQueue。如果要从 -1 换成其他值则需重启,即该值不能动态调整,若要动态调整,需要使用到下边这个配置
    • hystrix.threadpool.default.queueSizeRejectionThreshold:排队线程数量阈值,默认为 5,达到时拒绝,如果配置了该选项,队列的大小是该队列

注意: 如果 maxQueueSize=-1 的话,则该选项不起作用

4.4 断路器

    • hystrix.command.default.circuitBreaker.requestVolumeThreshold:当在配置时间窗口内达到此数量的失败后,进行短路。默认 20 个(10s 内请求失败数量达到 20 个,断路器开)
    • hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds:短路多久以后开始尝试是否恢复,默认 5s
    • hystrix.command.default.circuitBreaker.errorThresholdPercentage:出错百分比阈值,当达到此阈值后,开始短路。默认 50%

4.5 fallback

    • hystrix.command.default.fallback.isolation.semaphore.maxConcurrentRequests:调用线程允许请求 HystrixCommand.GetFallback() 的最大数量,默认 10。超出时将会有异常抛出,注意:该项配置对于 THREAD 隔离模式也起作用

4.6 属性配置参数

    • 参数说明:https://github.com/Netflix/Hystrix/wiki/Configuration
    • HystrixProperty 参考代码:http://www.programcreek.com/java-api-examples/index.php?source_dir=Hystrix-master/hystrix-contrib/hystrix-javanica/src/test/java/com/netflix/hystrix/contrib/javanica/test/common/configuration/command/BasicCommandPropertiesTest.java

最新文章

  1. 如何在UIimageview里显示一张图片里的某一部分
  2. 工具推荐:2016年最佳的15款Android黑客工具
  3. python中迭代器和生成器
  4. Java实现RC4加解密
  5. 用Rational Rose来建立数据库表
  6. TypeScript开发Vue
  7. 【JAVAWEB学习笔记】09_MySQL多表&JDBC(包含MySQL数据库思维导图)
  8. 认识容器和Docker(一)
  9. iBatis第三章:iBatis的基本用法
  10. 驰骋工作流引擎JFlow与activiti的对比之2种结构化模式
  11. 【ZooKeeper】ZooKeeper入门流水记
  12. 查看CPU/CACHE的拓扑结构
  13. linux远程安装和使用
  14. 『翻译』Access USB Devices on the Web
  15. HashSet与TreeSet 区别
  16. lmathlib文件
  17. 机器学习-数据可视化神器matplotlib学习之路(四)
  18. [中英对照]Booting Process in Linux RHEL 7 | Linux RHEL 7启动过程
  19. maven实战系列
  20. 自定义ajax

热门文章

  1. shell基础之case应用
  2. 为何存在uwsgi还要使用nginx
  3. xshell 终端 中文乱码
  4. Linxu 修改主机名
  5. 本地软件仓库配置及NFS安装
  6. libevent中的事件机制
  7. 在gitlab网页上合并分支
  8. TensorFlow反向传播算法实现
  9. VB 老旧版本维护系列---迷之集合- dataTable
  10. python+selenium基础篇,键盘操作