阿里dubbo出错提示Thread pool is EXHAUSTED 解决

系统在使用SpringMvc+Spring+Mybatis+Dubbo架构时遇到Thread pool is EXHAUSTED异常。分析发现,由于服务端Redis访问超时,导致Dubbo请求响应时间增长,客户端频繁请求引发线程数增加。通过调整dubbo.xml配置、使用jstack分析日志,并定位到服务端一处代码问题,最终优化对外服务访问,解决了线程池耗尽的问题。
摘要由CSDN通过智能技术生成

同事反馈,系统使用过程出个别时候会出现错误,系统使用srpingMvc+spring+mybatis+dubbo的微服务架构。检查日志看到如下异常信息:

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线程池资源消耗完了。最近也没有大的系统升级,目前服务端采用的是默认设置,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.n
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值