欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

RestTemplate未使用線程池問題的解決方法

 更新時間:2021年06月22日 14:19:29   作者:zetor_major  
今天給大家?guī)淼氖顷P(guān)于Springboot的相關(guān)知識,文章圍繞著RestTemplate未使用線程池展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下

一、問題描述

現(xiàn)場出現(xiàn)springboot服務(wù)卡死,無法打開頁面現(xiàn)象。

初步分析為服務(wù)中使用RestTemplate通信框架,但未使用連接池,如果通信拋出異常(連接失?。?,連續(xù)運行一定時間,導(dǎo)致線程飆升,資源耗盡,服務(wù)程序宕機。

二、問題再現(xiàn)

模擬無法通信的微服務(wù)地址,修改連接2s/次,啟動三個微服務(wù)demo進行通信,連續(xù)測試2小時,現(xiàn)象可再現(xiàn):

詳細如下圖:

啟動時線程數(shù):

連接異常提示:

線程飆升:

大量未關(guān)閉線程:

線程dump信息:

"http-nio-8081-exec-120" #216 daemon prio=5 os_prio=0 tid=0x000000002b0f9800 nid=0x4a28 runnable [0x0000000030349000]
   java.lang.Thread.State: RUNNABLE
       at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
    …
       at org.springframework.http.client.AbstractClientHttpRequest.execute(AbstractClientHttpRequest.java:53)
        at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:737)
        at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:672)
        at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.java:313)

三、問題分析:

主動健康檢查時,RestTemplate默認(rèn)情況下不使用連接池,每次調(diào)用都會打開一個新的本地臨時端口和一個新連接,如果通信異常,會導(dǎo)致連接不被回收,持續(xù)通信,它會不斷新建線程,并且很快突破本地可用端口限制范圍,導(dǎo)致服務(wù)卡死。

四、解決方案:

使用RestTemplate連接池,設(shè)置ReadTimeout、ConnectTimeout超時時間,進行連接回收。

五、回歸驗證:

修改后,驗證如下:

初始線程:

測試3小時結(jié)束時線程:

線程池線程未增加,狀態(tài)交替

到此這篇關(guān)于RestTemplate未使用線程池問題的解決方法的文章就介紹到這了,更多相關(guān)RestTemplate未使用線程池內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論