热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

江湖救急!应用socket引起所有的network应用程序出错,如MSN,outlook...

公司有个系统,比较古老,web端使用的是applet,applet作为socketclient端。另一台服务器运行socketserver.当多次执行某一个特定事务时(通过Applet,该事务会触
公司有个系统,比较古老,web端使用的是applet,applet作为socket client端。另一台服务器运行socket server.当多次执行某一个特定事务时(通过Applet,该事务会触发发送message到server),会引起browser,outlook, msn等任何有关网络连接的应用软件都挂掉。重新打开也不行,必须注销或重启机器。
1,不是每台机器都会产生这样的问题,有些客户机运行没有任何问题。
2,这些客户机的操作系统,浏览器,jdk version应该都没有区别。
3,很多事务都通过socket传送message,只有该操作会出现此类问题。

现在根本不知道问题出在那里,说是代码问题吧,有些机器还都好用,说不是代码问题吧。确实只有该事务会引起这个问题。郁闷了好久了。。。

12 个解决方案

#1


:(
淘汰掉那个系统吧lz

#2


先前开发这套系统的没留下技术文档?查阅下先

#3


没有什么技术文档,而且系统也不能立即淘汰。有那位前辈知道会引起所有有关网络的应用系统软件全部挂掉的原因。

#4


关键是找到问题所在

这种情况有两种可能最大
1是带宽占用上来了,比如出现反复发送数据,造成带宽被占用
2是端口或者系统缓存占住了。比如socket在连接到了server后发送数据造成阻塞,但没有关闭这个socket就重新启动另外一个socket,这样一直下去,可用port全部被占用,其他的程序也玩完了。系统缓存也有可能,一个socket一般都开辟4k缓存,如果手动设置可以更大。而系统可提供给端口的缓存总数是有限的,如果socket的buffer设置太大,而socket又太多,缓存用完,其他的网络程序也会遇到问题。


你先查查看是不是这个原因。可以通过netstat来看端口有没有增加,如果不是就要找具体细节了。

#5



我在server端有打印输出,的确就是在receiveMessage时停住了。不过没有重新打开socket,也就是说,当出现这种情况时应该是只有一个socket连接(端口固定的)。
不知道这种情况下会引起缓存占用过大么?应用的是object传递

#6


up

#7


你的applet是Socket(ip,port)来建立连接的吧。
出现问题时是客户端的不能用还是server端的不能用?

#8


对,是这种连接方式,出现问题时server端照常使用(使用多线程),不过该线程一直处于等待状态。client端所有网络相关的软件都挂掉了,包括浏览器,outlook,msn...
而且我的机器测试是好用的。

#9


现在你要测试的是客户端的问题,按我说的方法,在出问题后检测netstat,看看使用的端口有哪些,看看网络流量大小,再看看内存使用的变化。

应该不需要重新启动计算机,把客户中javaw进程杀了就可以了吧

#10


First netstat:
Active Connections

  Proto  Local Address          Foreign Address        State
  TCP    nataliec:1218          cs1epo2.sg.int.psaglobal.com:82  ESTABLISHED
  TCP    nataliec:1226          10.106.34.20:http      FIN_WAIT_1
  TCP    nataliec:1227          10.106.34.20:22501     CLOSED

#11


Second netstat (Client hang):
Active Connections

  Proto  Local Address          Foreign Address        State
  TCP    nataliec:1189          cs1epo2.sg.int.psaglobal.com:82  TIME_WAIT
  TCP    nataliec:1195          10.106.34.20:http      TIME_WAIT
  TCP    nataliec:1200          corp4dcsg1.sg.int.psaglobal.com:microsoft-ds  TIME_WAIT
  TCP    nataliec:1202          cs1epo2.sg.int.psaglobal.com:82  TIME_WAIT
  TCP    nataliec:1207          10.106.34.20:http      TIME_WAIT
  TCP    nataliec:1210          10.106.34.20:http      TIME_WAIT
  TCP    nataliec:1213          10.106.34.20:http      TIME_WAIT
  TCP    nataliec:1216          10.106.34.20:http      ESTABLISHED
  TCP    nataliec:1217          cs1epo2.sg.int.psaglobal.com:82  FIN_WAIT_2
  TCP    nataliec:1218          cs1epo2.sg.int.psaglobal.com:82  ESTABLISHED
  TCP    nataliec:1424          xchg2vs1.sg.int.psaglobal.com:10201  ESTABLISHED
  TCP    nataliec:1453          corp4dcsg1.sg.int.psaglobal.com:1026  ESTABLISHED
  TCP    nataliec:1463          xchg1vs1.sg.int.psaglobal.com:1475  ESTABLISHED
  TCP    nataliec:4522          corp4dcsg1.sg.int.psaglobal.com:1026  ESTABLISHED
  TCP    nataliec:4526          xchg2vs1.sg.int.psaglobal.com:10201  ESTABLISHED
  TCP    nataliec:4968          corp4dcsg1.sg.int.psaglobal.com:3268  CLOSE_WAIT

#12


Before that, 还有两个正常操作的后的netstat
1.Active Connections

  Proto  Local Address          Foreign Address        State
  TCP    nataliec:1218          cs1epo2.sg.int.psaglobal.com:82  ESTABLISHED
  TCP    nataliec:1227          10.106.34.20:22501     CLOSED
  TCP    nataliec:1230          cs1epo2.sg.int.psaglobal.com:82  SYN_SENT
2. Active Connections

  Proto  Local Address          Foreign Address        State
  TCP    nataliec:1218          cs1epo2.sg.int.psaglobal.com:82  ESTABLISHED
  TCP    nataliec:1226          10.106.34.20:http      CLOSING
  TCP    nataliec:1227          10.106.34.20:22501     CLOSED
  TCP    nataliec:4522          corp4dcsg1.sg.int.psaglobal.com:1026  ESTABLISHED
  TCP    nataliec:4526          xchg2vs1.sg.int.psaglobal.com:10201  ESTABLISHED

推荐阅读
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文探讨了在Java多线程环境下,如何确保具有相同key值的线程能够互斥执行并按顺序输出结果。通过优化代码结构和使用线程安全的数据结构,我们解决了线程同步问题,并实现了预期的并发行为。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
author-avatar
kanliyan_857
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有