接著上一篇文章,針 對(duì)Spring Cloud的常用問題再次做一些總結(jié)
創(chuàng)新互聯(lián)公司主營息烽網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,重慶APP開發(fā),息烽h5成都小程序開發(fā)搭建,息烽網(wǎng)站營銷推廣歡迎息烽等地區(qū)企業(yè)咨詢
一、整合Hystrix后首次請(qǐng)求失敗
1.1 原因分析
Hystrix 默認(rèn)的超時(shí)時(shí)間是1秒,如果在1秒內(nèi)得不到響應(yīng),就會(huì)進(jìn)入 fallback 邏輯。
了解springcloud架構(gòu)可以加求求:三五三六二四七二五九,由于 Spring 的懶加載機(jī)制,
首次請(qǐng)求往往會(huì)比較慢,因此在某些機(jī)器(特別是配置低的機(jī)器)上,首次請(qǐng)求需要的時(shí)間可能就會(huì)大于1秒。
1.2 解決方案
有很多方式解決該問題,下面列舉幾種比較簡單的方案:
1) 方法一:為Ribbon配置饑餓加載。
ribbon: eager-load: enabled: true clients: client1,client2
對(duì)于Zuul:
zuul: ribbon: eager-load: enabled: true
2) 方法二:延長 Hystrix 的超時(shí)時(shí)間,示例如下
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds:5000
該配置讓 Hystrix 的超時(shí)時(shí)間改為5秒。
3) 方法三:禁用 Hystrix 的超時(shí),示例如下
hystrix.command.default.execution.timeout.enabled: false
方法四:對(duì)于 Feign , 還可以為 Feign 禁用 Hystrix , 示例如下
feign.hystrix.enabled: false
這樣即可為 Feign 全局禁用 Hystrix 支持。但該方式比較極端,一般不建議使用。
二、Turbine 聚合數(shù)據(jù)不完整
在某些版本的Spring Cloud (例如 Brixton SR5)中,Turbine 會(huì)發(fā)生該問題。該問題的直接觀體現(xiàn)是:
使用 Turbine 聚合多個(gè)微服務(wù),但在 Hystrix Dashboard 上只能看到部分微服務(wù)的監(jiān)控?cái)?shù)據(jù)。
現(xiàn)象描述:
比如 Turbine 配置如下:
Turbine 理應(yīng)聚合 cloud-consumer-movie,cloud-consumer-movie-feign-hystrix-fallback-stream 這兩個(gè)微服務(wù)的監(jiān)控?cái)?shù)據(jù),然而打開 Hystrix Dashboard 時(shí),會(huì)發(fā)現(xiàn)Dashboard 上只顯示部分微服務(wù)的監(jiān)控?cái)?shù)據(jù)。
解決方案:
當(dāng) Turbine 聚合的微服務(wù)部署在同一臺(tái)主機(jī)上時(shí),就會(huì)出現(xiàn)該問題。
解決方案一:
為各個(gè)微服務(wù)配置不同的 hostname ,并將 preferIpAddress 設(shè)為 false 或者不設(shè)置。
eureka: client: serviceUrl: defaultZone:http://127.0.0.1:8001/eureka/ instance: hostname:ribbon # 配置hostname
解決方案二:
設(shè)置turbine.combine-host-port = true
turbine: appConfig: cloud-consumer-movie,cloud-consumer-movie-feign-hystrix-fallback-stream clusterNameExpression:"'default'" combine-host-port:true
方法三:
升級(jí) Spring Cloud 到 Camden 或更新版本。當(dāng)然,也可單獨(dú)升級(jí) Spring Cloud Netflix 到 1.2.0以上最新穩(wěn)定版(一般不建議單獨(dú)升級(jí) Spring Cloud Netflix, 因?yàn)榭赡軙?huì)跟 Spring Cloud 其他組件沖突)。
這是因?yàn)槔习姹局械?turbine.combine-host-port 默認(rèn)值是 false 。Spring Cloud 已經(jīng)意識(shí)到該問題,故在新的版本中將該屬性的默認(rèn)值設(shè)為 true 。該解決方案和方法二本質(zhì)是一致的。
相關(guān)代碼
org.springframework.cloud.netflix.turbine.TurbineProperties.combine-HostPort org.springframework.cloud.netflix.turbine.CommonsInstanceDiscovery.getInstance(String, String, String, Boolean)