AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

微服務(wù)循環(huán)依賴引發(fā)慘案,有坑!

來源: 責編: 時間:2024-07-12 17:26:14 744觀看
導讀最近的迭代轉(zhuǎn)測后遇到了一個比較有意思的問題。在測試環(huán)境整體運行還算平穩(wěn),但是過一段時間之后,就開始有接口超時了,日志中出現(xiàn)非常多的 “java.net.SocketTimeoutException: Read timed out”。試了幾次重啟大法,每次都

最近的迭代轉(zhuǎn)測后遇到了一個比較有意思的問題。在測試環(huán)境整體運行還算平穩(wěn),但是過一段時間之后,就開始有接口超時了,日志中出現(xiàn)非常多的 “java.net.SocketTimeoutException: Read timed out”。試了幾次重啟大法,每次都是只能堅持一會之后,再次出現(xiàn) SocketTimeoutException。rUt28資訊網(wǎng)——每日最新資訊28at.com

注意:在測試環(huán)境于遇到問題重啟服務(wù),并不是一個好的實踐,因為重啟可能會讓不容易出現(xiàn)的問題現(xiàn)場被破壞。如果問題在測試環(huán)境不能再重新,卻在發(fā)版后出現(xiàn)在生產(chǎn)環(huán)境的話,那不僅會造成生產(chǎn)運維事件,還要在巨大的壓力下去解決問題。rUt28資訊網(wǎng)——每日最新資訊28at.com

初步分析

順著測試匯報的出現(xiàn)問題的場景,跟蹤調(diào)用鏈上相關(guān)服務(wù)的日志,發(fā)現(xiàn)出現(xiàn)了微服務(wù)之間循依賴調(diào)用。大致情況可以抽象如下所示(圖中所有調(diào)用都是 http 協(xié)議):rUt28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片rUt28資訊網(wǎng)——每日最新資訊28at.com

  • Client 調(diào)用服務(wù) Foo.hello()
  • Foo.hello() 邏輯中會調(diào)用服務(wù) Boo.boo()
  • Boo.boo() 又調(diào)用回服務(wù) Foo 的另外一個方法 another()

當然真實的場景要比較這個復雜,調(diào)用鏈更長,不過最終形成了環(huán)形依賴調(diào)用。至于這個環(huán)形依賴為什么回導致超時,當時想了多種可能,比如數(shù)據(jù)庫慢查詢、數(shù)據(jù)庫鎖、分布式鎖等等。但是整個調(diào)用鏈上都是查詢請求,而且查詢相關(guān)的數(shù)據(jù)量也非常小,不會有鎖存在。發(fā)生問題的時候也沒有與查詢數(shù)據(jù)相關(guān)的數(shù)據(jù)庫寫請求。rUt28資訊網(wǎng)——每日最新資訊28at.com

鑒于這個環(huán)形依賴調(diào)用確實是這個迭代版本中引入的變更,以及雖然沒有理清其中的因果關(guān)系原理,但是這個環(huán)性依賴調(diào)用還是很可疑的,而且是不必要的環(huán)形調(diào)用。就抱著將環(huán)形依賴調(diào)用去掉試試看的態(tài)度,做了修復。修復完后,SocketTimeoutException 不再出現(xiàn)了。問題解決了。rUt28資訊網(wǎng)——每日最新資訊28at.com

探尋原因

問題雖然不再出現(xiàn),但是憑運氣解決的問題,通常有可能不是真的的解決。只有弄清楚背后的原理,我們才能真正的確認問題是不是這個原因?qū)е碌?,這樣的修復是不是真的把問題解決了。rUt28資訊網(wǎng)——每日最新資訊28at.com

通過假設(shè)環(huán)形調(diào)用就是導致調(diào)用超時的直接原因。我們看看能不能推出因果關(guān)系。通過把Foo 服務(wù)容器畫的更詳細一點,如下圖:rUt28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片rUt28資訊網(wǎng)——每日最新資訊28at.com

通過這個圖示,我們可以發(fā)現(xiàn),如果容器中接收請求的線程池如果都在等待服務(wù)Boo.boo() 的響應(yīng),而 Boo 又需要調(diào)用回服務(wù) Foo.another()。這個時候,如果所有的線程都處于這樣的狀態(tài),我們就會發(fā)現(xiàn)服務(wù) Foo 容器中以及沒有線程來處理 Boo 的請求了。關(guān)注公眾號:碼猿技術(shù)專欄,回復關(guān)鍵詞:1111 獲取阿里內(nèi)部的Java性能調(diào)優(yōu)手冊!某種程度上來說就是死鎖了。到這里,我們就可以很確定了,這個環(huán)形依賴調(diào)用就是導致出現(xiàn)調(diào)用超時的罪魁禍首。當 client 發(fā)起的請求速度大于這個環(huán)形調(diào)用鏈的處理速度的時候,慢慢的就會導致服務(wù) Foo 的所有線程都進入這種死鎖狀態(tài)。rUt28資訊網(wǎng)——每日最新資訊28at.com

驗證

這里只列出關(guān)鍵的代碼,具體的代碼可以參考 gitee 工程:https://gitee.com/donghbcn/CircularDependencyrUt28資訊網(wǎng)——每日最新資訊28at.com

Eureka 服務(wù)器

建個簡單工程將Eureka server啟動起來。rUt28資訊網(wǎng)——每日最新資訊28at.com

服務(wù) Foo

創(chuàng)建 SpringBoot 工程實現(xiàn) Foo 服務(wù)。Foo 通過 FeignClient 調(diào)用 Boo 服務(wù)。設(shè)置缺省的容器 Tomcat 的最大線程數(shù)為 16,Tomcat 默認配置最大線程數(shù) 200,對于驗證這個場景有點了大了,要看到效果需要等的時間有點長。rUt28資訊網(wǎng)——每日最新資訊28at.com

application.properties

spring.application.name=demo-fooserver.port=8000eureka.client.serviceUrl.defaultZnotallow=http://localhost:8080/eurekaserver.tomcat.threads.max=16
package com.cd.demofoo;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;@RestControllerpublic class FooController {    @Autowired    BooFeignClient booFeignClient;    @RequestMapping("/hello")    public String hello(){        long start = System.currentTimeMillis();        System.out.println("[" + Thread.currentThread() +                "] foo:hello called, call boo:boo now");        booFeignClient.boo();        System.out.println("[" + Thread.currentThread() +                "] foo:hello called, call boo:boo, total cost:" +                (System.currentTimeMillis() - start));        return "hello world";    }    @RequestMapping("/another")    public String another(){        long start = System.currentTimeMillis();        try {            //通過 slepp 模擬一個耗時調(diào)用            Thread.sleep(100);        } catch (InterruptedException e) {            e.printStackTrace();        }        System.out.println("foo:another called, total cost:" + (System.currentTimeMillis() - start));        return "another";    }}

服務(wù) Boo

創(chuàng)建 SpringBoot 工程實現(xiàn) Boo 服務(wù)。Boo 通過 FeignClient 調(diào)用 Foo 服務(wù)。rUt28資訊網(wǎng)——每日最新資訊28at.com

package com.cd.demoboo;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;@RestControllerpublic class BooController {    @Autowired    FooFeignClient fooFeignClient;    @RequestMapping("/boo")    public String boo(){        long start = System.currentTimeMillis();        fooFeignClient.another();        System.out.println("boo:boo called, call foo:another, total cost:" +                        (System.currentTimeMillis() - start));        return "boo";    }}

Jmeter

采用 Jmeter 來模擬并發(fā) Client 調(diào)用。配置了30 個 線程,無限循環(huán)。rUt28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片rUt28資訊網(wǎng)——每日最新資訊28at.com

很快服務(wù) Foo 日志就卡死了。過一會 Boo 的日志開始出現(xiàn) SocketTimeoutException,如下圖:rUt28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片rUt28資訊網(wǎng)——每日最新資訊28at.com

jstack

通過 jstack 我們可以看到 Foo 進程的所有線程都卡在 hello() 調(diào)用上了。rUt28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片rUt28資訊網(wǎng)——每日最新資訊28at.com

總結(jié)

微服務(wù)之間的環(huán)形依賴類似于類之間的循環(huán)依賴,當依賴關(guān)系形成了環(huán),會造成比較嚴重的問題:rUt28資訊網(wǎng)——每日最新資訊28at.com

  • 微服務(wù)直接不能形成環(huán)形調(diào)用,否則非常容易出現(xiàn)死鎖狀態(tài)。
  • 微服務(wù)之間的耦合性非常強,這嚴重違反了微服務(wù)的初衷;這種情況往往是服務(wù)之間的調(diào)用沒有約束導致的,為了方便取到或更新數(shù)據(jù),服務(wù)之間可以隨意的調(diào)用,以”微服務(wù)“為設(shè)計目標的系統(tǒng)會逐漸演變成一個分布式大單體。


rUt28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-100734-0.html微服務(wù)循環(huán)依賴引發(fā)慘案,有坑!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Vue3中使用@作為引用根目錄報錯,該如何解決?

下一篇: Redis高性能架構(gòu)詳解(圖文全面總結(jié))

標簽:
  • 熱門焦點
  • Redmi Buds 4開箱簡評:才199還有降噪 可以無腦入

    在上個月舉辦的Redmi Note11T Pro系列新機發(fā)布會上,除了兩款手機新品之外,Redmi還帶來了兩款TWS真無線藍牙耳機產(chǎn)品,Redmi Buds 4和Redmi Buds 4 Pro,此前我們在Redmi Note11T
  • CSS單標簽實現(xiàn)轉(zhuǎn)轉(zhuǎn)logo

    轉(zhuǎn)轉(zhuǎn)品牌升級后更新了全新的Logo,今天我們用純CSS來實現(xiàn)轉(zhuǎn)轉(zhuǎn)的新Logo,為了有一定的挑戰(zhàn)性,這里我們只使用一個標簽實現(xiàn),將最大化的使用CSS能力完成Logo的繪制與動畫效果。新logo
  • 三言兩語說透設(shè)計模式的藝術(shù)-單例模式

    寫在前面單例模式是一種常用的軟件設(shè)計模式,它所創(chuàng)建的對象只有一個實例,且該實例易于被外界訪問。單例對象由于只有一個實例,所以它可以方便地被系統(tǒng)中的其他對象共享,從而減少
  • 共享單車的故事講到哪了?

    來源丨海克財經(jīng)與共享充電寶相差不多,共享單車已很久沒有被國內(nèi)熱點新聞關(guān)照到了。除了一再漲價和用戶直呼用不起了。近日多家媒體再發(fā)報道稱,成都、天津、鄭州等地多個共享單
  • 重估百度丨大模型,能撐起百度的“今天”嗎?

    自象限原創(chuàng) 作者|程心 羅輯2023年之前,對于自己的“今天”,百度也很迷茫。“新業(yè)務(wù)到 2022 年底還是 0,希望 2023 年出來一個 1。”這是2022年底,李彥宏
  • 華為Mate 60系列用上可變靈動島:正式版體驗將會更出色

    這段時間以來,關(guān)于華為新旗艦的爆料日漸密集。據(jù)此前多方爆料,今年華為將開始恢復一年雙旗艦戰(zhàn)略,除上半年推出的P60系列外,往年下半年的Mate系列也將
  • 華為Mate60標準版細節(jié)曝光:經(jīng)典星環(huán)相機模組回歸

    這段時間以來,關(guān)于華為新旗艦的爆料日漸密集。據(jù)此前多方爆料,今年華為將開始恢復一年雙旗艦戰(zhàn)略,除上半年推出的P60系列外,往年下半年的Mate系列也將
  • iQOO Neo8 Pro真機諜照曝光:天璣9200+和V1+旗艦雙芯加持

    去年10月,iQOO推出了iQOO Neo7系列機型,不僅搭載了天璣9000+,而且是同價位唯一一款天璣9000+直屏旗艦,一經(jīng)上市便受到了用戶的廣泛關(guān)注。在時隔半年后,
  • 蘋果MacBook Pro 2021測試:仍不支持平滑滾動

    據(jù)10月30日9to5 Mac 消息報道,蘋果新的 14 英寸和 16 英寸 MacBook Pro 2021 上市后獲得了不錯的評價,亮點包括行業(yè)領(lǐng)先的性能,令人印象深刻的電池續(xù)航,精美豐
Top