摘要:所以这次采用多进程的方式来实现同时为多个客户端提供服务。而多进程则是通过创建多个进程来共同完成一件事。如果是子进程的执行环境,则返回。正常情况下,子进程是通过父进程创建的。以上则是我们的多进程回声服务程序。
上次的回声服务程序有个很大的缺点,就是只能同时连接一个客户端,这明显是不合理的。
所以这次采用多进程的方式来实现同时为多个客户端提供服务。
以下是最终的效果:
(通过 ps 命令可以查看到我们创建的工作进程)
(通过 xshell 打开多个终端,并向服务程序连接多个客户端)
在开始编码之前,先介绍一下什么是进程。
进程,即正在运行的占用内存的程序,是一个独立的内存空间。比如我们在 windows 上打开记事本软件,这个操作就相当于打开了一个进程。
而多进程则是通过创建多个进程来共同完成一件事。
我们本次只需实现服务端的程序就行了,客户端还使用之前的。没读过之前文章的可以查看历史文章。
在PHP中,我们可以使用 pcntl_fork 函数来实现创建进程。
下面是函数的原型:
int pcntl_fork ( void )
官方解释:
成功时,在父进程执行线程内返回产生的子进程的PID,在子进程执行线程内返回0。失败时,在 父进程上下文返回-1,不会创建子进程,并且会引发一个PHP错误。
为什么说是父进程执行的线程呢,因为一个进程中至少包含一个线程 ,而这个线程则是进程的主线程。
父进程在调用 pcntl_fork 时,同时复制出一个独立的子进程,这个子进程具有父进程同样的上下文。也就是说两个进程共享一个代码而已。
下面进入编码环节:
通过执行 pcntl_fork 函数,同时复制了一个子进程,此时,如果上下文是父进程的执行环境,则返回值为子进程的进程号。如果是子进程的执行环境,则返回0。所以下面的if程序结构,两个分支都执行了。
子进程同样还是以前的逻辑,用来接收客户端的消息,同时发送给客户端。
倒数第二行调用了 pcntl_waitpid 函数,在讲解这个函数之前我们先了解一下什么是僵尸进程。
正常情况下,子进程是通过父进程创建的。由于进程是互相独立的内存结构,所以父进程是不会知道子进程的运行状态的。子进程完成自己的任务之后,并不能自己退出,这个时候需要父进程通过操作系统来取得子进程的状态,从而回收子进程。否则,我们的子进程将会成为一个垃圾资源,也就是僵尸进程。
下面是这个函数的函数原型:
int pcntl_waitpid ( int $pid , int &$status [, int $options = 0 ] )
官方解释:
等待或返回fork的子进程状态。
其实上面的代码是有问题的,在 foreach 中第一次调用 pcntl_waitpid 之后 ,主进程其实此时是被阻塞着,一直在等待第一个子进程退出,而其他的子进程若此时异常退出,则并没有被主进程回收,也就产生了僵尸进程。而在实际的开发中主进程还是要做其他的事情的。
所以这里推荐采用非阻塞的方式,很简单,只需加上第三个参数:WNOHANG。即:pcntl_waitpid ($pid, $status, WNOHANG)
这样子可以在没有子进程退出的情况下立刻返回,从而继续执行后续代码。
以上则是我们的多进程回声服务程序。如果觉得文章还不错欢迎关注解锁更多~
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30873.html
摘要:多线程技术是个很庞大的课题,编程思想这本书英文版,以下简称中也用了页介绍的多线程体系。一个线程归属于唯一的进程,线程无法脱离进程而存在。五线程内数据线程的私有数据仅归属于一个线程,不在线程之间共享,例如,,。 多线程技术是个很庞大的课题,《Java编程思想》这本书(英文版,以下简称TIJ)中也用了136页介绍Java的多线程体系。的确,Java语言发展到今天,多线程机制相比其他的语言从...
摘要:多进程中与多进程相关的两个重要拓展是和。函数执行期间,主进程除了等待无法处理其他任务,所以一般不认为这是多进程编程。回收子进程有两种方式,一种是主进程调用函数等待子进程结束另外一种是处理信号。 转载请注明文章出处: https://tlanyan.me/php-review... PHP回顾系列目录 PHP基础 web请求 cookie web响应 session 数据库操作 加解...
摘要:上一篇文章是对编程的入门,这次我们基于实现一个简单的收发消息的服务。通过上面一篇文章,我们已经对于创建套接字的流程有了一定的了解,在这里就不多说这些了。第处将读取到的输入信息写入缓冲区,从而发送到服务端。 上一篇文章是对socket编程的入门,这次我们基于socket实现一个简单的收发消息的服务。 实现思路: 先说服务端: 接受客户端的连接 读取客户端发送过来的信息 将接受到信息发送...
阅读 1850·2021-11-25 09:43
阅读 1492·2021-09-02 15:21
阅读 3455·2019-08-30 15:52
阅读 1503·2019-08-30 12:48
阅读 1297·2019-08-30 10:57
阅读 2931·2019-08-26 17:41
阅读 681·2019-08-26 11:59
阅读 1368·2019-08-26 10:41