阿里dubbo出錯(cuò)提示Thread pool is EXHAUSTED問(wèn)題及解決方法
同事反饋,系統(tǒng)使用過(guò)程出個(gè)別時(shí)候會(huì)出現(xiàn)錯(cuò)誤,系統(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
通過(guò)字面大致意思是,dubbo線程池資源消耗完了。最近也沒(méi)有大的系統(tǒng)升級(jí),目前服務(wù)端采用的是默認(rèn)設(shè)置,dubbo.xml修改前配置。
<dubbo:protocol name="dubbo" port="20881" />
修改后
<dubbo:protocol name="dubbo" port="20881" threadpool="fixed" threads="500" />
觀察幾分鐘,查看日志,比之前會(huì)少一些報(bào)錯(cuò),異常還是存在。使用java的jstack命令導(dǎo)出日志再次進(jìn)行分析。
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多個(gè),綜合分析后問(wèn)題基本上確認(rèn),是由于服務(wù)端使用redis訪問(wèn)超時(shí)導(dǎo)致dubbo請(qǐng)求時(shí)間響應(yīng)過(guò)長(zhǎng),客戶端請(qǐng)求過(guò)多導(dǎo)致線程數(shù)量增加。
繼續(xù)定位異常代碼,發(fā)現(xiàn)消費(fèi)端有一個(gè)對(duì)外服務(wù)訪問(wèn)量過(guò)多,優(yōu)化代碼升級(jí)后問(wèn)題解決。
總結(jié)
到此這篇關(guān)于阿里dubbo出錯(cuò)提示Thread pool is EXHAUSTED 解決的文章就介紹到這了,更多相關(guān)阿里dubbo出錯(cuò)提示Thread pool is EXHAUSTED內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決mybatis plus 一對(duì)多分頁(yè)查詢問(wèn)題
這篇文章主要介紹了解決mybatis plus 一對(duì)多分頁(yè)查詢問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11swagger2隱藏在API文檔顯示某些參數(shù)的操作
這篇文章主要介紹了swagger2隱藏在API文檔顯示某些參數(shù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06IntelliJ IDEA多屏后窗口不顯示問(wèn)題解決方案
這篇文章主要介紹了IntelliJ IDEA多屏后窗口不顯示問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09SpringBoot中使用Filter和Interceptor的示例代碼
這篇文章主要介紹了SpringBoot中使用Filter和Interceptor的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06SpringBoot3使用Jasypt實(shí)現(xiàn)配置文件信息加密的方法
對(duì)于一些單體項(xiàng)目而言,在沒(méi)有使用SpringCloud的情況下,配置文件中包含著大量的敏感信息,如果這些信息泄露出去將會(huì)對(duì)企業(yè)的資產(chǎn)產(chǎn)生重大威脅,因此,對(duì)配置文件中的敏感信息加密是一件極其必要的事,所以本文介紹了SpringBoot3使用Jasypt實(shí)現(xiàn)配置文件信息加密的方法2024-07-07mybatis自定義參數(shù)類型轉(zhuǎn)換器數(shù)據(jù)庫(kù)字段加密脫敏
這篇文章主要為大家介紹了mybatis自定義參數(shù)類型轉(zhuǎn)換器數(shù)據(jù)庫(kù)字段加密脫敏,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09