socketinputstream专题

java.net.SocketInputStream.socketRead0 卡死导致 tomcat 线程池打满的问题

0 TL;DR; 问题与原因:某些特定条件下 java.net.SocketInputStream.socketRead0 方法会卡死,导致运行线程一直被占用导致泄露采用的方案:使用监控线程异步监控卡死事件,如果发生直接关闭网络连接释放链接以及对应的线程 1. 问题 一个服务 tomcat 线程池线程总是不释放,之前只能靠重启服务缓解 (这个服务的作用是对第三方网站做一个类似于适配器模式的封

SocketInputStream.socketRead0引起线程池提交任务后,futureTask.get超时

文章目录 1. 现象2. 结论3. 相关代码4. 查看堆栈:5. 查看submitCall5.1 ThreadPoolExecutor#execute最终调用了 RunnableFuture#run方法5.2 从代码层面判断 futureTask.get超时只影响了业务线程(调用futureTask.get的线程),不影响工作线程。5.3 future.get5.3.1 测试future.g