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

有人做过进程池吗?

    来源: 互联网  发布时间:2014-12-12

    本文导语:  如何实现?有没有什么资料? | 1.建立一个进程池,最近但的是一个进城id,一个忙闲标志,何一个管道(或unix socket),程序执行后先fork一堆子进程,同时和美一个子进程建立一个管道或者uni...

如何实现?有没有什么资料?

|
1.建立一个进程池,最近但的是一个进城id,一个忙闲标志,何一个管道(或unix socket),程序执行后先fork一堆子进程,同时和美一个子进程建立一个管道或者unix socket进行通信。
2。挡住进程接收到请求,从进程池中找一个空闲子进程,将空闲表机置1,将请求发送给子进程,在等待下一个请求
3。紫禁城处理完后,可以直接或者通过主进程返回结果给请求者,再通知主进程,主进程把该进程的空闲标志置0,以便下次使用

|
登记一个进程表,设定一个最大进程数目和一个最小进程数目和一个正常数;

系统启动时,就产生正常数目的进程。

一个业务进来,首先在进程表中搜索是否有空闲的进程,有的话,将该进程表项改成已用,并将业务递交给该进程。业务处理完毕后退出时将进程表项修改成未用。

如果业务请求时,进程表没有空余的进程,则向系统请求增加进程,系统首先检查当前进程数是否超过最大值,如果超过,拒绝业务请求。没有超过,则fork一个新的进程处理。

系统定时检查当前进程表的空闲状态,如果发现有过多的空闲进程(超过xx%),则停止一些,停止进程的数目下限为最小进程数。

这种服务器处理方式减少了fork进程时的系统资源消耗,达到减少响应时间的目的。

|
你是想要服务器程序A处于等待状态处理所有的工作,如果有需要就运行某个进程B,不需要时此进程B就什么也不做,下次再需要时此进程B又开始运行?
不就是要实现进程间通讯吗?
你的程序A做为父进程,而要运行的进程为B,一般情况让只有A处于监视状态,当发现条件成熟时就启动B进程,处理完毕了,B进程自动中止退出或者等待A发过来的信号中止。
用共享内存的方法很方便实现。

|
进程池没有做过,线程池做过。
线程池的话,可以用条件变量实现线程间的同步,处理请求的线程和接收请求的线程构成典型的生产者-消费者关系,用pthread_cont_wait和pthread_cond_signal可以轻松的实现,不需要自己管理线程状态,
不知道进程的同步中,有没有条件变量。

|
在前面有一个贴子,我把源代码都粘贴上了.方法比较好!

如果你想的话就去看看吧!

    
 
 

您可能感兴趣的文章:

 
本站(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,