首页 |缤纷校园 |心理援助 |英语世界 |公务员 |考研天地 |资格考试 |电脑认证 |免费论文 |实用文档 |求职就业 |论坛 |网络课堂 |留言版
 电脑认证首页     考试专题 考试提醒 计算机等级考试 计算机认证水平考试 IT认证 论坛
 最近更新
· [计算机专题]java多线程SOCKET程序问题
· [学习辅导]Java辅导:Java打包实现方…
· [学习辅导]Sybase数据库Varchar类型的…
· [软件设计师考试动态]河北:07年下半年计算机资…
· [备考指南]简单网络管理协议(SNMP)
· [备考指南]缺乏有效网络管理网工应考…
· [计算机专题]围棋理论6类布线施工注意事…
· [学习辅导]网络管理:视频会议QOS配置…
· [学习辅导]系统安全从定制IP策略开始
· [学习辅导]WindowsXP四则值得一用的技…
 精品课程
· [精品课程推荐]08年投资项目管理师考…
· [精品课程推荐]08年职称日语考试辅导…
· [精品课程推荐]08年环境影响评价师辅…
· [精品课程推荐]08年质量资格考试辅导…
· [精品课程推荐]08年会计职称辅导报精…
· [精品课程推荐]08年建筑师考试辅导京…
· [精品课程推荐]08职称英语考试辅导王…
· [精品课程推荐]08年咨询工程师考试名…
· [精品课程推荐]08年监理工程师考试辅…
· [精品课程推荐]经济师考试网上辅导报…
 考试动态
· [二级考试动态]上海:2008年上半年全国计…
· [二级考试动态]北京:2007年9月计算机等级…
· [二级考试动态]2007年12月全国计算机职业…
· [二级考试动态]青岛:2008年上半年计算机…
· [二级考试动态]宁夏:2007年9月计算机等级…
· [二级考试动态]北京地区计算机等级考试10…
· [二级考试动态]北京:07年下半年计算机等…
· [二级考试动态]2008年4月全国计算机等级考…
· [二级考试动态]2007年下半年计算机等级考…
· [二级考试动态]天津:2007年下半年全国计…
 试题下载
· [试题下载]2007年计算机等级考试二级…
· [试题下载]2007年9月计算机等级考试二…
· [试题下载]2007年9月二级VB试题答案
· [试题下载]2007年9月计算机二级VB模拟…
· [试题下载]2007年9月计算机二级VB模拟…
· [试题下载]2007年9月计算机二级VF模拟…
· [试题下载]2007年9月计算机二级VB模拟…
· [试题下载]2007年9月计算机等级考试二…
· [试题下载]VC++中利用/GS开关防止缓冲…
· [试题下载]2007年4月计算机等级考试二…
 学习辅导
· [学习辅导]2007年计算机二级VF编辑
· [学习辅导]2007年C语言辅导:可移植性
· [学习辅导]2007年制作风格独特的按钮
· [学习辅导]2007年VFP中使用Grid控件设…
· [学习辅导]MoreEffectiveC++之考虑变…
· [学习辅导]C++/CLI解析之基于堆栈的对…
· [学习辅导]C++builder的文件读写操作…
· [学习辅导]C++类对象的复制-拷贝构造…
· [学习辅导]C++基本数据类型与输入输出
· [学习辅导]C++程序设计之四书五经
 

java多线程SOCKET程序问题

文章录入:admin    责任编辑:admin   2008-1-31 16:12:47  来源:考资网  点击数:
 

  去年的一个项目中,我设计了一个多线程的UDP通讯程式,由我方一台主机,分别对应四地发送接收数据包。在生产环境已经非常稳健的运行了1年。

  最近,随着业务的增加,连接的远端增加到了12个,也就是一个IP向12个IP发送接收数据包。
我在主线程中,管理这12个独立的通讯线程,互不干扰,由于服务器是2U4核,所以该程式的设计具有一定可伸缩性。但是,最近维护人员告诉,发现会发生某地业务停顿。一检查,线程exception terminate。居然报的是:port already bind这个最常见的exception。但是在console里面,重启这个线程,它又可以正常启动,并稳定的运行。而且它每次发生的几率很随机,有时候死掉1个,有时死掉3个,或者全部正常。

  去年,该程式做过多次压力测试,并没发现这个问题,现在唯一导致它发生的原因就是线程增加了3倍。仔细分析,发现多线程的启动方式,是在spring里面进行管理和注册jmx,每个线程都事先配置成mbean。启动的时候,注入一个map里,再循环启动。而udp通讯的方式是,随机的由OS分配端口,会不会是线程的request太快,而OS没有lock port cache的strategy,我想到这里于是在循环启动bean的方法里面,加了一个Thread.sleep(100)。再次测试,解决。

  最后,我认为os在分配随机端口的时候,可能没有锁定机制,如果线程的request是高conconrent,就有可能出现重叠,而引发port lready bind 这个最简单的错误。要解决这个问题,第一就是尽量延长启动间隔,尤其是多路并发的server上,第二,人为的控制port的分配。

  • 上一个文章:

  • 下一个文章: 没有了
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    关于本站 - 广告服务 - 站内导航 - 网站声明 - 友情链接 - 联系我们
    Copyright©2003-2008 www.dastu.com, All Rights Reserved.

    心语心愿科技(北京)有限责任公司 版权所有

    鄂ICP备05000022号