您好,登錄后才能下訂單哦!
概述
在一條慢SQL導致購物車服務無法使用的解決方案一文中,提到了客戶端調用購物車服務的時候,超時了。如果當時客戶端沒有設置超時時間的話,會在客戶端中產生級聯故障。先用一張圖來說明一下。
聚合層除了調用購物車微服務,還調用了營銷系統微服務。如果購物車服務的接口響應時間很慢,而客戶端聚合層調用購物車服務時,又沒有設置超時時間,那么將占有大量的連接,如果請求購物車服務的請求量比較大,瞬間就會把連接占用完,直接導致聚合層調用營銷系統時,需要阻塞住等待獲取連接,這樣的話,整個小程序的很多功能就都用不了了。
從這里我們可以看到,最終小程序端會整體響應很慢,因為它調用了聚合層,而聚合層又調用了一個性能很差的購物車服務。產生級聯故障了,小程序端和聚合層都在等待中耗盡了資源,這個是非常可怕的事情。
設置超時時間
聚合層是使用了Spring Cloud Ribbon
,我們可以設置一下Ribbon
的超時時間。具體的可以參看SpringCloud Edgware.SR3版本中Ribbon的timeout設置方法
ribbon:
ReadTimeout: 2000
ConnectTimeout: 2000
這樣的話,聚合層調用購物車服務,如果兩秒鐘沒有返回結果,則超時報錯。這樣做有兩個好處。
知識擴展
客戶端保持彈性真心很重要,因此像客戶端中的
都是需要了解的。要做一個彈性客戶端,可以借助一些工具,像Netflix
的Hystrix
組件就非常不錯,并且已經被Spring Cloud
集成進去了,使用起來也比較簡單。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。