进程间通信
参考文章
php高级应用之进程控制及进程间通讯 workman 作者发布
PHP 相关进程间通信扩展
-- System V IPC:
sysvmsg 消息队列
sysvsem 信号量
sysvshm 共享内存
-- BSD IPC
socket(stream)
-- POSIX IPC
posix 信号量
posix 共享内存
posix 消息队列
sysvmsg(消息队列)
用途:
解决进程间通信问题
用法:
发送方(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 获取,执行。完成了进程间同步问题!此外进程间通信采用的方式是共享内存。
推荐阅读
Laravel 等框架的模型关联的可用性
比如说,获取用户信息的接口,接口中除了要返回 user 表的数据外,还需要返回类似 user_option 或者 user_info 等表的数据。这个时候用 laravel 的模型关联的形式如下:
灰色v碰触阅读 1.1k
初学后端,如何做好表结构设计?
这篇文章介绍了设计数据库表结构应该考虑的4个方面,还有优雅设计的6个原则,举了一个例子分享了我的设计思路,为了提高性能我们也要从多方面考虑缓存问题。
王中阳Go赞 4阅读 1.7k评论 2
一分钟搞明白!快速掌握 Go WebAssembly
最近因为各种奇怪的原因,更多的接触到了 WebAssembly。虽然之前很多博客也翻过写过各种文章,但总感觉欠些味道。于是今天梳理了一版,和大家一起展开学习。
煎鱼赞 4阅读 2.2k
面试官:请说一下如何优化结构体的性能?
使用内存对齐机制优化结构体性能,妙啊!前言之前分享过2篇结构体文章:10秒改struct性能直接提升15%,产品姐姐都夸我好棒 和 Go语言空结构体这3种妙用,你知道吗? 得到了大家的好评。这篇继续分享进阶内容:结...
王中阳Go赞 4阅读 3.8k评论 2
Laravel入门及实践,快速上手ThinkSNS+二次开发
【摘要】自从ThinkSNS+不使用ThinkPHP框架而使用Laravel框架之后,很多人都说技术门槛抬高了,其实你与TS+的距离仅仅只是学习一个新框架而已,所以,我们今天来说说Laravel的入门。
ThinkSNS赞 1阅读 2.4k
我让chatGPT用PHP写一个MVC框架,不仅写出来,还能跑!
没想到写出来的框架确实挺简单的,但是又没觉得哪里不对,于是我尝试把这个框架放到服务器试试能不能跑起来,最后还真的可以跑起来,为了让大家能够看到这个框架的演示,我直接爬一个热搜,然后便于展示数据。
TANKING赞 1阅读 1.7k
开发一个全网搜索引擎的大致流程
由于对搜索引擎技术很感兴趣,便开始尝试开发一个搜索引擎。在参考了网上有限的资料后,加上自己钻研,最终开发出了一个小型的全网搜索引擎,底部有项目地址和搜索测试图片。
会飞的鸟赞 1阅读 5.7k评论 1
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。