摘要:接受不到消息消息队列通过指定而被创建后,任意一方销毁了该队列,都会导致其他发送或接收方失败。用法场景进程,中代码段要用到中代码段的结果。完成了进程间同步问题此外进程间通信采用的方式是共享内存。
参考文章
深刻理解Linux进程间通信(IPC)
进程间通信(IPC)介绍
php高级应用之进程控制及进程间通讯 workman 作者发布
PHP 相关进程间通信扩展-- System V IPC: sysvmsg 消息队列 sysvsem 信号量 sysvshm 共享内存 -- BSD IPC socket(stream) -- POSIX IPC posix 信号量 posix 共享内存 posix 消息队列sysvmsg(消息队列)
php ftok 函数作用解析
php ftok 参数2坑!
用途:解决进程间通信问题
用法:发送方(send.php)
$key = 1; $msg = "发送方发送的消息"; $q = msg_get_queue($key); $send = msg_send($q , 1 , $msg , true , true); if ($send) { echo "消息发送成功" . PHP_EOL; } else { echo "消息发送失败" . PHP_EOL; }
接收方(receive.php)
$key = 1; $q = msg_get_queue($key); /** * 第二个参数解释: < 0 ,小于该绝对值的最小类型队列上的第一条记录 例如我设置了 -5,绝对值 5 该消息队列的消息类型有 2 3 4 5 6 7 则返回类型为 2 的消息队列上的第一条记录 0 则获取队列第一条消息(不管消息类型,标识符) 1 获取设置类型下的第一条消息 第三个参数必须是个变量!(坑爹的货!) */ msg_receive($q , 1 , $msg_type , 1024 , $msg , true , MSG_NOERROR , $error_code);错误处理
无权限访问
有可能你会碰到访问无权限访问队列的情况。那是因为你的代码长这样。我也忘了是怎样修复的,后面自动好了。
接受不到消息
消息队列通过指定 key 而被创建后,任意一方销毁了该队列,都会导致其他发送 或 接收方失败。
信号量(sysvsem) + 共享内存(sysvshm) 用途:注意了:解决进程间同步问题。
用法场景:进程 A 、B、C,B 中代码段 y 要用到 A 中代码段 x 的结果。C 中代码段 m 要用到 B 中代码段 y 的结果。
$key = ftok(__FILE__ , 1); $shm = shm_attach($key); create(3 , [ // 进程 A function($index) use($key , $shm){ $sem_id = sem_get($key); // 获取信号量!(其他相同获取该信号量的进程等待,直到该信号量被释放为止) sem_acquire($sem_id); // x 处理语句 shm_put_var($shm , 1 , 10); $wait = 3; $count = 1; while ($count >= $wait) { echo "进程 A 等待处理" . $count++ . "s" . PHP_EOL; sleep(1); } // 3s 后释放信号量 sem_release($shm); } , // 进程 B function($index) use($key , $shm){ $sem_id = sem_get($key); // 获取信号量!(其他相同获取该信号量的进程等待,直到该信号量被释放为止) sem_acquire($sem_id); // x 处理语句返回结果 $x = shm_get_var($shm , 1); $y = $x + 11; shm_put_var($shm , 2 , $y); $wait = 5; $count = 1; while ($count >= $wait) { echo "进程 B 等待处理" . $count++ . "s" . PHP_EOL; sleep(1); } // 5s 后释放信号量 sem_release($shm); } , // 进程 C function($index) use($key , $shm){ $sem_id = sem_get($key); // 获取信号量!(其他相同获取该信号量的进程等待,直到该信号量被释放为止) sem_acquire($sem_id); // x 处理语句返回结果 $y = shm_get_var($shm , 2); $c = $x + 12; echo "获取到结果:" . $c; // 删除共享内存段 sem_remove($shm); } , ];
解释:A 首先获取到信号量,然后等待 3s 后释放,期间 B、C在调用 sem_acquire 后阻塞,直到获取到该信号量为止。A 释放信号量后,B 现获取,然后阻塞 5s 释放,最后 C 获取,执行。完成了进程间同步问题!此外进程间通信采用的方式是共享内存。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30646.html
阅读 2985·2021-11-23 09:51
阅读 2798·2021-11-11 16:55
阅读 2907·2021-10-14 09:43
阅读 1394·2021-09-23 11:22
阅读 1034·2019-08-30 11:04
阅读 1663·2019-08-29 11:10
阅读 955·2019-08-27 10:56
阅读 3101·2019-08-26 12:01