1.【Hystrix技术指南】(2)参数配置的源码详细介绍
2.Hystrix Dashboard详ç»ä»ç»
3.Hystrix原理与实战
【Hystrix技术指南】(2)参数配置的详细介绍
配置参数详解
Hystrix属性优先级排序如下:
1. 实例属性
2. 实例默认
3. 默认属性
4. 默认值
HystrixCommand.run()的隔离策略设置如下:
执行超时限制设置为实例默认的属性execution.isolation.thread.timeoutInMilliseconds。
设置是源码否启用执行超时限制为实例默认的属性execution.timeout.enabled。
超时发生时是源码否中断执行为实例默认的属性execution.isolation.thread.interruptOnTimeout。
取消动作发生时是源码否响应中断为实例默认的属性execution.isolation.thread.interruptOnCancel。
最大请求数设置为实例默认的源码属性execution.isolation.semaphore.maxConcurrentRequests。
回退方法控制通过属性fallback.isolation.semaphore.maxConcurrentRequests、源码java gui 源码fallback.enabled来实现。源码
断路器(Circuit Breaker)的源码配置如下:
是否启用断路器设置为circuitBreaker.enabled。
在一个滚动窗口中,源码打开断路器的源码最少请求数设置为circuitBreaker.requestVolumeThreshold。
回路被打开后拒绝请求到再次尝试请求并决定回路是源码否继续打开的时间设置为circuitBreaker.sleepWindowInMilliseconds。
打开回路并启动回退逻辑的源码错误比率设置为circuitBreaker.errorThresholdPercentage。
强制断路器进入打开或关闭状态的源码属性circuitBreaker.forceOpen、circuitBreaker.forceClosed。源码
请求上下文的源码配置包括:
是否启用请求缓存设置为requestCache.enabled。
是否记录日志到HystrixRequestLog设置为requestLog.enabled。
HystrixCollapser行为控制如下:
触发批处理执行前的最大请求数设置为maxRequestsInBatch。
批处理创建到执行之间的毫秒数设置为timerDelayInMilliseconds。
请求缓存是否对HystrixCollapser的调用起作用设置为requestCache.enabled。
线程池属性包括:
核心线程池大小设置为coreSize。
线程池最大值设置为maximumSize。真量指标源码
最大队列值设置为maxQueueSize。
队列拒绝的阈值设置为queueSizeRejectionThreshold。
存活时间设置为keepAliveTimeMinutes。
允许maximumSize与coreSize不同设置为allowMaximumSizeToDivergeFromCoreSize。
统计的滚动窗口的时间段大小设置为metrics.rollingStats.timeInMilliseconds。
滚动的统计窗口被分成的桶的数目设置为metrics.rollingStats.numBuckets。
这些配置选项允许您精确控制Hystrix的行为,确保您的应用程序能够高效、可靠地运行。详细配置需要根据您的智慧题库管理源码具体需求进行调整。
Hystrix Dashboard详ç»ä»ç»
1ãç®ä»
Hystrix Dashboardæ¯ä¸ä¸ªéè¿æ¶éactuator端ç¹æä¾çHystrixæµæ°æ®ï¼å¹¶å°å ¶å¾è¡¨åç客æ·ç«¯ãå¦æéè¦éè¿å¾è¡¨åççé¢æ¥ç被æè·¯å¨ä¿æ¤çæ¹æ³ç¸å ³è°ç¨ä¿¡æ¯ãæè å®æ¶çæ§è¿äºè¢«æè·¯å¨ä¿æ¤çåºç¨çå¥åº·æ åµï¼å°±å¯ä»¥ä½¿ç¨Hystrix Dashboardã
2ãæ£æ2.1 å¯å¨Hystrix Dashboardå建ä¸ä¸ªSpring Boot项ç®æ·»å Hystrix Dashboard ä¾èµ
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId></dependency>å¨å¯å¨ç±»ä¸ä½¿ç¨@EnableHystrixDashboard注解æ¥å¯å¨Hystrix Dashboard
@SpringBootApplication@EnableHystrixDashboardpublicclassApplication{ publicstaticvoidmain(String[]args){ SpringApplication.run(Application.class,args);}}æå®Hystrix Dashboardæå¡å¯å¨ç«¯å£
server:port:å¯å¨æå¡ï¼è®¿é®/hystrix端ç¹ï¼çå°å¦ä¸çé¢åè¯æHystrix Dashboardå¯å¨æå
2.2 å¯ç¨Actuator端ç¹Hystrix Dashboardæ¯éè¿å®æ¶è·åActuator端ç¹æä¾çHystrixæµæ¥å®æ¶çæ§è¿äºè¢«æè·¯å¨ä¿æ¤çåºç¨çå¥åº·æ åµï¼å æ¤å¨è¿äºè¢«æè·¯å¨ä¿æ¤çåºç¨ä¸éè¦å¼å¯HystrixæµçActuator端ç¹ï¼æ³¨æï¼å¦ä¸ææé ç½®é½æ¯å¨å·²ç»éæäºHystrixçæå¡ä¸è¿è¡çç¸å ³æä½ï¼ã
å¼å ¥actuatorä¾èµ
<!--actuatorä¾èµ--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency>æ´é²hystrix端ç¹
#æ´é²hystrix端ç¹management:endpoints:web:exposure:include:'hystrix.stream'å¨Hystrix Dashboardä¸è¾å ¥æå¡æ´é²çhystrixæµå°åhttp://localhost:/actuator/hystrix.stream
ç¹å»Monitor Streamä¹åè¿å ¥çåå§çé¢å¦ä¸æ示ï¼å¦æ没åºç°é¡µé¢ï¼åªæ¯æ¾ç¤ºloadingï¼é£å°±è¯´ææè·¯å¨æ¹æ³æªè¢«è°ç¨ï¼åªéåæè·¯å¨æ¹æ³åéä¸æ¬¡è¯·æ±å³å¯ï¼ï¼
2.3 Hystrix Dashboardé¢æ¿åæ°ä»ç»Hystrix Dashboardé¢æ¿å¯åä¸ä¸ä¸¤é¨åæ¥æ¥è¯¢ï¼ä¸é¢é¨åæ¯æè·¯å¨æ¹æ³è°ç¨çç¸å ³ä¿¡æ¯ï¼Circuitï¼ä¸é¢é¨åæ¯Hystrix为æè·¯å¨æ¹æ³æä¾ç线ç¨æ± ç¸å ³ä¿¡æ¯ï¼Thread Poolsã
Circuit:
Circuitè¿éå±ç¤ºçå½åæ¹æ³çç¸å¯¹ä¿¡æ¯ï¼å¦ææå¤ä¸ªæ¹æ³è¢«æè·¯å¨ä¿æ¤ï¼é£ä¹è¿éå°ä¼ä¾æ¤å±ç¤ºå¤ä¸ªæ¹æ³çç¸å ³ä¿¡æ¯ã
å¨å¾è¡¨ä¸ï¼å·¦ä¸è§çåå代表äºè¯¥æ¹æ³çæµéåç¶æï¼
ååè¶å¤§ä»£è¡¨æ¹æ³æµéè¶å¤§
åå为绿è²ä»£è¡¨æè·¯å¨å¥åº·ãé»è²ä»£è¡¨æè·¯å¨å¶åæ éã红è²ä»£è¡¨æè·¯å¨æ é
å³ä¸è§ç计æ°å¨ï¼ä¸åæ°åï¼ï¼
第ä¸åä»ä¸å°ä¸
绿è²ä»£è¡¨å½åæåè°ç¨çæ°é
èè²ä»£è¡¨ç路请æ±çæ°é
è绿è²ä»£è¡¨é误请æ±çæ°é
第äºåä»ä¸å°ä¸
é»è²ä»£è¡¨è¶ æ¶è¯·æ±çæ°é
ç´«è²ä»£è¡¨çº¿ç¨æ± æç»çæ°é
红è²ä»£è¡¨å¤±è´¥è¯·æ±çæ°é
第ä¸å
è¿å»sçé误请æ±ç¾åæ¯
Thread Poolsï¼
Hystrixä¼é对ä¸ä¸ªåä¿æ¤çç±»å建ä¸ä¸ªå¯¹åºç线ç¨æ± ï¼è¿æ ·åçç®çæ¯Hystrixçå½ä»¤è¢«è°ç¨çæ¶åï¼ä¸ä¼åæ¹æ³è¯·æ±çº¿ç¨çå½±åï¼æè 说Hystrixçå·¥ä½çº¿ç¨åè°ç¨è 线ç¨ç¸äºä¹é´ä¸å½±åï¼
å¨å¾è¡¨ä¸ï¼å·¦ä¸è§çåå代表äºè¯¥çº¿ç¨æ± çæµéåç¶æï¼
ååè¶å¤§ä»£è¡¨çº¿ç¨æ± è¶æ´»è¶ï¼æµéè¶å¤§
ååé¢è²ä»£è¡¨çæ¯çº¿ç¨æ± çå¥åº·ç¶åµ
å·¦ä¸è§ä»ä¸è³ä¸ï¼
Active代表线ç¨æ± ä¸æ´»è·çº¿ç¨çæ°é
Queued代表æéç线ç¨æ°éï¼è¯¥åè½é»è®¤ç¦æ¢ï¼å æ¤é»è®¤æ åµä¸å§ç»ä¸º0
Pool Size代表线ç¨æ± ä¸çº¿ç¨çæ°éï¼ä¸é¢å¾ææéäºï¼å°å¾æ»MMPï¼
å³ä¸è§ä»ä¸è³ä¸ï¼
Max Active代表æ大活è·çº¿ç¨ï¼è¿éå±ç¤ºçæ°æ®æ¯å½åéç¨å¨æä¸ï¼æ´»è·çº¿ç¨çæ大å¼
Execcutions代表线ç¨æ± ä¸çº¿ç¨è¢«è°ç¨æ§è¡Hystrixå½ä»¤ç次æ°
Queue Size代表线ç¨æ± éåç大å°ï¼é»è®¤ç¦ç¨ï¼æ æä¹
Hystrix原理与实战
分布式系统中,依赖服务间调用常见,同步调用时,若库存服务不可用,商品服务线程被阻塞,大量请求可能耗尽资源,导致服务不可用,引发雪崩效应。Hystrix是Netflix开源的容错框架,具有自我保护能力,平台源码定制开发用于隔离服务依赖,避免雪崩效应。其设计目标是通过熔断、回退等策略提高系统的稳定性和可靠性。
Hystrix遵循的设计原则包括容错、隔离、控制和降级。通过线程池和信号量隔离减少资源竞争,熔断机制限制对故障服务的调用频率,回退逻辑在服务不可用时提供备用方案。酷信源码交通实现上,Hystrix提供了多种执行命令方法(execute、queue、observe、toObservable),分别适用于同步和异步调用,以及是否立即执行。Hystrix容错主要通过添加容许延迟和容错方法,控制分布式服务交互,隔离访问点,提供回退选项,提高系统弹性。
资源隔离中,线程池和信号量用于限制并发访问。线程池通过配置不同类型的命令对应不同线程池,实现服务间的隔离。信号量限制并发数量,避免大量请求同时到达依赖服务,防止服务过载。Hystrix熔断器则通过统计错误率,动态控制对依赖服务的调用频率,以防止服务调用链的级联故障。熔断器配置包括是否启用、错误阈值、请求频率、睡眠窗口等参数。
熔断器工作原理分为判断是否允许请求、是否打开熔断开关、是否允许单个请求通行等步骤,通过统计请求结果,维护健康检查窗口,判断服务状态。在降级处理中,Hystrix提供快速失败、无声失败、静态回退、Stubbed回退、缓存回退、主次逻辑切换等多种策略,确保服务在依赖故障时仍能提供部分功能。
总结,Hystrix通过自我保护能力、容错策略、资源隔离和熔断机制,以及灵活的降级逻辑,有效提高了分布式系统在依赖故障情况下的稳定性,减少了雪崩效应的风险,确保关键业务不受影响。