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

Linux下进程池实现

    来源: 互联网  发布时间:2017-01-17

    本文导语:  各位高手:      我现在接手一项工作:用c/c++写一个进程池,要求:     1 客户端只有一个,但是却在不停的发报文,所以服务器端与客户端建立socket长联接,(即服务端只accept客户端联接请求一次,之后就在这个...

各位高手: 
    我现在接手一项工作:用c/c++写一个进程池,要求:
    1 客户端只有一个,但是却在不停的发报文,所以服务器端与客户端建立socket长联接,(即服务端只accept客户端联接请求一次,之后就在这个套结字上循环接收,处理客户端的报文,每次收到一个报文,就起一个子进程处理这个报文,因为一秒钟可能收到几百条报文,而处理每条报文需要一段时间,如果不设进程池,就有可能积累过多进程,尽管可以在每个子进程处理完后就结束掉,来了新的报文就起新进程,但是有一种说法认为:每天假设有100万报文,就需要起100万次进程,假设Linux系统关掉每个子进程都回产生一些垃圾,就会导致形系统崩溃,我虽然认为这种看法不必要,因为Linux作为一个成熟的系统,结束一个子进程(exit),怎么会产生垃圾?但不得不按循环利用子进程池方案作:起固定个数子进程后,每个处理报文的子进程 处理完后不结束,而是通知(怎样通知?管道)管理进程自己空闲,等待调用,来了新的报文,由某一管理进程查询哪个子进程空闲,使用之,请问上述循环利用固定数目的进程池怎样实现?
    查了包括本论坛在内的好多资料,都是只讲方法,没有代码,给我的做项目时间有限,能否请做过的贴代码上来?多谢!
我已有的通讯代码如下:(没有进程池代码)
recvFrontSock = accept(listenFrontSock, (__SOCKADDR_ARG )&peer , (socklen_t*)&addrlen2);
for (;;)// 循环接收客户端发来的终端报文
{
read_bytes = read(recvFrontSock, buff, received);
if (fork() == 0)// 每次收到客户端发来的报文就起一个子进程处理
{
process(socketToCore, semid, shm_id, shm_field8583id, pid, buff);
// 处理完后如何通知管理进程自己空闲?等待(睡眠等待??)重新调用

}// if (fork() == 0)
}//for (;;)

 

|
进程池还没用玩过,下面说说我的想法:
先起100个工作进程,另起一个管理进程,
初始管理进程启动,然后创建100个工作进程,所有工作进程pend在信号SIGUSR1上,管理进程维护一个数据结构记录每个进程都是空闲的。
下面开始工作,
来了一个请求,要传到工作进程去处理,那么就必须使用进程间通讯,比如消息队列,把请求写到一个全局的消息队列里去,管理进程找到一个空闲进程的PID,改这个进程状态的忙,然后发送一个信号如SIGUSR1到工作进程, 工作进程pend在SIGUSR1上,当工作进程收到SIGUSR1后从消息队列里读出请求进行处理,处理完成后发送一个信号如SIGUSR2通知自己已经处理完了,然后继续pend在SIGUSR1上,管理进程收到信号SIGUSR2后再把这个工作进程置为空闲,供以后使用。

以上是我的想法,应该跟标准备的进程池技术一样。如果楼主还是觉得代码来提快,我建议还是先把基础打好,就像一个人在成为作家之前必须先学会写字一样。

|


你这有个问题, SIGUSR2 发往 父进程组时,可能父进程已经在SIGUSR2处理函数里。 而Linux不保证信号排队,所以。。。 不够完善。。。

|
如果是进程池,首先要考虑的就是报文传递的方式了,用哪种IPC好.
一个用户,那也是一个read,这么看来,共享内存是一种好的IPC.

那么,这种工作方式就是:

先启动进程池,2就开始工作了.之后循环处理1.

1.收取报文---->报文放入共享内存---->在管道里写上内存指针
2.进程池就是从管道里读指针,读到后,就处理.  


lighttpd就是进程池模型吧,很快的.


当然,线程池也不错,只是楼上某位推荐的是boost实现的线程池,你不想装一个boost吧...
(不过公司让用,就用吧,也不错. )

我写过linux下的异步IO和线程池.  不依赖3方库的.
其实,你这个问题,用异步IO加线程池,才是最佳的方案.
现在工作忙,下周准备写一个进程池.



    
 
 

您可能感兴趣的文章:

  • linux僵尸(zombie)进程介绍及清除
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • linux下进程占用内存空间详解
  • linux命令如何实现重启父进程而不会使其子进程退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • Linux中最多同时可以开多少个进程,一个进程可以开多少个线程?
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • Linux守护进程 的子进程 终端处理
  • Linux内核进程与应用进程的通信方式有哪些?
  • 在linux,如何用共享内存来实现进程间的通讯?(这些进程没有父子关系)
  • linux下system函数调用shell命令后,怎样让主进程不等子进程返回,接着执行(在线)?
  • linux进程(线程)运行过程中如何获取本进程当前的内存使用状况,统计信息?
  • 如何linux下监控进程及其子进程占用资源?
  • linux下的进程如何访问另外一个进程建立的mutex?
  • linux中用killall命令杀死进程的时候会释放掉该进程所占有的内存吗?
  • linux内核高手进!关于调用__fork()时0号进程的子进程才能与父进程共享PID的困惑
  • 请教:在Linux下怎么样检测一个进程是否是僵尸进程??
  • 请问linux进程的哪些信息保存在内核里?哪些信息又保存在进程空间里?谢谢
  • Linux下请教一个父进程杀死子进程的问题.
  • 怎么查看Linux中所运行的进程,并且知道哪些是停止响应的,用什么命令可以杀掉停止响应的进程?
  • 【求助】linux/Unix下创建子进程,向父进程发送信号,子进程也能收到改信号,此时如何让子进程不收到信号
  • linux下通过crond实现自动执行程序
  • Linux和Unix相对WIN、NETWARE有什么好处?他们之间有什么区别?WIN、NETWARE能实现的功能LINUX和UNIX能实现吗?
  • Linux下c函数dlopen实现加载动态库so文件代码举例
  • linux下如实现与window下的驱动器实现文件共享??
  • Linux内存文件系统(ramdisk)的三种实现方式
  • windows 下的PortTunnel 在linux下怎么实现?或者相应的已经实现的软件?端口映射
  • linux内存文件系统ramfs实现原理
  • 在linux下如何编程实现nslookup命令实现的IP地址和域名互相转换的功能?
  • Linux 共享内存介绍及实现代码
  • 我需要一个模型,在 LINUX C 下。实现线程间的控制,执行,阻塞,再执行。。。。。不知道如何实现。
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在没有linux的盘,只有DOS启动盘)
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • 如何让win2000和linux共存。我装好WIN2000,再装LINUX7.0,但LILO只能找到LINUX,不能引导WIN2000
  • linux c下利用srand和rand函数生成随机字符串
  • 在windows中的VMware装了个linux,主板有两个串口,能做windows和linux的串口通信测试么,怎么测试这两个串口在linux是有效
  • Linux c++虚函数(virtual function)简单用法示例代码
  • 我们网站的服务器从windows2000迁往linux,ASP程序继续使用,可是我连LINUX的皮毛都不了解,大家告诉我LINUX下怎么建网站??
  • Docker官方镜像将会使用Alpine Linux替换Ubuntu
  • 中文Linux与西文Linus分别哪一个版是权威?I认为是:中科软的白旗Linux与西文的绿帽子Linux!大家的看法呢?
  • Linux下chmod命令详细介绍及用法举例
  • 我重装了winme,却进不了Linux了,而我现在又没有Linux光盘,也没有Linux启动盘,还有没有办法?


  • 站内导航:


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

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

    浙ICP备11055608号-3