介绍
RabbitMQ是一个可以接收和转发消息的代理(broker)。
你可以把比喻成邮局系统:当你把你要寄的邮件存放到邮箱,你可以确定邮递员(先生或女士)最终会把邮件交给你的收件人。
在这个比喻中,RabbitMQ是一个邮箱,是一个邮局,同时也是邮递员,和真正邮局系统不同点在于它没有使用纸来寄东西。
相反,它接受、存储和转发二进制数据块消息。
RabbitMQ和消息传递通常使用的一些术语:
生产者仅仅只有发送功能,发送消息的程序是生产者(producer):
队列(queue)是位于RabbitMQ中的邮箱的名称.虽然消息流经RabbitMQ和你的应用程序,
但它们只能存储于队列中,队列只受限于主机的内存和磁盘。它本质上是一个大的消息缓存区。
许多生产者可以发送消息到一个队列,同时也可以多个消费者从一个队列获取数据。
下图就是我们表示队列的方式:
消费与接收有相似的含义,通常等待接收消息的程序指的是消费者(comsumer):
请注意:代理,生产者以及消费者不是一定要驻留在同一台主机上的。实际上这些程序大多数都不是在同一台主机上。
一个应该程序同时也可以是生产者和消费者。
“Hello World”
(使用go rabbitmq 客户端开始编写经典hello world程序)
在这份指导我们会使用go创建两个小的应用程序:
生产者发送单独的一条消息,消费者接收并打印出来。我们掩饰一些rabbitmq api中的细节,
为了快速开始“hello world”消息传递,集中关注一些简单的事情。
在下图中,“P”是生产者,“C"是消费者,中间的框是队列--RabbitMQ给消费者保留的消息缓冲区。
RabbitMQ客户端库:
RabbitMQ可以使用多种协议,本教程使用一种开源、通用的消息传递协议AMQP-0-9-1。
RabbitMQ同样有许多不同语言的客户端,这里使用的是"Go amqp" 客户端(其他还有,php,C#,java等)
首先使用go get安装amqp协议:
go get github.com/streadway/amqp
Sending(发送)
我们会将send.go叫做我们的消息发布者(发送人)。receiver.go叫做消息消费者(接收人)
publisher(发布者)连接到RabbitMQ,发送一条消息,之后退出。
在send.go,首先要引入amqp协议库
package main
import (
"github.com/streadway/amqp"
"log"
)
一个用来帮助我们检查每一次amqp库调用的返回值
func failOnError(err error, msg string) {
if err != nil {
log.Fatalf("%s: %s", msg, err)
}
}
然后连接到RabbitMQ服务。
conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
failOnError(err, "Failed to connect to RabbitMQ")
defer conn.Close()
该连接抽象了socket连接,并且为我们提供了版本协商及认证等功能。接着我们要创建一个channel,大部分的RabbitMQ API接口都是在这里面。
ch, err := conn.Channel()
failOnError(err, "Failed to open a channel")
defer ch.Close()