阿里dubbo出錯提示Thread pool is EXHAUSTED問題及解決方法
同事反饋,系統(tǒng)使用過程出個別時候會出現(xiàn)錯誤,系統(tǒng)使用srpingMvc+spring+mybatis+dubbo的微服務(wù)架構(gòu)。檢查日志看到如下異常信息:
Caused by: java.util.concurrent.RejectedExecutionException: Thread pool is EXHAUSTED! Thread Name: DubboServerHandler-10.8.64.57:20880, Pool Size: 200 (active: 200, core: 200, max: 200, largest: 200), Task: 5823
通過字面大致意思是,dubbo線程池資源消耗完了。最近也沒有大的系統(tǒng)升級,目前服務(wù)端采用的是默認設(shè)置,dubbo.xml修改前配置。

<dubbo:protocol name="dubbo" port="20881" />
修改后
<dubbo:protocol name="dubbo" port="20881" threadpool="fixed" threads="500" />
觀察幾分鐘,查看日志,比之前會少一些報錯,異常還是存在。使用java的jstack命令導出日志再次進行分析。
at java.net.SocketInputStream.socketRead0(Native Method) at java.net.SocketInputStream.socketRead(SocketInputStream.java:116) at java.net.SocketInputStream.read(SocketInputStream.java:171) at java.net.SocketInputStream.read(SocketInputStream.java:141) at java.net.SocketInputStream.read(SocketInputStream.java:127) at redis.clients.util.RedisInputStream.ensureFill(RedisInputStream.java:196) at redis.clients.util.RedisInputStream.readByte(RedisInputStream.java:40) at redis.clients.jedis.Protocol.process(Protocol.java:151) at redis.clients.jedis.Protocol.read(Protocol.java:215) at redis.clients.jedis.Connection.readProtocolWithCheckingBroken(Connection.java:340) at redis.clients.jedis.Connection.getIntegerReply(Connection.java:265) at redis.clients.jedis.Jedis.exists(Jedis.java:179)
發(fā)現(xiàn)該段代碼既然有400多個,綜合分析后問題基本上確認,是由于服務(wù)端使用redis訪問超時導致dubbo請求時間響應(yīng)過長,客戶端請求過多導致線程數(shù)量增加。
繼續(xù)定位異常代碼,發(fā)現(xiàn)消費端有一個對外服務(wù)訪問量過多,優(yōu)化代碼升級后問題解決。
總結(jié)
到此這篇關(guān)于阿里dubbo出錯提示Thread pool is EXHAUSTED 解決的文章就介紹到這了,更多相關(guān)阿里dubbo出錯提示Thread pool is EXHAUSTED內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot中添加監(jiān)聽器及創(chuàng)建線程的代碼示例
這篇文章主要介紹了SpringBoot中如何添加監(jiān)聽器及創(chuàng)建線程,文中有詳細的代碼示例,具有一定的參考價值,需要的朋友可以參考下2023-06-06
詳解Spring中使用@within與@target的區(qū)別
這篇文章主要介紹了Spring中使用@within與@target的一些區(qū)別,本文通過項目案例給大家詳細分析,給大家介紹的非常詳細,代碼簡單易懂,需要的朋友可以參考下2021-09-09
Java中YYYY-MM-dd與yyyy-MM-dd的區(qū)別及跨年問題
YYYY-MM-dd可能會導致跨年周的日期被歸屬到錯誤的年份, yyyy-MM-dd總是表示實際的日歷年份,無論日期所在的周是否跨年,本文就來介紹一下兩者的區(qū)別,感興趣的可以了解一下2024-01-01

