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

关于多进程通信的问题

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

    本文导语:  我的主服务器每次接到请求(socket)都会fork出新的进程去处理请求,但是子进程返回给客户的数据却是在父进程里,要从父进程里获得数据,然后返回给客户。pipe和共享内存可以实现这种方式,但是用pipe就阻塞住主服...

我的主服务器每次接到请求(socket)都会fork出新的进程去处理请求,但是子进程返回给客户的数据却是在父进程里,要从父进程里获得数据,然后返回给客户。pipe和共享内存可以实现这种方式,但是用pipe就阻塞住主服务器了,服务器还要接受其它的socket请求。不知如何实现这个功能好,比如一些其它的服务器比如apache等,是如何实现这种功能的。

|
如果子进程也要操作这些数据的话,用共享内存吧。

父子进程的通信问题也可以用信号与消息队列来处理。

|
fork()出的子进程是共享父进程的数据的,你可以取得那个数据。

|
共享内存+信号量是最理想的。
不过话说回来,如果只是读取一些url发给客户干的活不多的话,其实也没必要fork.fork本身也费时间费资源。能简单处理就简单处理。

|
显然,多线程是个最最简单易行的办法。

共享内存可能不是个好办法。那些url到底有多少,很难估算空间。

我觉得楼主可能担心的问题在于socket io的阻塞问题,所有要fork。

一种方法是使用异步非阻塞io,单进程实现,效率应该超强。

另外一种方法是实现一个单独的url管理服务,接入应用fork出来的子进程跟该服务进行daemon socket通讯。

不过,呵呵,还是多线程来的爽快。

    
 
 

您可能感兴趣的文章:

  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 进程通信和线程通信的区别
  • 求教 "客户进程" 与 "守护进程" 间通信问题
  • 子进程与父进程通信问题?急
  • 我想让vfork后就execl一进程,同时让execl出来的进程之间能相互通信,求助
  • 怎么实现这个类?(进程间通信)
  • Linux内核进程与应用进程的通信方式有哪些?
  • 内核进程与用户进程间的通信
  • 请问有关进程间通信的问题 iis7站长之家
  • 关于进程通信的问题
  • 关于两进程通信的问题
  • 进程间通信究竟跟“临界区”有什么关系?
  • 请问有关进程间通信的问题
  • linux进程异步通信,高手请进
  • linux下的一个进程通信问题,请指教。
  • 有关进程通信
  • linux 进程之间的通信问题
  • linux进程间通信
  • linux下进程间通信问题。
  • 进程间信号通信问题
  • Linux下进程间通信常用的方法有哪些?谢谢了
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 请教,进程通讯问题,除了父子进程能进行通讯外,任意两个进程都可以吗?
  • 父进程退出后子进程的问题
  • 僵死进程父进程的问题
  • 一个关于父进程和子进程的问题
  • 请教一个关于子进程和父进程竞争的问题
  • 多个进程共用一个信号量,如果某个进程死掉,此时又将信号量锁定,其它进程就死掉,有什么办法可以解决这一问题
  • 求教一个关于子进程与父进程socket描述符的一个问题
  • 请教:进程创建和进程状态有关问题
  • unix中有关父进程和子进程的问题
  •  
    本站(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秒后继续向下执行,请问
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录
  • 【如何彻底杀死子进程】Kill -9子进程后进程呈僵死状态
  • 信号灯同步2个进程,一个进程如何主动给另一个进程发送通知?


  • 站内导航:


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

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

    浙ICP备11055608号-3