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

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

1.php代码如下:

<?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代码如下:

<?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);
}

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

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

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

2.php代码如下:

<?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代码如下:

<?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);
}

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

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

时间: 2024-12-19 14:01:14

php ActiveMQ的发送消息,与处理消息的相关文章

ActiveMQ 发送和就收消息

一.添加 jar 包 <dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-all</artifactId> <version>5.11.2</version> </dependency> 二.消息传递的两种形式 1.点对点:发送的消息只能被一个消费者接收,第一个消费者接收后,消息没了 2.发布/订阅:消息可以被多个消费

解决Springboot整合ActiveMQ发送和接收topic消息的问题

环境搭建 1.创建maven项目(jar) 2.pom.xml添加依赖 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.0.RELEASE</version> </parent> <dependencies> &l

ActiveMQ发消息和收消息

来自:http://blog.163.com/chengwei_1104/blog/static/53645274201382315625329/ ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位. 下面详细的解释常用类的作用 ConnectionFactory 接口(连接工厂) 用

JMS服务器ActiveMQ的初体验并持久化消息到MySQL数据库中

JMS服务器ActiveMQ的初体验并持久化消息到MySQL数据库中 一.JMS的理解JMS(Java Message Service)是jcp组织02-03年定义了jsr914规范(http://jcp.org/en/jsr/detail?id=914),它定义了消息的格式和消息传递模式:消息包括:消息头,消息扩展属性和消息体,其结构看起来与SOAP非常的相似,但一般情况下,SOAP主要关注远程服务调用,而消息则专注于信息的交换:消息分为:消息生产者,消息服务器和消息消费者.生产者与消费者之间

ActiveMQ 确认机制ACK(收到消息后,应该有一个回应也就是确认答复)

一.ACK机制简介 ACK (Acknowledgement),即确认字符,在数据通信中,接收站发给发送站的一种传输类控制字符.表示发来的数据已确认接收无误. JMS API中约定了Client端可以使用四种ACK_MODE,在javax.jms.Session接口中: AUTO_ACKNOWLEDGE = 1    自动确认 CLIENT_ACKNOWLEDGE = 2    客户端手动确认 DUPS_OK_ACKNOWLEDGE = 3    自动批量确认 SESSION_TRANSACTE

ActiveMQ的学习(三)(ActiveMQ的消息事务和消息的确认机制)

ActiveMQ的消息事务 消息事务,是保证消息传递原子性的一个重要特性,和JDBC的事务特征类似. 一个事务性发送,其中一组消息要么能够全部保证到达服务器,要么都不到达服务器.生产者,消费者与消息服务器都支持事务性.ActiveMQ得事务主要偏向在生产者得应用. ActiveMQ消息事务流程图: 原生jms事务发送(生产者的事务发送) 不加事务得情况:(程序没有错误,10条消息会到达mq中) 不加事务得情况:(程序有错误,结果是发送成功3条,其余不成功---因为没有加事务) 加事务得情况:(程

java 发送微信客服消息

? 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 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 package com.baosight.wechat.service; import net.sf.json.JSONObject;

你知道吗,msg也能发送多行的消息

熟悉命令行的人都知道msg消息发送工具,但它之能发送单行的信息,但用一些小技巧我们就可以让它一次发送多行的消息,譬如在消息中间加入批处理换行符,下面是参考代码: @echo off setlocal enabledelayedexpansion set title=批处理换行符命令脚本 title %title% echo %title% echo. rem 下面的空行不能省略 set p=!^ ! msg %username% /w "这里是 第1行!p!这里是 第2行!p!!p!这里是 第4

JAX-WS创建和JavaAPI发送和处理SOAP消息实例

JAX-WS规范是一组XML web services的JAVA API,在 JAX-WS中,一个远程调用可以转换为一个基于XML的协议例如SOAP,在使用JAX-WS过程中,开发者不需要编写任何生成和处理SOAP消息的代码.JAX-WS的运行时实现会将这些API的调用转换成为对应的SOAP消息. JAX-WS 也提供了一组针对底层消息进行操作的API调用,你可以通过Dispatch 直接使用SOAP消息或XML消息发送请求或者使用Provider处理SOAP或XML消息.通过web servi