资讯专栏INFORMATION COLUMN

进程间通信

Richard_Gao / 859人阅读

摘要:接受不到消息消息队列通过指定而被创建后,任意一方销毁了该队列,都会导致其他发送或接收方失败。用法场景进程,中代码段要用到中代码段的结果。完成了进程间同步问题此外进程间通信采用的方式是共享内存。

参考文章

深刻理解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

相关文章

  • PHP进程通信

    摘要:一进程间通信理解间进程通信机制,先了解下进程间有哪些通讯机制历史发展按照历史来源主要有两大块的管道,,信号的消息队列,共享内存,信号灯。信号量主要作为进程间,以及进程内部线程之间的通讯手段。主要依赖,兼容扩展实现方式的进程间通信之消息队列。 PHP间进程如何通信,PHP相关的服务的IPC是实现方式,IPC的思想如何用到项目中。 一、linux进程间通信 理解php间进程通信机制,先了解...

    haobowd 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<