golang如何实现rabbitmq监听

寻技术 Go编程 2023年10月14日 100

本篇内容介绍了“golang如何实现rabbitmq监听”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

准备工作

在开始之前,需要确保已经安装RabbitMQ。由于RabbitMQ依赖Erlang,所以还需要安装Erlang。

安装完成之后,我们需要安装Golang第三方包。其中,AMQP包是必不可少的,它可以让我们很方便地连接和操作RabbitMQ。

go get github.com/streadway/amqp

代码实现

首先,我们需要连接到RabbitMQ。连接成功后,我们需要声明一个名为“test”、类型为“fanout”的exchange。exchange是RabbitMQ中实现消息路由的重要组成部分,它负责接收消息并将它们分发给队列。在这种情况下,我们将声明一个名为“test”的exchange,并将其类型设置为“fanout”,这意味着它将消息广播给所有订阅了它的队列。

conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
failOnError(err, "Failed to connect to RabbitMQ")
defer conn.Close()

ch, err := conn.Channel()
failOnError(err, "Failed to open a channel")
defer ch.Close()

err = ch.ExchangeDeclare(

"test",   // name
"fanout", // type
true,     // durable
false,    // auto-deleted
false,    // internal
false,    // no-wait
nil,      // arguments

)
failOnError(err, "Failed to declare an exchange")

接下来,我们需要创建一个新的、非持久的、具有自动生成名称的队列。在这里,我们将使用队列的名称来绑定它们与刚刚声明的“test”exchange。

q, err := ch.QueueDeclare(

"",    // name
false, // durable
false, // delete when unused
true,  // exclusive
false, // no-wait
nil,   // arguments

)
failOnError(err, "Failed to declare a queue")

err = ch.QueueBind(

q.Name, // queue name
"",     // routing key
"test", // exchange
false,
nil,

)
failOnError(err, "Failed to bind a queue")

现在,RabbitMQ已经准备就绪,我们可以开始监听它的消息了。我们可以使用Consume函数来实现消息监听,它可以使我们持续不断地接收来自队列的消息,并对它们进行处理。

msgs, err := ch.Consume(

q.Name, // queue name
"",     // consumer
true,   // auto-ack
false,  // exclusive
false,  // no-local
false,  // no-wait
nil,    // args

)
failOnError(err, "Failed to register a consumer")

for msg := range msgs {

log.Printf("Received a message: %s", msg.Body)

}

在以上代码中,我们使用了ch.Consume()方法来监听指定队列中的消息,并通过打印日志的方式输出了消息内容。需要注意的是,我们使用了一个死循环来部署进行消息监听,这意味着我们会一直监听队列,直至程序被停止或者出现错误。

完整代码如下:

package main

import (

"log"

"github.com/streadway/amqp"

)

func failOnError(err error, msg string) {

if err != nil {
    log.Fatalf("%s: %s", msg, err)
}

}

func main() {

conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
failOnError(err, "Failed to connect to RabbitMQ")
defer conn.Close()

ch, err := conn.Channel()
failOnError(err, "Failed to open a channel")
defer ch.Close()

err = ch.ExchangeDeclare(
    "test",   // name
    "fanout", // type
    true,     // durable
    false,    // auto-deleted
    false,    // internal
    false,    // no-wait
    nil,      // arguments
)
failOnError(err, "Failed to declare an exchange")

q, err := ch.QueueDeclare(
    "",    // name
    false, // durable
    false, // delete when unused
    true,  // exclusive
    false, // no-wait
    nil,   // arguments
)
failOnError(err, "Failed to declare a queue")

err = ch.QueueBind(
    q.Name, // queue name
    "",     // routing key
    "test", // exchange
    false,
    nil,
)
failOnError(err, "Failed to bind a queue")

msgs, err := ch.Consume(
    q.Name, // queue name
    "",     // consumer
    true,   // auto-ack
    false,  // exclusive
    false,  // no-local
    false,  // no-wait
    nil,    // args
)
failOnError(err, "Failed to register a consumer")

for msg := range msgs {
    log.Printf("Received a message: %s", msg.Body)
}

}

关闭

用微信“扫一扫”