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)文章
Java?CompletableFuture實現(xiàn)原理分析詳解
CompletableFuture是Java8并發(fā)新特性,本文我們主要來聊一聊CompletableFuture的回調(diào)功能以及異步工作原理是如何實現(xiàn)的,需要的可以了解一下2022-09-09Java 5個人坐在一起(有關(guān)第五個人歲數(shù)的問題)
利用遞歸的方法,遞歸分為回推和遞推兩個階段。要想知道第五個人歲數(shù),需知道第四人的歲數(shù),依次類推,推到第一人(10歲),再往回推,需要的朋友可以參考下2017-02-02Java生成10個1000以內(nèi)的隨機數(shù)并用消息框顯示數(shù)組內(nèi)容然后求和輸出
這篇文章主要介紹了Java生成10個1000以內(nèi)的隨機數(shù)并用消息框顯示數(shù)組內(nèi)容然后求和輸出,需要的朋友可以參考下2015-10-10Java中獲取?List中最后一個元素3種方法以及實際應(yīng)用
這篇文章主要給大家介紹了關(guān)于Java中獲取?List中最后一個元素3種方法以及實際應(yīng)用的相關(guān)資料,由于List的索引是從0開始的,所以最后一個元素的索引是List的大小減1,需要的朋友可以參考下2023-11-11