Windows 安装 amqp 扩展

RabbitMQ 是基于 amqp(高级消息队列协议) 协议的。使用 RabbitMQ 前必须为 PHP 安装相应的 amqp 扩展。
  1. 下载相应版本的 amqp 扩展:http://pecl.php.net/package/amqp,解压缩文件。
  2. 将 php_amqp.dll 复制到 php 的扩展目录 ext 下,修改配置文件 php.ini:

    [amqp]
    extension=php_amqp.dll
  3. 将 rabbitmq.*.dll 文件复制到 php 的安装目录下,然后修改 Apache 配置文件 httpd.conf:

    #[rabbitmq]
    LoadFile "F:\wamp64\bin\php\php7.0.10\rabbitmq.*.dll"
  4. 重启服务器,查看 phpinfo,确认扩展信息。

Direct Exchange 模式

Direct Exchange 模式的交换机适合用于消息的单播发送. 交换机根据推送消息时的 routing key 和 队列的 routing key 判断消息应该推送到哪个队列. 可以实现同一交换机上的消息, 根据 routing key 推送到不同的队列中.

默认 Direct Exchange

此种模式下,使用 RabbitMQ 的默认 Exchange 即可,默认的 Exchange 是 Direct 模式。使用默认 Exchange 时,不需要对 Exchange 进行属性设置和声明,也不需要对 Queue 进行显示绑定和设置 routing key。Queue 默认会绑定到默认 Exchange,以及默认 routing key 与 Queue 的名称相同。

producer.php:
  1. 创建连接并发起连接
  2. 在连接上创建通道
  3. 在通道上获取默认交换机
  4. 向交换机发送消息
 header('Content-Type: text/html; charset=utf-8');
// 连接设置
$conConfig = [
  'host' => '127.0.0.1',
  'port' => 5672,
  'login' => 'root',
  'password' => 'root',
  'vhost' => '/'
];
try
{
  // RabbitMQ 连接实例
  $con = new AMQPConnection($conConfig);
  // 发起连接
  $con->connect();
  // 判断连接是否仍然有效
  if(!$con->isConnected())
  {
    echo '连接失败';die;
  }
  // 新建通道
  $channel = new AMQPChannel($con);
  // 使用RabbitMQ的默认Exchange
  $exchange = new AMQPExchange($channel);
  for($i = 1; $i < 6; $i++)
  {
    $message = [
      'name' => '默认交换机,消息-' . $i,
      'info' => 'Hello World!'
    ];
    // 发送消息,为消息指定routing key,成功返回true,失败false
    $state = $exchange->publish(json_encode($message, JSON_UNESCAPED_UNICODE), 'test.queue1');
    if($state)
    {
      echo 'Success' . PHP_EOL;
    }else
    {
      echo 'Fail' . PHP_EOL;
    }
  }
  // 关闭连接
  $con->disconnect();
}catch(Exception $e)
{
  echo $e->getMessage();
}
consumer.php:
  1. 创建连接并发起连接
  2. 在连接上创建通道
  3. 在通道上创建队列并声明队列
  4. 从队列获取消息
 header('Content-Type: text/html; charset=utf-8');
$conConfig = [
  'host' => '127.0.0.1',
  'port' => 5672,
  'login' => 'root',
  'password' => 'root',
  'vhost' => '/'
]; try
{
  $con = new AMQPConnection($conConfig);
  $con->connect();
  if(!$con->isConnected())
  {
    echo '连接失败';die;
  }   $channel = new AMQPChannel($con);   $queue = new AMQPQueue($channel);
  $queue->setName('test.queue1');
  // 声明队列,不需要对Queue进行显示绑定到交换机和指定Queue的routing key
  $queue->declareQueue();
  $queue->consume(function($envelope, $queue)
  {
    echo $envelope->getBody() . PHP_EOL;
  }, AMQP_AUTOACK);   $con->disconnect();
}catch(Exception $e)
{
  echo $e->getMessage();
}

自定义 Direct Exchange

producer:
header('Content-Type: text/html; charset=utf-8');
// 连接设置
$conConfig = [
  'host' => '127.0.0.1',
  'port' => 5672,
  'login' => 'root',
  'password' => 'root',
  'vhost' => '/'
];
try
{
  // RabbitMQ 连接实例
  $con = new AMQPConnection($conConfig);
  // 发起连接
  $con->connect();
  // 判断连接结果,true成功,false失败
  if(!$con->isConnected())
  {
    echo '连接失败';die;
  }
  // 新建通道
  $channel = new AMQPChannel($con);
  // 新建交换机
  $exchange = new AMQPExchange($channel);
  // 交换机名称
  $exchange->setName('test.direct');
  // 交换机类型
  $exchange->setType('direct');
  // 声明交换机
  $exchange->declareExchange();
  for($i = 1; $i < 6; $i++)
  {
    $message = [
      'name' => 'direct交换机,消息-' . $i,
      'info' => 'Hello World!'
    ];
    // 发送消息,同时为消息指定routing key,成功返回true,失败false
    $state = $exchange->publish(json_encode($message, JSON_UNESCAPED_UNICODE), 'test.queue1');
    if($state)
    {
      echo 'Success' . PHP_EOL;
    }else
    {
      echo 'Fail' . PHP_EOL;
    }
  }   // 关闭连接
  $con->disconnect();
}catch(Exception $e)
{
  echo $e->getMessage();
}
consumer:
 header('Content-Type: text/html; charset=utf-8');
$conConfig = [
  'host' => '127.0.0.1',
  'port' => 5672,
  'login' => 'root',
  'password' => 'root',
  'vhost' => '/'
]; try
{
  $con = new AMQPConnection($conConfig);
  $con->connect();
  if(!$con->isConnected())
  {
    echo '连接失败';die;
  }   $channel = new AMQPChannel($con);   $exchange =new AMQPExchange($channel);
  $exchange->setName("test.direct");
  $exchange->setType('direct');
  $exchange->setFlags(AMQP_DURABLE);
  $exchange->declareExchange();   $queue = new AMQPQueue($channel);
  $queue->setName('test.queue1');
  // 声明队列,不需要对Queue进行显示绑定到交换机和指定Queue的routing key
  $queue->declareQueue();
  // 绑定队列到指定交换机,并指定routing key,即分发规则,消息的routing key与队列的绑定routing key匹配时才
  $queue->bind('test.direct', 'test.queue1');
  $queue->consume(function($envelope, $queue)
  {
    echo $envelope->getBody() . PHP_EOL;
  }, AMQP_AUTOACK);   $con->disconnect();
}catch(Exception $e)
{
  echo $e->getMessage();
}

PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (一) -- 安装 AMQP 扩展和 Direct Exchange 模式的更多相关文章

  1. PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (四) -- Push API 和 Pull API

    RabbitMQ 中针对消息的分发提供了 Push API (订阅模式) 和 Pull API (主动获取) 两种模式. 在 PHP 中, 这两种模式分别通过 AMQPQueue 类中的 consum ...

  2. PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (三) -- Header Exchange

    此模式下,消息的routing key 和队列的 routing key 会被完全忽略,而是在交换机推送消息和队列绑定交换机时, 分别为消息和队列设置 headers 属性, 通过匹配消息和队列的 h ...

  3. PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (二) -- Topic Exchange 和 Fanout Exchange

    Topic Exchange 此模式下交换机,在推送消息时, 会根据消息的主题词和队列的主题词决定将消息推送到哪个队列. 交换机只会为 Queue 分发符合其指定的主题的消息. 向交换机发送消息时,消 ...

  4. PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (五) -- 自动 ACK、手动 ACK、NACK

    以 Direct 类型的 交换机和 Queue 的 get 方法为例. producer.php // 连接设置 $conConfig = [ 'host' => '127.0.0.1', 'p ...

  5. RabbitMQ简单介绍+Windows环境安装

    文章目录 1.RabbitMQ简介2.RabbitMQ与其他MQ有什么不同3.RabbitMQ环境安装3.1 安装erlang3.2 安装rabbitmq-server4. RabbitMQ管理平台介 ...

  6. gtk+3.0的环境配置及基于gtk+3.0的python简单样例

    /*********************************************************************  * Author  : Samson  * Date   ...

  7. AMQP消息队列之RabbitMQ简单示例

    前面一篇文章讲了如何快速搭建一个ActiveMQ的示例程序,ActiveMQ是JMS的实现,那这篇文章就再看下另外一种消息队列AMQP的代表实现RabbitMQ的简单示例吧.在具体讲解之前,先通过一个 ...

  8. Linux下,如何给PHP安装pdo_mysql扩展

    下载了一个免费开源的广告系统(openadserver),在Linux上安装时,提示要安装 pdo_mysql 扩展,先前有过编译安装 soap扩展 的经历,今天要编译安装 pdo_mysql 扩展, ...

  9. RabbitMQ基础知识及Linux安装

    RabbitMQ: RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现. AMQP协议: AMQP,即Advanced Message Qu ...

随机推荐

  1. 客户端与服务器持续同步解析(轮询,comet,WebSocket)

    在B/S模型的Web应用中,客户端常常需要保持和服务器的持续更新.这种对及时性要求比较高的应用比如:股票价格的查询,实时的商品价格,自动更新的twitter timeline以及基于浏览器的聊天系统( ...

  2. hash学习

    hash真奇妙 1.子串hash:如果我们要求一段子串的hash值,设h[i]:1-i的hash值,h[l-r]=h[r]-h[l-1]*pw[r-l+1],无论是模意义下还是自然溢出都是可以的 2. ...

  3. 关于使用java执行shell脚本获取centos的硬盘序列号和mac地址

    1.获取硬盘序列号: 新建shell脚本文件: identifier.sh, 内容为: diskdata=`fdisk -l` diskleft=${diskdata#*"identifie ...

  4. bzoj 4555: [Tjoi2016&Heoi2016]求和【NTT】

    暴力推式子推诚卷积形式,但是看好多blog说多项式求逆不知道是啥.. \[ \sum_{i=0}^{n}\sum_{j=0}^{n}S(i,j)*2^j*j! \] \[ S(i,j)=\frac{1 ...

  5. poj 3281 Dining【最大流】

    记得把牛拆掉!拆成两个点i和i'在中间连一条流量为1的边,来限制每头牛只能选一组 一般来讲是一种物品一个消费者各占一边,但是这里有两个物品,所以考虑把牛放在中间,s向所有的食物连流量为1的边,所有食物 ...

  6. bzoj1303[CQOI2008]中位数图 / 乱搞

    题目描述 给出1~n的一个排列,统计该排列有多少个长度为奇数的连续子序列的中位数是b.中位数是指把所有元素从小到大排列后,位于中间的数. 输入输出格式 输入格式: 第一行为两个正整数n和b,第二行为1 ...

  7. taskkill帮助信息

    taskkill帮助信息: C:\Users\xusweeter>taskkill /? TASKKILL [/S system [/U username [/P [password]]]] { ...

  8. ASP.NET CORE 使用 EF CORE访问数据库

    asp.net core通过ef core来访问数据库,这里用的是代码优先,通过迁移来同步数据库与模型. 环境:vs2017,win10,asp.net core 2.1 一.从建立asp.net c ...

  9. 加密解密(1)HTTPS与HTTP区别

    HTTPS简介 HTTPS(全称:Hypertext Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版.即 ...

  10. Java中的流(2)字节流-InputStream和OutputStream

    字节流的两个顶层类是抽象类:InputStream和OutputStream 1. OutputStream void write(int b) 往流中写一个字节b void write(byte b ...