当前位置:  技术问答>linux和unix

关于多进程sokcet服务器的一个问题

    来源: 互联网  发布时间:2015-11-13

    本文导语:  我前一阵子编写了一个服务器端程序,是socket程序,然后基本实现就是每个客户端连接上就fork一个子进程进行通讯处理。对方客户端程序是采用多线程的方式。 最近出现了一个问题就是,当客户端的线程数达到一定...

我前一阵子编写了一个服务器端程序,是socket程序,然后基本实现就是每个客户端连接上就fork一个子进程进行通讯处理。对方客户端程序是采用多线程的方式。
最近出现了一个问题就是,当客户端的线程数达到一定量并运行几天后,客户端发出的消息,我的服务器端就可能收不到,导致系统超时。
因为是双方做的接口系统,所以现在想确定问题的具体所在。对方客户端的开发人员说他们的消息发出去了,但是我在服务器端又看不到收到消息包的日志(如果收到消息,我会将起打印在日志中),我自己写了一个客户端测试程序进行发包,也是消息包发出去了,但是我的服务端却收不到。
暂时只能靠重启解决了,但是运行了几天就会出现这种问题,不知道有哪位碰到过类似情况么?或者哪位知道有什么工具可以监测系统socket通讯过程中的消息传递吗?

|
可能的原因:
1、进程数超限
2、描述符数目超限

ulimit -a看看soft limit是多少,然后检查进程出问题时的值。可以到/proc下去看描述符的个数。pstree可以看进程数。

|
日志文件问题,在大部分操作系统下它的大小是有限定的。
另外线程数量也是有限定的

不知道你客户端的运行环境是什么,在Linux下调用send函数后并不是马上就发送出网卡了,只是放到一个发送队列里面去了而已

哪位知道有什么工具可以监测系统socket通讯过程中的消息传递吗
tcpdump就可以做到,可以指定ip、端口,打印数据包内容等,这个最好在你的服务端运行。

    
 
 

您可能感兴趣的文章:

  • a 请问怎样查看服务器上的telnet进程,及远程telnet进程的ip
  • 服务器端的共享内存可否被远程客户端的进程所挂载使用?
  • 进程模型服务器的问题
  • unix下,多进程socket 服务器问题
  • 关于udp服务器 单进程
  • 我的linux服务器,cpu总是30-50%,top,ps出来的结果看不到哪个进程,怎么办?
  • fork 父进程动态刷新,子进程做操作反馈给服务器,不能实现,求指教
  • 客户端关闭,服务器进程也关闭?
  • 趋势的一道面试题:网络编程中设计并发服务器,使用多进程 与 多线程 ,请问有什么区别?
  • 启动CVS服务器后,CVS的后台服务进程叫什么名?
  • 如何确定服务器的IO所属的进程?
  • 请问gprof命令对于多进程服务器的性能测试是否支持?
  • redhad linux9.0 的命令行中如何终止(杀死)一个服务器进程?
  • 通过JDBC连接数据库,执行抄作后,关闭了连接,数据服务器端的进程还在,怎麽处理?
  • linux系统使用python监控apache服务器进程脚本分享
  • 有谁知道redhat linux服务器可以给tomcat保留部分内存不被其他进程使用吗?
  • 很奇怪的问题:linux下tcp send导致服务器进程崩溃
  • 急!急!能否用applet建立一个新的进程通过http协议访问服务器上的文件?
  • Tornado Web服务器多进程启动的2个方法
  • 我的客户端为单进程。会迭代生成4000个连接,但成功连到服务器上的总是不超过3973个。
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3