zoukankan      html  css  js  c++  java
  • php 事务处理,ActiveMQ的发送消息,与处理消息

    可以通过链式发送->处理->发送。。。的方式处理类似事务型业务逻辑

    比如 发送一个注册消息,消息队列处理完注册以后,紧接着发送一个新手优惠券赠送,赠送完再发一个其它后续逻辑处理的消息等待后续队列处理

     

     

    php ActiveMQ的发送消息,与处理消息

    我们以一个简单的用户注册为例,当用户点击注册按钮后,我们发送一个消息,后台php接收到该消息然后处理。

    1.php代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    <?php
    $stomp new Stomp('tcp://192.168.1.222:61613');
     
    $obj new Stdclass();
    //下面这些数据,实际中是用户通过前端页面post来的,这里只做演示
    $obj->username = 'test';
    $obj->password = '123456';
    //发送一个注册消息到队列,我们这里模拟用户注册
    $stomp->send('/queue/userReg', json_encode($obj));

    2.php代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    <?php
    $stomp new Stomp('tcp://192.168.1.222:61613');
    //订阅只对一个有效,如果启动多个脚本,只有一个会接收到消息
    $stomp->subscribe('/queue/userReg');
     
    while(true) {
        //判断是否有读取的信息
        if($stomp->hasFrame()) {
            $frame $stomp->readFrame();
     
            $data = json_decode($frame->body, true);
            var_dump($data);
     
            //我们通过获取的数据
            //处理相应的逻辑,比如存入数据库,发送验证码等一系列操作。
            //$db->query("insert into user values('{$username}','{$password}')");
            //sendVerify();
     
            //表示消息被处理掉了,ack()函数很重要
            $stomp->ack($frame);
        }
        sleep(1);
    }

    分别运行上面两个脚本文件

    1
    2
    > /data/php56/bin/php 1.php
    > /data/php56/bin/php 2.php

    我们还可以把上面的2.php代码分成多步执行。

    2.php代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    <?php
    $stomp new Stomp('tcp://192.168.1.222:61613');
    $stomp->subscribe('/queue/userReg');
     
    while(true) {
        //判断是否有读取的信息
        if($stomp->hasFrame()) {
            $frame $stomp->readFrame();
     
            $data = json_decode($frame->body, true);
     
            //注册信息入库
            //$ret = db->query("insert into user values('{$data['username']}', '{$data['password']}')");
            //这里演示直接设成true了
            $ret = true;
            if($ret) {
                echo $data['username'], '入库成功', PHP_EOL;
                //如果入库成功,再次把数据发送到另一个消息队列中,进行下一步处理
                $stomp->send('/queue/sendVerify'$frame->body);
     
                $stomp->ack($frame);
            }
        }
        sleep(1);
    }

    3.php代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    <?php
    $stomp new Stomp('tcp://192.168.1.222:61613');
    $stomp->subscribe('/queue/sendVerify');
     
    while(true) {
        //判断是否有读取的信息
        if($stomp->hasFrame()) {
            $frame $stomp->readFrame();
     
            $data = json_decode($frame->body, true);
     
            //$ret = sendVerify()发送验证码,实际中应该是请求某接口
            $ret = true;
            if($ret) {
                echo $data['username'], '发送验证码成功', PHP_EOL;
     
                $stomp->ack($frame);
            }
        }
        sleep(1);
    }

    再次分别运行上面的三个脚本

    1
    2
    3
    > /data/php56/bin/php 1.php
    > /data/php56/bin/php 2.php
    > /data/php56/bin/php 3.php

  • 相关阅读:
    java json 库之 jackson
    java 多线程
    golang slice 和 string 重用
    golang 字节对齐
    golang 并发编程之生产者消费者
    golang 设计模式之选项模式
    golang aws-sdk-go 之 s3 服务
    markdown 一个优雅的写作工具
    常见句型、用法
    hg
  • 原文地址:https://www.cnblogs.com/dasn/p/8581106.html
Copyright © 2011-2022 走看看