免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2236 | 回复: 3
打印 上一主题 下一主题

[Linux] 进程终止,线程创建的资源为啥不释放? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-01-20 18:48 |只看该作者 |倒序浏览
进程终止,线程创建的资源为啥不释放?

rhel6.3 64位, 内核版本2.6.32

进程A, 创建了线程B,A然后for(;pause(); B自己listenfd=socket(), bind(), bind端口号65535, listen(listenfd, ...), 然后阻塞在accept()上,

奇怪的现象来了: 我使用信号SIGTERM kill掉A, 然后使用netstat查看, 发现65535端口仍旧处于LISTEN状态, 除非重启, 否则,
再启动A然后创建线程B永远失败, 因为端口永远被占用

我个人理解: 进程都终止了, 它的线程创建的资源应该也被释放掉,

另外, 即使设置了信号处理函数, 收到信号后pthread_cancel(threadB); 也不行, 甚至close(listenfd);也不行, 总之, 端口号一直处于LISTEN状态!!!



我可以说, 这是内核的bug吗?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:57:09
2 [报告]
发表于 2015-01-21 00:20 |只看该作者
因为是异常终止的,所以占用的端口没有释放,有些系统会不定期的检查异常占用的资源,并对其进行释放,也就是说等一会儿就好了。如果想要每次占用端口之前强制系统检查端口是否已经异常了,可以使用setsockopt(sockfd, IPPROTO_IP, IP_ADD_MEMBERSHIP, optval, optlen)函数。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
3 [报告]
发表于 2015-01-21 09:17 |只看该作者
回复 1# faku


    贴一个能重现你问题的完整例子。

BTW,内核哪那么多bug,还是先确认你自己的代码没问题再说。

论坛徽章:
0
4 [报告]
发表于 2015-01-24 19:51 |只看该作者
是这样的啊。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP