linux ubuntu安装rabbitmq,Ubuntu 16.04配置 RabbitMQ 服务

本文详细介绍了在Ubuntu 16.04和17.10上安装RabbitMQ的步骤,包括添加源、配置公钥、更新安装服务及启用管理页面。此外,还讲解了RabbitMQ的基本函数,如连接、定义交换机和队列、发送和接收消息、回调处理以及关闭连接。提供了一个完整的PHP示例来展示如何与RabbitMQ交互。
摘要由CSDN通过智能技术生成

1.首先,添加相应的源

在 Ubuntu 16.04 下

echo "deb https://dl.bintray.com/rabbitmq/debian xenial main" | sudo tee /etc/apt/sources.list.d/bintray.rabbitmq.list

在 Ubuntu 17.10 下

echo "deb https://dl.bintray.com/rabbitmq/debian artful main" | sudo tee /etc/apt/sources.list.d/bintray.rabbitmq.list

2.配置公钥

wget -O- https://www.rabbitmq.com/rabbitmq-release-signing-key.asc | sudo apt-key add -

3. 更新并安装服务

sudo apt-get update

sudo apt-get install rabbitmq-serve

安装结束后默认是运行的

invoke-rc.d rabbitmq-server stop/start  //可以运行,该代码进行开启或关闭

开启页面管理

rabbitmq-plugins enable rabbitmq_management

运行该代码即可访问 http://localhost:15672/ 进行页面管理

9f1cce15a7902e612a5b1e2066e9eea4.png

以上,安装RabbitMQ 服务就完成了。

RabbitMQ一些基本函数介绍

1.连接

// 连接服务,获取句柄

$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');

$connection->isConnected() or die("Cannot connect to the broker!\n");

$channel = $connection->channel();

2.定义

//direct:在direct类型的exchange中,只有这两个routingkey完全相同,exchange才会选择对应的binging进行消息路由。

//fanout:此exchange的路由规则很简单直接将消息路由到所有绑定的队列中,无须对消息的routingkey进行匹配操作。

//topic:此类型exchange和上面的direct类型差不多,这里的routingkey可以有通配符:'*','#' ,其中'*'表示匹配一个单词,

// '#'则表示匹配没有或者多个单词,对 key 进行模式匹配,比如 ab* 可以传递到所有 ab* 的 queue

// headers : 不常用

$channel->exchange_declare('demo', 'direct'); //声明交换机,相当于定义规则

//passive: 消极处理, 判断是否存在队列,存在则返回,不存在直接抛出 PhpAmqpLib\Exception\AMQPProtocolChannelException 异常

//durable:true、false true:在服务器重启时,能够存活

//exclusive :是否为当前连接的专用队列,在连接断开后,会自动删除该队列,生产环境中应该很少用到吧。

//autodelete:当没有任何消费者使用时,自动删除该队列

//nowait : 相当于一个async版的声明队列,可以看到是没有返回的。调完方法就结束。也不等队列创建结果

//auto_delete: 当所有消费客户端连接断开后,是否自动删除队列

//arguments: 附加参数,规则设置

$channel->queue_declare('kzae', false, false, false, false);

//队列绑定交换机

$channel->queue_bind('hello','amq.direct', 'bbb');

3.发送

//mandatory标志告诉服务器至少将该消息route到一个队列中,否则将消息返还给生产者;

//immediate标志告诉服务器如果该消息关联的queue上有消费者,则马上将消息投递给它,如果所有queue都没有消费者,

//直接把消息返还给生产者,不用将消息入队列等待消费者了

$channel->basic_publish($msg, 'amq.direct', 'bbb');

4.接收

//采用 no-ack 的方式进行确认,也就是说,每次 Consumer 接到数据后,不管是否处理完成,RabbitMQ Server 会立即把这个 Message 标记为完成,然后从 Queue 中删除

$channel->basic_consume('hello', '', false, false, false, false, $callback);

5.回调

$callback = function(PhpAmqpLib\Message\AMQPMessage $msg) {

echo " [x] Received ", $msg->body, "\n";

//delivery_info['channel']: PhpAmqpLib\Channel\AMQPChannel

var_dump($msg->delivery_info);

$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']); //确认ack

};

6. 结束

$channel->close();

$connection->close();

RabbitMQ 的详细介绍:请点这里

RabbitMQ 的下载地址:请点这里

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值