[NPWP笔记]使用多进程处理客户请求

之前《Develop a multi-process server with perl》中描述了采用都进程处理客户端的请求,监听Socket一直处于accept状态,当有客户端的请求到达时,服务器创建一个子进程,后续对客户端的请求处理全部交由此子进程。这种用法会导致频繁的创建与关闭子进程,影响服务器的性能,尤其是在大并发的情况下显得更为严重。

     本文中依旧采用多线程处理客户端的请求,与上次的多进程不同的是,我们预先创建指定数目的子进程,每一个客户端的连接请求到来时,不在需要创建子进程(预先已经创建好了)。

     本例子程序还存在问题,预先启动的子进程是固定数目,下面的代码中采用NUM=2,也就是说此服务器尽可以同时处理两个客户端的请求,只要是服务器的处理没有处于accept状态,之后所有的请将将会被拒绝。

 

客户端代码与之前的代码相同,测试服务器时,在一个终端服务器,另开两个终端分别用于启动客户端。此时两个客户端的请求都可以正常的被处理。之后再新的终端启动另一个客户端。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值