-
rabbitmq 依赖于依赖于Erlang,需要先安装Erlang,地址:http://www.erlang.org/downloads(当前为23.1版本64位)
-
(方便ERL程序对引用包的调用,可省略)
(1) 下载完成后安装。
win10 设置环境变量 计算机—>属性—>高级系统设置—>环境变量
(2)安装完成后设置ERLANG_HOME为刚才的安装目录
(3)然后在用户变量PATH中添加上**%ERLANG_HOME%\bin**
(4)环境变量安装好后,打开cmd 输出erl 出现提示信息则说明环境变量配置成功
![安装的erl的当前的版本号](https://img-blog.csdnimg.cn/20200928151425976.png#pic_center -
下载并安装rabbitmq windown版
https://www.rabbitmq.com/
点击右侧的updates下任一个版本查看版本说明(当前rabbitmq版本3.88需要至少erlang
版本至少21.3,本地安装的erlang版本大于这个版本即可)
4. 安装过程自带安装management可视化页面,我们打开 127.0.0.1:15672 访问 账号guest 密码guest
-
以上安装rabbit服务端完成,如果我们想用php操作rabbimq服务,则需要安装php扩展 amqp 查看本地的php版本信息
到https://pecl.php.net/package/amqp下载对应的扩展(对应的版本,64位,非安全线程)下载完成压缩包中的文件如下如图
php_amqp.dll 放在php的exten扩展目录并在php.ini中添加 extension=php_amqp.dll ,
把rabbitmq.4.dll放在php根目录(即有php.exe的目录) 并在apache的配置文件 加载该链接库,
即在httpd.conf 添加 LoadFile “D:/phpstudy_pro/Extensions/php/php7.3.4nts/rabbitmq.4.dll”.
以上没有问题的话就可以在php配置信息里面看到amqp扩展
6 以上环境安装完后就可以写php的代码了,简单原理 发送端服务开启.客户端开启,生产者推送消息到rabbitmq,只要rabbitmq有数据,消费端开启状态下,消费端就会从rabbitmq取数据。发送端的send.php代码
//发送消息
$conn_args = array(
'host' => 'localhost',
'port' => '5672',
'login' => 'guest', //默认的用户名和密码
'password' => 'guest',
'vhost' => '/',
);
$e_name = 'emailExchange'; //交换机名
//$q_name = 'q_linvo'; //无需队列名
$k_route = 'route_key'; //路由key 与
//创建连接和channel
$conn = new AMQPConnection($conn_args);
if (!$conn->connect()) {
die("Cannot connect to the broker!\n");
}
$channel = new AMQPChannel($conn);
//消息内容
$message = "your mother call your back home now!!!";
//创建交换机对象
$ex = new AMQPExchange($channel);
$ex->setName($e_name);
$ex->setType(AMQP_EX_TYPE_DIRECT); //投递机制,精准投递,这个我们在消费端设置即可
$ex->setFlags(AMQP_DURABLE);//持久化设置
$ex->declareExchange();
//发送消息
//$channel->startTransaction(); //开始事务
//for($i=0; $i<5; ++$i){
//如果需要进行消息持久化机制的话,则进行如下设置
//$ex->publish($message,$k_route,AMQP_NOPARAM,array());//如果delivery是1的话,则表明是非持久化,持久化的时候注意使用AUTOASK。则处理完的消息可以自动删除
//不需要的话则进行这样:$ex->publish($message, $k_route,AMQP_NOPARAM,array('delivery_mode'=>2, 'priority'=> 9));
// echo "Send Message:".$ex->publish($message, $k_route)."\n";
//}
//$channel->commitTransaction(); //提交事务
$i = 0;
while (true) {
$i++;
if ($i > 1000) {
break;
}
echo "Send Message:" . $ex->publish($message ,$k_route) . "\n";
echo "Send Message Content:" . $message . $k_route . "\n";
}
$conn->disconnect();
接收端rev.php的代码:
/配置信息
$conn_args = array(
'host' => '127.0.0.1',
'port' => '5672',
'login' => 'guest',
'password' => 'guest',
'vhost' => '/'
);
$e_name = 'emailExchange'; //交换机名
$q_name = 'email1'; //队列名
$k_route = 'route_key'; //路由key
//创建连接和channel
$conn = new AMQPConnection($conn_args);
if (!$conn->connect()) {
die("Cannot connect to the broker!\n");
}
$channel = new AMQPChannel($conn); //只需要创建这一个即可,至于为什么多一个channel就不知道了
//创建交换机
$ex = new AMQPExchange($channel);
$ex->setName($e_name);
$ex->setType(AMQP_EX_TYPE_DIRECT); //direct类型 ,精准投递,根据交换机publish的路由信息队列绑定时才会进行
$ex->setFlags(AMQP_DURABLE); //持久化 ,支持rabbitMq重启时交换机自动恢复
echo "Exchange Status:" . $ex->declareExchange() . "\n"; //查看如果交换机不存在则进行创建
//创建队列
$q = new AMQPQueue($channel);
$q->setName($q_name);
$q->setFlags(AMQP_DURABLE); //队列持久化
echo "Message Total:" . $q->declareQueue() . "\n"; //同样,如果不存在则创建
//绑定交换机与队列,并指定路由键
echo 'Queue Bind: ' . $q->bind($e_name, $k_route) . "\n"; //绑定路由,只处理投递指定$k_route的消息
//阻塞模式接收消息
echo "Message:\n";
while (True) {
$q->consume('processMessage');
//$q->consume('processMessage', AMQP_AUTOACK); //自动ACK应答
}
$conn->disconnect();
/**
* 消费回调函数
* 处理消息
*/
function processMessage($envelope, $queue)
{
$msg = $envelope->getBody();
echo $msg . "\n"; //处理消息
$queue->ack($envelope->getDeliveryTag()); //手动发送ACK应答
}
命令行运行 php send.php php rev.php