CentOS 7 安装rabbitmq

对于windows安装php rabbitmq扩展

https://www.cnblogs.com/88phper/p/8296066.html

 

1. 下载rabbitmq依赖的库 librabbitmq

mkdir php-rabbitmq
cd php-rabbitmq
wget https://github.com/alanxz/rabbitmq-c/archive/v0.9.0.tar.gz

 tar xvzf v0.9.0.tar.gz 
cd rabbitmq-c-0.9.0/

mkdir build

cd build

# 让cmake根据../CMakeList.txt,即rabbitmq-c的根目录下的CMakeList.txt创建Makefile文件,Makefile文件会被创建到build目录中

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/librabbitmq ..
cmake --build .

make

sudo make install

php rabbitmq 的扩展安装_回调方法

2. 安装php扩展

cd ../../

wget http://pecl.php.net/get/amqp-1.9.0.tgz

tar xvzf amqp-1.9.0.tgz 
cd amqp-1.9.0
phpize

php rabbitmq 的扩展安装_消息队列_02

# 找到php-config的路径

sudo yum install mlocate

sudo updatedb

sudo locate php-config

# 安装librabbitmq开发包

yum install librabbitmq-devel
./configure --with-php-config=/www/server/php/56/bin/php-config --with-amqp --with-librabbitmq-dir=/usr/local/librabbitmq

make -j2

$ sudo make install
Installing shared extensions:     /www/server/php/56/lib/php/extensions/no-debug-non-zts-20131226/

php -i |grep php.ini

php rabbitmq 的扩展安装_回调方法_03

extension=amqp.so #extension_dir自己定义
service php-fpm restart #重启

php rabbitmq 的扩展安装_消息队列_04

php rabbitmq 的扩展安装_php_05

一个简单的生产者消费者示例

* consumer.php

<?php
//声明连接参数
$config = array(
    'host' => '192.168.1.1',
    'vhost' => '/',
    'port' => 5672,
    'login' => '******',
    'password' => '******'
);

//连接broker
$cnn = new AMQPConnection($config);
if (!$cnn->connect()) {
    echo "Cannot connect to the broker";
    exit();
}
//在连接内创建一个通道
$ch = new AMQPChannel($cnn);
//创建一个交换机
$ex = new AMQPExchange($ch);
//声明路由键
$routingKey = 'key_1';
//声明交换机名称
$exchangeName = 'exchange_1';
//设置交换机名称
$ex->setName($exchangeName);
//设置交换机类型
//AMQP_EX_TYPE_DIRECT:直连交换机
//AMQP_EX_TYPE_FANOUT:扇形交换机
//AMQP_EX_TYPE_HEADERS:头交换机
//AMQP_EX_TYPE_TOPIC:主题交换机
$ex->setType(AMQP_EX_TYPE_DIRECT);
//设置交换机持久
$ex->setFlags(AMQP_DURABLE);
//声明交换机
$ex->declareExchange();
//创建一个消息队列
$q = new AMQPQueue($ch);
//设置队列名称
$q->setName('queue_1');
//设置队列持久
$q->setFlags(AMQP_DURABLE);
//声明消息队列
$q->declareQueue();
//交换机和队列通过$routingKey进行绑定
$q->bind($ex->getName(), $routingKey);
//设置消息队列消费者回调方法,并进行阻塞
$q->consume(function($envelope, $queue) {
   //接收消息并进行处理的回调方法
    sleep(2);
    //echo消息内容
    echo $envelope->getBody()."\n";
    //显式确认,队列收到消费者显式确认后,会删除该消息
    $queue->ack($envelope->getDeliveryTag());
});
//$q->consume("receive", AMQP_AUTOACK);//隐式确认,不推荐

生产者

* publisher.php

<?php

$config = array(
    'host' => '192.168.1.1',
    'vhost' => '/',
    'port' => 5672,
    'login' => '******',
    'password' => '******'
);

$cnn = new AMQPConnection($config);
if (!$cnn->connect()) {
    echo "Cannot connect to the broker";
    exit();
}

$ch = new AMQPChannel($cnn);
$ex = new AMQPExchange($ch);
//消息的路由键,一定要和消费者端一致
$routingKey = 'key_1';
//交换机名称,一定要和消费者端一致,
$exchangeName = 'exchange_1';
$ex->setName($exchangeName);
$ex->setType(AMQP_EX_TYPE_DIRECT);
$ex->setFlags(AMQP_DURABLE);
$ex->declareExchange();

//创建10个消息
for ($i=1;$i<=10;$i++){
	//消息内容
    $msg = array(
        'data'  => 'message_'.$i,
        'hello' => 'world',
    );
    //发送消息到交换机,并返回发送结果
    //delivery_mode:2声明消息持久,持久的队列+持久的消息在RabbitMQ重启后才不会丢失
    echo "Send Message:".$ex->publish(json_encode($msg), $routingKey, AMQP_NOPARAM, array('delivery_mode' => 2))."\n";
    //代码执行完毕后进程会自动退出
}

启动消费者

php rabbitmq 的扩展安装_rabbitmq_06

启动生产者

php rabbitmq 的扩展安装_rabbitmq_07

很快执行完了

查看消费者:

php rabbitmq 的扩展安装_显式_08

一个一个消费