Springcloud分散式微服務b2b2c電子商務一整合Hystrix(二)
接著上一篇文章,針
對Spring Cloud的常用問題再次做一些總結
一、整合Hystrix後首次請求失敗
1.1 原因分析
Hystrix 預設的超時時間是1秒,如果在1秒內得不到響應,就會進入 fallback 邏輯。
瞭解springcloud架構可以加求求:三五三六二四七二五九,由於 Spring 的懶載入機制,
首次請求往往會比較慢,因此在某些機器(特別是配置低的機器)上,首次請求需要的時間可能就會大於1秒。
1.2 解決方案
有很多方式解決該問題,下面列舉幾種比較簡單的方案:
1) 方法一:為Ribbon配置飢餓載入。
ribbon: eager-load: enabled: true clients: client1,client2
對於Zuul:
zuul: ribbon: eager-load: enabled: true
2) 方法二:延長 Hystrix 的超時時間,示例如下
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds:5000
該配置讓 Hystrix 的超時時間改為5秒。
3) 方法三:禁用 Hystrix 的超時,示例如下
hystrix.command.default.execution.timeout.enabled: false
方法四:對於 Feign , 還可以為 Feign 禁用 Hystrix , 示例如下
feign.hystrix.enabled: false
這樣即可為 Feign 全域性禁用 Hystrix 支援。但該方式比較極端,一般不建議使用。
二、Turbine 聚合資料不完整
在某些版本的Spring Cloud (例如 Brixton SR5)中,Turbine 會發生該問題。該問題的直接觀體現是:
使用 Turbine 聚合多個微服務,但在 Hystrix Dashboard 上只能看到部分微服務的監控資料。
現象描述:
比如 Turbine 配置如下:
Turbine 理應聚合 cloud-consumer-movie,cloud-consumer-movie-feign-hystrix-fallback-stream 這兩個微服務的監控資料,然而開啟 Hystrix Dashboard 時,會發現Dashboard 上只顯示部分微服務的監控資料。
解決方案:
當 Turbine 聚合的微服務部署在同一臺主機上時,就會出現該問題。
解決方案一:
為各個微服務配置不同的 hostname ,並將 preferIpAddress 設為 false 或者不設定。
eureka: client: serviceUrl: defaultZone: instance: hostname:ribbon # 配置hostname
解決方案二:
設定turbine.combine-host-port = true
turbine: appConfig: cloud-consumer-movie,cloud-consumer-movie-feign-hystrix-fallback-stream clusterNameExpression:"'default'" combine-host-port:true
方法三:
升級 Spring Cloud 到 Camden 或更新版本。當然,也可單獨升級 Spring Cloud Netflix 到 1.2.0以上最新穩定版(一般不建議單獨升級 Spring Cloud Netflix, 因為可能會跟 Spring Cloud 其他元件衝突)。
這是因為老版本中的 turbine.combine-host-port 預設值是 false 。Spring Cloud 已經意識到該問題,故在新的版本中將該屬性的預設值設為 true 。該解決方案和方法二本質是一致的。
相關程式碼
org.springframework.cloud.netflix.turbine.TurbineProperties.combine-HostPort org.springframework.cloud.netflix.turbine.CommonsInstanceDiscovery.getInstance(String, String, String, Boolean)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69952307/viewspace-2672836/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SpringCloud分散式微服務b2b2c電子商務分散式微服務-docker-feign-hystrix(七)SpringGCCloud分散式微服務Docker
- SpringCloud分散式微服務b2b2c電子商務docker-feign-hystrix-ribbon(八)SpringGCCloud分散式微服務Docker
- SpringCloud分散式微服務b2b2c電子商務-hystrix引數詳解(十)SpringGCCloud分散式微服務
- SpringCloud分散式微服務b2b2c電子商務-SpringBoot 整合JPA(四)GCCloud分散式微服務Spring Boot
- SpringCloud分散式微服務b2b2c電子商務(十三)Springboot整合RabbitMQGCCloud分散式微服務Spring BootMQ
- SpringCloud分散式微服務b2b2c電子商務(五)springboot整合 beatlsqlGCCloud分散式微服務Spring BootTLSSQL
- java b2b2c電子商務 springcloud分散式微服務-Session共享JavaSpringGCCloud分散式微服務Session
- SpringCloud分散式微服務b2b2c電子商務(一)元件和概念介紹SpringGCCloud分散式微服務元件
- SpringCloud分散式微服務b2b2c電子商務-定時任務(Scheduling Tasks)SpringGCCloud分散式微服務
- Springcloud分散式微服務b2b2c電子商務一Spring Cloud常見問題(一)SpringGCCloud分散式微服務
- JAVA b2b2c電子商務SpringCloud分散式微服務spring-security-基本JavaSpringGCCloud分散式微服務
- SpringCloud分散式微服務b2b2c電子商務-Gateway的基本入門SpringGCCloud分散式微服務Gateway
- SpringCloud分散式微服務b2b2c電子商務docker-feign配置(六)SpringGCCloud分散式微服務Docker
- SpringCloud分散式微服務b2b2c電子商務(二)Eureka(服務註冊和服務發現基礎篇)SpringGCCloud分散式微服務
- SpringCloud分散式微服務b2b2c電子商務(三)註冊中心叢集篇SpringGCCloud分散式微服務
- SpringCloud分散式微服務b2b2c電子商務-Spring Boot配置檔案詳解GCCloud分散式微服務Spring Boot
- SpringCloud分散式微服務b2b2c電子商務-docker部署spring cloud專案(十一)SpringGCCloud分散式微服務Docker
- Java b2b2c電子商務 SpringCloud分散式微服務-config的簡單配置shh方式JavaSpringGCCloud分散式微服務
- (十四)JAVA springboot微服務b2b2c電子商務系統- Spring Cloud構建分散式電子商務平臺JavaSpring Boot微服務Cloud分散式
- 電子商務Java微服務 SpringBoot整合SpringSecurityJava微服務Spring BootGse
- SpringCloud分散式微服務b2b2c電子商務-Spring Cloud自定義引導屬性源SpringGCCloud分散式微服務
- JAVA spring cloud boot b2b2c電子商務分散式微服務JavaSpringCloudboot分散式微服務
- SpringCloud分散式微服務b2b2c電子商務(十二)在springboot中用redis實現訊息佇列GCCloud分散式微服務Spring BootRedis佇列
- java B2B2C Springcloud電子商務平臺原始碼------Hystrix的快取使用JavaSpringGCCloud原始碼快取
- (一)springcloud微服務分散式雲架構-SpringCloud簡介SpringGCCloud微服務分散式架構
- (三)springcloud微服務分散式雲架構-SpringCloud整合專案簡介SpringGCCloud微服務分散式架構
- 關於SpringCloud微服務雲架構構建B2B2C電子商務平臺之-(SpringGCCloud微服務架構
- SpringCloud微服務整合DubboSpringGCCloud微服務
- springcloud微服務分散式雲架構-SpringCloud簡介SpringGCCloud微服務分散式架構
- JAVA springboot微服務b2b2c電子商務系統-(七)高可用的分散式配置中心(Spring Cloud Config)JavaSpring Boot微服務分散式Cloud
- SpringCloud微服務雲架構構建B2B2C電子商務平臺分析之-服務消費(Ribbon)SpringGCCloud微服務架構
- java版 電子商務Springcloud分散式微服務多使用者商城系統-Springboot專案打包JavaGCCloud分散式微服務Spring Boot
- 分散式微服務雲架構構建電子商務平臺分散式微服務架構
- java B2B2C Springcloud電子商務平臺原始碼JavaSpringGCCloud原始碼
- JAVA springboot微服務b2b2c電子商務系統(二)服務消費者(rest+ribbon)JavaSpring Boot微服務REST
- SpringCloud微服務系列- 分散式能力建設之微服務閘道器SpringGCCloud微服務分散式
- SpringCloud構建微服務架構-Hystrix服務降級SpringGCCloud微服務架構
- springcloud微服務分散式雲架構簡介SpringGCCloud微服務分散式架構