rabbitmq 使用PhpAmqpLib
rabbitmq类
rabbitmq.php
<?php require_once __DIR__ . '/vendor/autoload.php'; use PhpAmqpLib\Connection\AMQPStreamConnection; use PhpAmqpLib\Message\AMQPMessage; abstract class rabbitmq
{
//MQ的默认连接配置
public $config = array(
'host' => '192.168.33.50', //ip
'port' => '5672', //端口号
'user' => 'admin', //用户
'password' => 'admin', //密码
'vhost' => '/' //虚拟host
);
public $connection; //链接
public $channel; //信道 public $exchangeName = ''; //交换机名
public $queueName = ''; //队列名
public $routeKey = ''; //路由键
public $exchangeType = 'direct'; //交换机类型 public $autoAck = true; //是否自动ack应答 public function __construct($exchangeName, $queueName, $routeKey, $exchangeType = 'direct', $config=array())
{
$this->exchangeName = empty($exchangeName) ? '' : $exchangeName;
$this->queueName = empty($queueName) ? '' : $queueName;
$this->routeKey = empty($routeKey) ? '' : $routeKey;
$this->exchangeType = empty($exchangeType) ? '' : 'direct';
if(!empty($config))
{
$this->setConfig($config);
}
$this->createConnect();
} //创建连接与信道
private function createConnect()
{
$host = $this->config['host'];
$port = $this->config['port'];
$user = $this->config['user'];
$password = $this->config['password'];
$vhost = $this->config['vhost'];
if(empty($host) || empty($port) || empty($user) || empty($password))
{
throw new Exception('RabbitMQ的连接配置不正确');
}
//创建链接
$this->connection = new AMQPStreamConnection($host, $port, $user, $password, $vhost);
//创建信道
$this->channel = $this->connection->channel();
$this->createExchange();
} //创建交换机
private function createExchange()
{
//创建交换机$channel->exchange_declare($exhcange_name,$type,$passive,$durable,$auto_delete);
//passive: 消极处理, 判断是否存在队列,存在则返回,不存在直接抛出 PhpAmqpLib\Exception\AMQPProtocolChannelException 异常
//durable:true、false true:服务器重启会保留下来Exchange。警告:仅设置此选项,不代表消息持久化。即不保证重启后消息还在
//autoDelete:true、false.true:当已经没有消费者时,服务器是否可以删除该Exchange
$this->channel->exchange_declare($this->exchangeName, $this->exchangeType, false, true, false);
//passive: 消极处理, 判断是否存在队列,存在则返回,不存在直接抛出 PhpAmqpLib\Exception\AMQPProtocolChannelException 异常
//durable:true、false true:在服务器重启时,能够存活
//exclusive :是否为当前连接的专用队列,在连接断开后,会自动删除该队列
//autodelete:当没有任何消费者使用时,自动删除该队列
//arguments: 自定义规则
$this->channel->queue_declare($this->queueName, false, true, false, false);
} //发送消息
public function sendMessage($data)
{
//创建消息$msg = new AMQPMessage($data,$properties)
//#$data string类型 要发送的消息
//#roperties array类型 设置的属性,比如设置该消息持久化[‘delivery_mode’=>2]
$msg = new AMQPMessage($data, array('delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));
$this->channel->basic_publish($msg,$this->exchangeName, $this->routeKey);
} //处理消息
public function dealMq($flag)
{
$this->autoAck = $flag;
$this->channel->queue_bind($this->queueName,$this->exchangeName, $this->routeKey);
//prefetchSize:0
//prefetchCount:会告诉RabbitMQ不要同时给一个消费者推送多于N个消息,即一旦有N个消息还没有ack,则该consumer将block掉,直到有消息ack
//global:true\false 是否将上面设置应用于channel,简单点说,就是上面限制是channel级别的还是consumer级别
//$this->channel->basic_qos(0, 1, false);
//1:queue 要取得消息的队列名
//2:consumer_tag 消费者标签
//3:no_local false这个功能属于AMQP的标准,但是rabbitMQ并没有做实现.参考
//4:no_ack false收到消息后,是否不需要回复确认即被认为被消费
//5:exclusive false排他消费者,即这个队列只能由一个消费者消费.适用于任务不允许进行并发处理的情况下.比如系统对接
//6:nowait false不返回执行结果,但是如果排他开启的话,则必须需要等待结果的,如果两个一起开就会报错
//7:callback null回调函数
//8:ticket null
//9:arguments null
$this->channel->basic_consume($this->queueName, '', false, $this->autoAck, false, false, function($msg){$this->get($msg);});
//监听消息
while(count($this->channel->callbacks)){
$this->channel->wait();
}
} public function get($msg)
{
$param = $msg->body;
$this->doProcess($param);
if(!$this->autoAck)
{
//手动ack应答
$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);
}
} abstract public function doProcess($param); public function closeConnetct()
{
$this->channel->close();
$this->connection->close();
} //重新设置MQ的链接配置
public function setConfig($config)
{
if (!is_array($config)) {
throw new Exception('config不是一个数组');
}
foreach ($config as $key => $value) {
$this->config[$key] = $value;
} } }
send.php
<?php
include_once('rabbitmq.php');
class Publisher extends rabbitmq
{
public function __construct()
{
parent::__construct('crm', 'crm_test', 'crm_test');
}
public function doProcess($msg)
{ } } $publisher = new Publisher();
for($i=0;$i<100000;$i++){
$publisher->sendMessage('Hello,World!');
} $publisher->closeConnetct();
consumer.php
<?php
include_once('rabbitmq.php');
class Consumer extends rabbitmq
{
public function __construct()
{
parent::__construct('crm', 'crm_test', 'crm_test');
}
public function doProcess($msg)
{
echo $msg."\n";
}
}
$consumer = new Consumer();
//$consumer->dealMq(false);
$consumer->dealMq(false);
rabbitmq 使用PhpAmqpLib的更多相关文章
- RabbitMQ之php-amqplib使用
PHP下使用rabbitmq可以使用第三方类库来实现 技术参考: https://rabbitmq.shujuwajue.com/tutorials_with_php/[1]Hello_World.h ...
- PHP中RabbitMQ之phpAmqplib实现(五
本章讲诉如何使用php-amqplib实现RabbitMQ. 环境:CoentOS,PHP 7 简单介绍一下php-amqplib php-amqplib是Advanced Message Queui ...
- RabbitMQ的交换机类型(三)
RabbitMQ的交换机类型共有四种,是根据其路由过程的不同而划分成的 分别是Direct Exchange(直连交换机), Fanout Exchange(扇型交换机), Topic Excha ...
- Pythonpika PhpAmqpLib rabbitmq服务中queues被清空的异常处理 无模式数据库对数据结构的定义和控制
/** * Declares queue, creates if needed * * @param string $queue * @param bool $passive * @param boo ...
- php-amqplib库操作RabbitMQ
RabbitMQ基本原理 首先,建议去大概了解下RabbitMQ(以下简称mq)的基本工作原理,可以参考这篇文章最主要的几个对象如下 对象名称 borker 相当于mq server channe ...
- RabbitMq学习6-安装php-amqplib(RabbitMQ的phpAPI)
一.使用composer安装php-amqplib 1.在你的项目中添加一个 composer.json文件: { "require": { "php-amqplib/p ...
- 安装php-amqplib(RabbitMQ的phpAPI)
历史经验告诉我们,装逼没有好下场. 总结一下之前composer安装php-amqplib包失败的原因: composer安装的时候需要指定PHP执行文件的位置: PHP安装路径:/usr/local ...
- Linux rabbitmq的安装和安装amqp的php插件
RabbitMQ是一个消息代理.它的核心原理非常简单:接收和发送消息.你可以把它想像成一个邮局:你把信件放入邮箱,邮递员就会把信件投递到你的收件人处.在这个比喻中,RabbitMQ是一个邮箱.邮局.邮 ...
- rabbitmq - (消息队列) 的基本原理介绍
介绍 MQ全称为Message Queue, 是一种分布式应用程序的的通信方法,它是消费-生产者模型的一个典型的代表,producer往消息队列中不断写入消息,而另一端consumer则可以读取或者订 ...
随机推荐
- 苹果系统安装虚拟机 Mac如何安装虚拟机教程 (含系统镜像的下载地址)
镜像下载地址 http://www.itellyou.cn 1.前言 大家在用 Mac 系统的时候,可能有时难免还是要用到 Windows 系统.在 Mac 上使用 Windows 系统有二种方 ...
- Tomcat 80端口被占用
1.“运行”中输入cmd2.在命令行中输入netstat -ano,得到端口号对应的PID 3.打开任务管理器,点击“查看“菜单,选择“选择列”,给进程列表中添加”PID“列,然后找到PID对应的进程 ...
- nginx重新编译不停服
找到安装nginx的源码根目录,如果没有就下载新的安装包 .tar.gz 查看ngixn版本极其编译参数 /usr/local/nginx/sbin/nginx -V 进入nginx源码目录 cd n ...
- checklist和基础安全知识
checklist和基础安全知识 https://book.yunzhan365.com/umta/rtnp/mobile/index.html 网络安全科普小册子 http://sec.cuc.ed ...
- socket之IO多路复用
概述 目的:同一个线程同时处理多个IO请求. 本文以python的select模块来实现socket编程中一个server同时处理多个client请求的问题. web框架tornado就是以此实现多客 ...
- 《精通并发与Netty》学习笔记(11 - 详解NIO (二) 分散/聚集 Scatter/Gather、Selector)
一.分散/聚集 Scatter/Gather scatter/gather指的在多个缓冲区上实现一个简单的I/O操作,比如从通道中读取数据到多个缓冲区,或从多个缓冲区中写入数据到通道:scatter( ...
- 【FFMPEG】VS2013编译ffmpeg
原文:http://blog.csdn.net/uselym/article/details/49885867 由于VS2013支持c99了,所以,可以直接用vs2013进行ffmpeg的编译调试,而 ...
- js的new Date兼容iOS和Android
在写一个移动端的报名活动页面时,其中一个逻辑是:过了报名日期,“立即报名”按钮置灰,不允许报名:具体逻辑如下,在真机上测试的时候,Android端可以把按钮失效,iOS则是无法把按钮失效.后台返回的时 ...
- JavaScript里的类和继承(转)
转自: http://www.h5cn.com/js/jishu/2016/0121/17634.html js与大部分客户端语言有几点明显的不同: JS是 动态解释性语言,没有编译过程,它在程序运行 ...
- Rocketmq-简单部署
一.准备环境 1.系统:Centos7.3(无硬性要求) 2. jdk:1.8 3.maven:3.5(无硬性要求) 4.git 5.rocketmq 4.2 二.环境部署 1.jdk1.8以及mav ...