时间:2021-05-26
本文实例讲述了php进程间通讯的方法。分享给大家供大家参考,具体如下:
php单进程单线程处理批量任务太慢了,受不鸟了,但是php不能多线程,最终选择了多进程处理批量任务.
php多进程主要使用for进行分裂,然后利用的unix/linux的信号量进行进程间通讯.
本例使用的是:生产者=>消费者=>收集器,的模式.
<?php// ===== 全局变量 =====// ipc进程间通讯$key = ftok(__FILE__, "a");$queue = msg_get_queue($key);// 进程ID$producer_pid = 0;$consumers_pid = array();$collector_pid = posix_getpid();// ===== 消费者 =====for ($i=0; $i < 2; $i++) { $consumer_pid = pcntl_fork(); if ($consumer_pid == -1) { exit("could not fork!\n"); } else if ($consumer_pid) { // pcntl_wait($status); echo "consumer_pid: $consumer_pid\n"; $consumers_pid[] = $consumer_pid; } else { $pid = posix_getpid(); echo "consumer_pid: $pid start\n"; while (true) { msg_receive($queue, $pid, $msgtype, 1024, $message); if ($message == "exit") { break; } // 数据处理 $n = intval($message); msg_send($queue, $collector_pid, $n * $n); } exit("consumer ok!\n"); }}// ===== 产生者 =====$producer_pid = pcntl_fork();if ($producer_pid == -1) { exit("could not fork!\n");} else if ($producer_pid) { // pcntl_wait($status); echo "producer_pid: $producer_pid\n";} else { $pid = posix_getpid(); echo "producer_pid: $pid start\n"; $n = 0; for ($i=0; $i < 10; $i++) { foreach ($consumers_pid as $consumer_pid) { $n++; msg_send($queue, $consumer_pid, $n); } sleep(1); } foreach ($consumers_pid as $consumer_pid) { msg_send($queue, $consumer_pid, "exit"); } sleep(1); msg_send($queue, $collector_pid, "exit"); exit("producer ok!\n");}// ===== 收集器 =====while (true) { msg_receive($queue, $collector_pid, $msgtype, 1024, $message); if ($message == "exit") { break; } echo sprintf("% 5d: %d\n", $msgtype, $message);}exit("collector ok!\n");更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP进程与线程操作技巧总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php日期与时间用法总结》、《php面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP将进程作为守护进程的方法。分享给大家供大家参考。具体分析如下:php中posix_setsid()的用法文档解释是“Makethecurre
本文实例讲述了PHP的pcntl多进程用法。分享给大家供大家参考。具体分析如下:PHP使用PCNTL系列的函数也能做到多进程处理一个事务。比如我需要从数据库中获
本文实例讲述了php多进程编程父进程的阻塞与非阻塞。分享给大家供大家参考,具体如下:php中进程的阻塞,主要是父进程等待子进程退出。1.php代码如下:
一、进程间通信IPC(Inter-ProcessCommunication)IPC机制:实现进程之间通讯管道:pipe基于共享的内存空间队列:pipe+锁的概念
本文提供一个用C#实现串口通讯实例,亲自编写,亲测可用!开发环境:VS2008+.netFrameWork3.5(实际上2.0应该也可以)第一步创建一个WinF