JAVA 多线程解决高并发、超时线程池耗尽问题

2023-05-16

第一类

问题:项目中遇到了,创建20个固定线程的线程池,在测试环境,多线程如果高并发的调用都没出现问题,但是在实际的项目中,出现了线程池内线程超时等待并将池内的线程耗尽,导致其它的程序走到多线程调用时候出现了执行慢、线程无法执行问题。

问题原因:通过分析定位发现,是由于多线程内的程序在有些条件下,线程内的程序执行周期大于多线程调用的周期,导致线程池内的现场全部被占用。

解决方法:线程执行时候开启线程执行的超时功能。

第二类

执行到这里本应该感觉没有问题了,但是在实际的环境中发现线程执行过程中还是存在被耗尽的问题,百思不得期解。痛定思痛,查看对应的文档,并查看原代码发现问题。

问题核心:线程池在执行的时候,正常执行结束后线程是可以结束的,但是超时时候现场会返回报错信息,报错了现场内部并未触发了中断,导致线程一直被占用,未释放导致。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

JAVA 多线程解决高并发、超时线程池耗尽问题 的相关文章

随机推荐