线程处于RUNNABLE java.net.PlainDatagramSocketImpl.receive0

zytry 2012-03-31 04:53:05
java通过线程池管理特功能的线程(每个线程都有socket通信。)。但在某linux环境下,线程中的socket通讯貌似无法正常关闭;线程一直涨到5000以上知道系统outmemory,所有线程无法再创建。

通过jstack查看,大部分线程都处于以下状态:

"Reciever" daemon prio=10 tid=0x08a84400 nid=0x1193 runnable [0x56e24000]
java.lang.Thread.State: RUNNABLE
at java.net.PlainDatagramSocketImpl.receive0(Native Method)
- locked <0x75cf63c0> (a java.net.PlainDatagramSocketImpl)
at java.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:136)
- locked <0x75cf63c0> (a java.net.PlainDatagramSocketImpl)
at java.net.DatagramSocket.receive(DatagramSocket.java:725)
- locked <0x75cf6400> (a java.net.DatagramPacket)
- locked <0x75cf0ff8> (a java.net.DatagramSocket)
at com.voxbiblia.jresolver.UDPTransportService.recv(UDPTransportService.java:71)
at com.voxbiblia.jresolver.ConversationService$Reciever.run(ConversationService.java:119)

Locked ownable synchronizers:
- None

因为线程的创建是通过quartz自动任务产生,所以同时发现同样数量的如下信息:
"Scheduler" daemon prio=10 tid=0x082c3800 nid=0x86d in Object.wait() [0x668c5000]
java.lang.Thread.State: TIMED_WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
at com.voxbiblia.jresolver.ConversationScheduler.run(ConversationScheduler.java:127)
- locked <0x759e7b28> (a com.voxbiblia.jresolver.ConversationScheduler)

Locked ownable synchronizers:
- None

代码中socket.close()是在finally中调用过的。
在大部分linux环境下都是没问题,任务线程不会超过线程池的上限!
只有这个某公司自开发的内核的linux。只要用到这个socket通信线程的功能部分就会最终线程涨满...直至进程无法再创建任何线程...

有没有兄弟遇到过此类型的问题。望能提供一点参考,望不吝赐教,我这里先行道谢!
...全文
655 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
zytry 2012-04-01
  • 打赏
  • 举报
回复
我分析不退出的socket的线程是发生了阻塞。但如何去判断呢。

socket 被close后,系统是符合回收销毁线程呢?
zytry 2012-04-01
  • 打赏
  • 举报
回复
谁给来点想法
zytry 2012-03-31
  • 打赏
  • 举报
回复
socket本身设置了超时时间。其实本人测试过,在其他环境,把socket.close()删掉后,再做压力测试都没有模拟出该环境下的问题。

故也想找出此类型问题如何在开发环境重现...
从零开始讲述Java线程的核心知识,通过板书和一步一步画图的方式,引领大家逐步去理解和掌握这些知识;并深入分析源码实现,理解背后的实现原理,知其然还要知其所以然。从多线程核心基础讲起,理解线程的风险,多种创建线程的方式;再到深入理解线程的状态;然后是线程的基本操作。系统、深入、快速上手实现多线程。 课程目标:    快速上手掌握Java线程的经典课程,    系统、全面、深入掌握Java线程的核心知识主讲老师:CC老师     20年Java开发和使用经验,多年的首席架构师和CTO,畅销原创书籍《研磨设计模式》的作者。         参与和领导了上百个大中型项目的设计和开发,在互联网应用系统架构、系统设计、    应用级框架和中间件开发等方面具有很多经验和领悟。    更为难得的是,入行20年,仍然奋战在技术一线,深知一线架构师需要掌握哪些技术、    掌握到什么程度、一线架构设计会遇到哪些坑、如何才能做出最合适的架构设计,经验最难得!适应人群:    想要系统、深入学习Java线程    已有Java开发基础,想要快速掌握Java线程    补充Java线程知识,为进入一线大厂做准备学习方式:随到随学课程内容:第一节课:系统理解Java并发编程的知识体系    1:为什么要掌握Java并发编程    2:整个课程的目标    3:整个课程的学习内容第二节课:线程必备基础知识    1:理解线程是什么,理解进程,图示    2:理解轻量级的含义    3:理解时序调度,线程是时序调度的基本单元,图示    4:理解调度方式:抢占式,图示    5:理解我们写的程序基本都是多线程的应用,图示    6:理解并发和并行,图示    7:为什么需要线程第三节课:线程的风险    1:线程安全性问题,图示    2:线程的活跃度问题:死锁、饥饿、活锁,图示    3:线程的性能问题,这里主要是线程间切换 上下文的开销第四节课:创建线程的方式之一    1: 代码演示:实现Runnable接口的方式来创建线程    2:学习Thread类的方法和属性的应用    3:学习Thread类的源码第五节课:创建线程的方式之二    1:继承Thread的方式来创建线程    2:继续学习Thread类的源码,分析线程初始化过程    3: 代码演示:演示ThreadGroup    4: 代码演示:演示daemon线程,理解daemon线程和主线程的关系第六节课:创建线程的方式之三    1: 代码演示:匿名内部类的方式来创建线程    2:继续学习Thread类的源码,分析run方法的调用过程    3:代码演示:callable的方式来创建线程,带返回值    4: 学习FutureTask的部分源码,分析run方法到call方法的调用过程第七节课:线程状态详解    1:通过Thread源码来查看线程状态的定义    2:一步一步画图,讲述状态之间的变迁第八节课:线程的基本操作sleep 和yield    1:阅读Thread源码    2:代码演示:sleep的使用    3:代码演示:yield的使用    4:sleep和yield的对比理解第九节课:线程的基本操作join和interrupt    1:阅读Thread源码    2:代码演示:join的使用    3:代码演示:interrupt的使用这里是《Java并发编程与源码分析》的第一部分——讲述多线程核心基础实现快速上手多线程的经典之作   

81,095

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧