• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PHP多进程通信-消息队列使用

    向消息队列发送数据和获取数据的测试

    ?php
    $key=ftok(__FILE__,'a');
    
    //获取消息队列
    $queue=msg_get_queue($key,0666);
    //发送消息
    //msg_send($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个子进程来进行处理。
     * 
     */
    
    //设定脚本永不超时
    set_time_limit(0);
    $ftok = ftok(__FILE__, 'a');
    $msg_queue = msg_get_queue($ftok);
    $pidarr = []; 
    
    //产生子进程
    $pid = pcntl_fork();
    if ($pid) {
     //父进程模拟生成一个特大的数组。
     $arr = range(1,100000);
     //将任务放进队里,让多个子进程并行处理
     foreach ($arr as $val) {
      $status = msg_send($msg_queue,1, $val);
      usleep(1000);
     } 
     $pidarr[] = $pid;
     msg_remove_queue($msg_queue);
    } else {
     //子进程收到任务后,fork10个子进程来处理任务。
     for ($i =0; $i10; $i++) {
      $childpid = pcntl_fork();
      if ($childpid) {
       $pidarr[] = $childpid; //收集子进程processid
      } else {
       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) {
       unset($pidarr[$key]);
      } 
     } 
     sleep(1);
    }

    以上所述是小编给大家介绍的PHP通信-消息队列使用详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    您可能感兴趣的文章:
    • PHP如何限制定时任务的进程数量
    • PHP基于进程控制函数实现多线程
    • PHP程序守护进程化实现方法详解
    • 一文看懂PHP进程管理器php-fpm
    • php多进程中的阻塞与非阻塞操作实例分析
    • php多进程并发编程防止出现僵尸进程的方法分析
    • 浅谈PHP进程管理
    • php多进程模拟并发事务产生的问题小结
    • 浅谈并发处理PHP进程间通信之外部介质
    上一篇:浅谈PHP匿名函数和闭包
    下一篇:浅谈PHP进程管理
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    PHP多进程通信-消息队列使用 PHP,多,进程,通信,消息,队列,