/**
* 消息列队服务
* @author zhou.tingze
* @example
* -----------------------------------Create----------------------------------------
* $array = array('a','b','c','d');
* $this->load->library('amqp_service');
* $this->amqp_service->setSaveType('test_exchange', 'test_queue', 'test_router');
* $this->amqp_service->createMessageQueue($array);
* -----------------------------------End-------------------------------------------
*
* -----------------------------------Get-------------------------------------------
* $this->load->library('amqp_service');
* $this->amqp_service->setSaveType('test_exchange', 'test_queue', 'test_router');
* $message_queue = $this->amqp_service->getMessageQueue();
* var_dump($message_queue)
* -----------------------------------End-------------------------------------------
*/ class Amqp_service extends Base_service{ public $conn;
public $exchange;
public $queue;
public $router; function __construct(){
parent:: __construct(); //获取系统配置
$this->load->config('app_config', TRUE);
$app_config = $this->config->item('app_config'); $this->connect($app_config['amqp']);
} /**
*
* 尝试连接Amqp服务
*/
private function connect($amqp_args)
{
$this->conn = new AMQPConnection($amqp_args);
$this->conn->connect(); if (!$this->conn->isConnected())
{
throw new Exception('Cannot connect to the broker.');
}
} /**
*
* 设定消息列队保存方式
* @param String $exchange_name 交换机名
* @param String $queue_name 消息列队名
* @param String $router_name 路由名
*/
public function setSaveType($exchange_name, $queue_name, $router_name)
{
$this->exchange = $exchange_name;
$this->queue = $queue_name;
$this->router = $router_name;
} /**
*
* 创建消息列队
* @param Array $array
*/
public function createMessageQueue($array)
{
//创建交换机
$channel = new AMQPChannel($this->conn);
$ex = new AMQPExchange($channel); //交换机名
$ex->setName($this->exchange);
$ex->setType(AMQP_EX_TYPE_DIRECT);
$ex->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
$ex->declare(); //创建消息列队
$q = new AMQPQueue($channel); //队列名
$q->setName($this->queue);
$q->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
$q->declare(); //绑定交换机与队列,并指定路由键
$q->bind($this->exchange, $this->router); //消息发布
$channel->startTransaction();
$message = json_encode($array);
$ex->publish($message, $this->router);
$channel->commitTransaction(); //$this->conn->disconnect();
} /**
*
* 获取消息列队
*/
public function getMessageQueue()
{
try
{
//设置queue名称,使用exchange,绑定routingkey
$channel = new AMQPChannel($this->conn);
$q = new AMQPQueue($channel); $q->setName($this->queue);
$q->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
$q->declare();
$q->bind($this->exchange, $this->router); //消息获取
$messages = $q->get(AMQP_AUTOACK) ; $arr = array();
if ($messages){
$arr = json_decode($messages->getBody(), true );
}
}catch (Exception $e){
throw new Exception($e->getMessage());
}
//$this->conn->disconnect(); return $arr;
} /*
public function getAllMessageQueue()
{
//设置queue名称,使用exchange,绑定routingkey
$channel = new AMQPChannel($this->conn);
$q = new AMQPQueue($channel); $q->setName($this->queue);
$q->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
$q->declare();
$q->bind($this->exchange, $this->router);
$this->conn->disconnect(); //阻塞模式获取消息列队
while(True){
$q->consume('processMessage');
//$q->consume('processMessage', AMQP_AUTOACK); //自动ACK应答
}
}
*/ public function __destruct()
{
$this->conn->disconnect();
}
} /**
* 消费回调函数
* 处理消息
* @param Object $envelope
* @param Object $queue
*/
/*
function processMessage($envelope, $queue) {
$msg = $envelope->getBody();
echo $msg . '<br />'; //手动发送ACK应答
$queue->ack($envelope->getDeliveryTag());
}
*/

  

在PHP中如何使用消息列队的更多相关文章

  1. C#操作消息列队

    首先安装消息队列MSMQ,在“计算机管理-服务和应用程序-消息队列-专用队列”中新建列队名称Demo: static void SendAndReceiveMsg() { MessageQueue m ...

  2. 消息列队 php 基于redis 实现

    说明 消息列队 基于PHP 实现. 之前 用python 的 flower 实现了 列队. 今天这里我们用的是 PHP 来实现: 在实际的业务环境中 PHP 用的多些: PHP 实现列队 最重要的是用 ...

  3. 消息列队 分布式事务解办法 celery flower使用总结

    前言 项目中有场景 需要用到 分布式事务业务,经过查下资料把学习相关笔记做记录方便他人或者自己后面查看. 场景 在网站A业务中有个操作 是 要在网站B中新建一台服务器跑业务.A中执行B中的接口创建服务 ...

  4. ZeroMQ接口函数之 :zmq_msg_recv - 从一个socket中接受一个消息帧

    ZeroMQ 官方地址 :http://api.zeromq.org/4-2:zmq_msg_recv zmq_msg_recv(3) ØMQ Manual - ØMQ/3.2.5 Name zmq_ ...

  5. 在WPF中处理Windows消息

    在Winform中 处理Windows消息通过重写WndProc方法 在WPF中 使用的是System.Windows. Sytem.Windows.Controls等名字空间,没有WndProc函数 ...

  6. 如何在项目中引入MetaQ消息收发机制

    当需要异步发送和接收大量消息时,需要在Crystal项目中引入MetaQ消息收发机制. 关于MetaQ使用的官方例子可参考:https://github.com/killme2008/Metamorp ...

  7. 微信小程序中发送模版消息注意事项

    在微信小程序中发送模版消息 参考微信公众平台Api文档地址:https://mp.weixin.qq.com/debug/wxadoc/dev/api/notice.html#模版消息管理 此参考地址 ...

  8. spring拦截器中修改响应消息头

    问题描述 前后端分离的项目,前端使用Vue,后端使用Spring MVC. 显然,需要解决浏览器跨域访问数据限制的问题,在此使用CROS协议解决. 由于该项目我在中期加入的,主要负责集成shiro框架 ...

  9. 即时通信系统中实现聊天消息加密,让通信更安全【低调赠送:C#开源即时通讯系统(支持广域网)——GGTalk4.5 最新源码】

    在即时通讯系统(IM)中,加密重要的通信消息,是一个常见的需求.尤其在一些政府部门的即时通信软件中(如税务系统),对即时聊天消息进行加密是非常重要的一个功能,因为谈话中可能会涉及到机密的数据.我在最新 ...

随机推荐

  1. C#_Fileuploadify_notMvc_description

    Uploadify Version 3.2 Options选项设置 auto 选择文件后自动上传 buttonClass 给“浏览按钮”加css的class样式 buttonCursor 鼠标移上去形 ...

  2. NetBeans 安装Android 开发环境

    基本的开发环境都是Eclipse + Android SDK + Android plugin for Eclipse NetBeans下开发Android的所需要的基本条件:NetBeans(包含J ...

  3. 《Entity Framework 6 Recipes》中文翻译——第九章EntityFramework在N层架构程序中的应用(七)

    在WCF服务中的序列化代理 问题 您有一个从查询返回的动态代理对象,你想要把它像POCO对象已经进行序列化.在序列化基于实体对象的POCO(普通旧CLR对象)时,实体框架会自动生成一个动态生成的派生类 ...

  4. Android(java)学习笔记81:java异常处理机制

    1.try....catch/try...catch...finally package cn.itcast_02; /* * 我们自己如何处理异常呢? * A:try...catch...final ...

  5. 使用 MJ 自定义下拉刷新

    // // ViewController.m // Refresh // // Created by Apple on 16/7/19. // Copyright © 2016年 mac. All r ...

  6. linux cd

    cd -回到上一次 操作的目录 cd ..回到上级目录 cd ../../回到上两级目录

  7. JDK的安装

    安装jdk解压拷贝过来的jdk(1.6版本)压缩包 cd /usr/local/tar xzvf /tmp/jdk.tgz 修改环境变量vi /etc/profile 加入如下内容export JAV ...

  8. 安装.Net framework 3.5 sp1报错的解决方法

    错误日志,提示: [11/22/07,18:04:40] Microsoft .NET Framework 2.0a: [2] Error: Installation failed for compo ...

  9. Android 内存分析工具 MAT(Memory Analyzer Tool)

    如果使用DDMS确实发现了我们的程序中存在内存泄漏,那又如何定位到具体出现问题的代码片段,最终找到问题所在呢?如果从头到尾的分析代码逻辑,那肯定 会把人逼疯,特别是在维护别人写的代码的时候.这里介绍一 ...

  10. asp.net上传大文件

    Asp.net默认允许上传文件的最大值为4M. 如果想要上传更大的文件,需要修改web.config文件,方法是: 在<system.web>节点中添加代码 <httpRuntime ...