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

 

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

 

 

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

posted on 2018-03-16 14:29  mynetstudy  阅读(260)  评论(0编辑  收藏  举报