您好,登錄后才能下訂單哦!
這篇文章主要講解了“怎么解決RestTemplate未使用線程池的問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么解決RestTemplate未使用線程池的問題”吧!
現場出現springboot服務卡死,無法打開頁面現象。
初步分析為服務中使用RestTemplate通信框架,但未使用連接池,如果通信拋出異常(連接失敗),連續運行一定時間,導致線程飆升,資源耗盡,服務程序宕機。
模擬無法通信的微服務地址,修改連接2s/次,啟動三個微服務demo進行通信,連續測試2小時,現象可再現:
詳細如下圖:
啟動時線程數:
連接異常提示:
線程飆升:
大量未關閉線程:
線程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默認情況下不使用連接池,每次調用都會打開一個新的本地臨時端口和一個新連接,如果通信異常,會導致連接不被回收,持續通信,它會不斷新建線程,并且很快突破本地可用端口限制范圍,導致服務卡死。
使用RestTemplate連接池,設置ReadTimeout、ConnectTimeout超時時間,進行連接回收。
修改后,驗證如下:
初始線程:
測試3小時結束時線程:
線程池線程未增加,狀態交替
感謝各位的閱讀,以上就是“怎么解決RestTemplate未使用線程池的問題”的內容了,經過本文的學習后,相信大家對怎么解決RestTemplate未使用線程池的問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。