RabbitMQ 入门

RabbitMQ 是对于AMQP协议的消息队列的一种实现,先了解AMQP队列,才能更方便的熟悉rabbitmq的概念

1.一些概念

AMQP 协议全称Advanced Message Queuing Protocol.是一个规定了客户端如何和消息中间件进行通讯的消息协议.

消息中间件(brokers),就是从 publishers (也就是所谓的生产者)接受消息,然后进行处理,转发给 consumers(消费者)

AMQP 是一个网络传输的协议, brokers,publishers,consumers 都是支持集群和扩展的.

Rabbitmq 就是扮演其中的 brokers. 目前支持的协议是 AMQP 0-9-1模型

2.AMQP

基本的消息流程类似图中所示

rabbitmq

Exchange 是个 AMQP 实体, 定义了消息应该怎样路由给 Queue
Queue 则是一个先进先出的队列
每个 Queue 需要声明绑定到某个 Exchange 才可以接受消息.
Publisher就是我们自己编写的消息发送方程序
Consumer 就是消息接收方

2.1 Exchange

Exchange 主要有以下几种

Name Default pre-declared names
Direct exchange (Empty string) and amq.direct
Fanout exchange amq.fanout
Topic exchange amq.topic
Headers exchange amq.match (and amq.headers in RabbitMQ)

1) Direct Exchange

每个 Queue 通过 routing_key 和 Exchange 绑定
发送的消息根据 routing key 发送到指定队列

2) Fanout Exchange

就是广播到所有队列
绑定时不用带 routing key

3) Topic Exchange

则有点像订阅模式,发布给订阅了该主题的队列
也是使用绑定时的 routing key 来处理发布订阅的逻辑.
Queue 绑定的时候可以使用通配符来定义自己需要订阅的routing key模式

4) Headers Exchange

不是使用 route key 来进行路由,而是使用 message 的 Header 来进行路由
自定义每个消息都使用的头部,来发送消息,并进行路由.
这样可以在发送消息的时候动态设定发动到哪个队列

除此之外还有一个名字为空字符的默认 Exchange, 这个 Exchange 也是一个 direct Exchange, 每个队列创建的时候就会默认绑定到这个 Exchange 上.而 routing key, 就是每个Queue 的名字.

另外Exchange 有如下几个属性:

  • Name 名称
  • Durability (exchanges survive broker restart) 设置持久化有可能在消息队列发生消息堆积导致大量信息遗保存硬盘文件上.可能会导致硬盘空间被占满需要注意.
  • Auto-delete (exchange is deleted when all queues have finished using it)
  • Arguments (these are broker-dependent)

2.2 Queue

AMQP 模型下的 Queue 有这些属性

  • Name
  • Durable (the queue will survive a broker restart)
  • Exclusive (used by only one connection and the queue will be deleted when that connection closes)
    只允许一个连接
  • Auto-delete (queue is deleted when last consumer unsubscribes)
  • Arguments (some brokers use it to implement additional features like message TTL)

大部分参数都和 Exchange 一样.多了一个 Exclusive 的参数.主要是设定某个队列必须串行处理用的.

2.3 消息相关

AMQP 设定了接受消息可以使用推( push API)和拉(pull API)的模型.

关于消息的删除, AMQP 也定义了两种模式,一种是一旦发送到对应的 consumer 就自动删除消息,还有一种则需要 consumer 使用basic.ack AMQP 方法来回应这个消息, broker 才会把这个消息移除.

在需要 basic.ack 的消息模型中,如果一个 cosumer 一直没有 ack 一个消息,它就不会收到下一个消息.而且在这种情况当没有 consumer 接收消息时,消息会堆积在 borker 上,导致硬盘空间被占用.

所以如果使用 Durable 持久化队列,请务必设定Queue的名字,保证在 consumer 崩溃后可以连回原来的 Queue, 以免 publisher 一直在往一个没有 consumer 接收信息的队列里面发消息,导致硬盘空间爆炸.

3. RabbitMQ

3.1 安装和配置

安装方法参考官方文档
https://www.rabbitmq.com/download.html

RabbitMQ 的配置分成在配置文件里面设定和环境变量设定两种.

配置文件 rabbitmq.conf的语法比较蛋疼,是使用Erlang 的 config 语法.感觉就像一个数组的配置.最后的.号不要漏掉了

比如远程连接的设置:

[
{rabbit, [{tcp_listeners, [{"127.0.0.1", 5672},
                           {"0.0.0.0", 10087}]}, 
          {msg_store_file_size_limit, 504800},
          {loopback_users, ["guest"]}]}
].

连接用的用户名和密码则使用 rabbitmqctl 来创建

官方提供的一个配置例子,可以作为参考
https://github.com/rabbitmq/rabbitmq-server/blob/stable/docs/rabbitmq.config.example

对于环境变量的设置项,按照文档,在 shell中设定的全局的 env 会覆盖 rabbimq-env.conf 的设置.然而这边实际使用时,在 debian下设定全局的环境变量并不生效.最后修改了在 rabbitmq 的配置目录下的 rabbitmq-env.conf才生效.

https://www.rabbitmq.com/relocate.html中列出了一些目录配置,
主要修改这些环境变量来配置 rabbitmq的目录相关的信息,比如RABBITMQ_MNESIA_DIR是默认存放队列和持久化.默认 rabbitmq 把持久化放在/ var 下面,很多情况这里并没有多少空间来存放大量的数据.

3.2 rabbitmqctl

这是一个用来查看rabbitmq 状态以及操作 rabbitmq的命令行工具

常用操作:

rabbitmqctl start 
rabbitmqctl stop stop 整个 rabbitmq 和对应的 erlang node
rabbitmqctl start_app 
rabbitmqctl stop_app  注意 stop_app 会移除所有的 virtual host 和用户的配置.
这个不会 stop erlang node, 不过会终止 rabbitmq

rabbitmqctl list_queues  列出所有队列,参数可以选择显示具体内容
rabbitmqctl list_exchanges 列出 exchang
rabbitmqctl  list_connections

rabbitmqctl add_user 增加用户
rabbitmqctl set_permissions 增加权限

purge_queue  移除队列里的所有消息

更多信息参考官方文档:
https://www.rabbitmq.com/man/rabbitmqctl.1.man.html

3.3 方法

rabbitmq 就是对 amqp 中的 broker 的方法进行了实现(其中带 xxx-ok的方法).而 client 则需要每个语言自己实现客户端的方法.

https://www.rabbitmq.com/amqp-0-9-1-reference.html

主要的使用方法并不难,就是

  1. declear_exchange
  2. declear_queue
  3. bind Queue to Exchange

publisher 使用 basic_publish 来发布消息
consumer 使用 basic_consumer 来接受消息,并且处理完毕之后使用 basic_ack, 发送消息消费确认.

这方面可以一边参考官方的6个示例来进行理解.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容