golang使用RabbitMQ(一)helloworld

介绍

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()

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值