向消息队列发送数据和获取数据的测试
<?php$key=ftok(__file__,'a');//获取消息队列$queue=msg_get_queue($key,0666);//发送消息//msg_nd($queue, 1, "hello, 1"退房);//接收消息,如果接收不到会阻塞msg_receive($queue, 1, $message_type, 1024, $message1);//移除消息//msg_remove_queue($queue);//var_dump($message1);
<?php/** * 这段代码模拟了一个日常的任务。 * 第一个父进程产生了一个子进程。子进程又作为父进程,产生10个子进程。 * 可以简化为a -> b -> c,d,e... 等进程。 * 作为a来说,只需要生产任务,然后交给b 来处理。b 则会将任务分配给10个子进程来进行处理。 * *///设定脚本永不超时t_time_limit(0);$ftok = ftok(__f毕业文章ile__, 'a');$msg_queue = msg_get_queue($ftok);$pidarr = []; //产生子进程$pid = pcntl_fork();if ($pid) { //父进程模拟生成一个特大的数组。 $arr = range(1,100000); //将任务放进队里,让多个子进程并行处理 foreach ($arr as $val) { $status = msg_nd($msg_queue,1, $val); usleep(1000); } $pidarr[] = $pid; msg_remove_queue($msg_queue);} el { //子进程收到任务后,fork10个子进程来处理任务。 for ($i =0; $i<10; $i++) { $child我国的根本制度是什么pid = pcntl_fork珠宝品牌排名(); if ($childpid) {再游玄都观 $pidarr[] = $childpid; //收集子进程processid } el { while (true) { msg_receive($msg_queue, 0, $msg_type, 1024, $message); if (!$message) exit(0); echo $message.php_eol; usleep(1000); } } } }//防止主进程先于子进程退出,形成僵尸进程while (count($pidarr) > 0) { foreach ($pidarr as $key => $pid) { $status = pcntl_waitpid($pid, $status); if ($status == -1 || $status > 0) { unt($pidarr[$key]); } } sleep(1);}
以上所述是www.887551.com给大家介绍的php通信-消息队列使用详解整合,希望对大家有所帮助
本文发布于:2023-04-06 14:57:42,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/effc21244da58b0e645ef11d622fc73e.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:PHP多进程通信.doc
本文 PDF 下载地址:PHP多进程通信.pdf
留言与评论(共有 0 条评论) |