Follow

Follow

Go lang and RabbitMQ Integration!

Maheshwar Ligade's photo
Maheshwar Ligade
·Apr 25, 2023·

3 min read

Play this article

Table of contents

  • Getting Started
  • Conclusion:

RabbitMQ is a message broker that facilitates communication between different applications. It is a widely used open-source message broker that implements the Advanced Message Queuing Protocol (AMQP). It is used for message queuing, routing, and reliability. Go is a modern programming language that has become increasingly popular for building microservices due to its efficiency and concurrency support. Integrating RabbitMQ with Go can provide a reliable and scalable solution for building distributed systems.

Getting Started

Prerequisites:

  • RabbitMQ server should be installed and running.

  • Go should be installed on the machine.

Setup:

  • Create a new project directory in Go, for example, "rabbitmq-go".

  • Install the AMQP client package for Go using the following command:

go get github.com/streadway/amqp

Publishing Messages to RabbitMQ:

To publish messages to RabbitMQ, the following steps need to be followed:

  1. Connect to the RabbitMQ server:
conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
if err != nil {
    panic(err)
}
defer conn.Close()
  1. Create a channel:
ch, err := conn.Channel()
if err != nil {
    panic(err)
}
defer ch.Close()
  1. Declare a queue to publish messages to:
q, err := ch.QueueDeclare(
    "test-queue",
    false,
    false,
    false,
    false,
    nil,
)
if err != nil {
    panic(err)
}
  1. Publish a message to the queue:
message := "Hello, RabbitMQ!"
err = ch.Publish(
    "",
    q.Name,
    false,
    false,
    amqp.Publishing{
        ContentType: "text/plain",
        Body:        []byte(message),
    },
)
if err != nil {
    panic(err)
}

Consuming Messages from RabbitMQ:

To consume messages from RabbitMQ, the following steps need to be followed:

  1. Connect to the RabbitMQ server:
conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
if err != nil {
    panic(err)
}
defer conn.Close()
  1. Create a channel:
ch, err := conn.Channel()
if err != nil {
    panic(err)
}
defer ch.Close()
  1. Declare a queue to consume messages from:
q, err := ch.QueueDeclare(
    "test-queue",
    false,
    false,
    false,
    false,
    nil,
)
if err != nil {
    panic(err)
}
  1. Consume messages from the queue:
msgs, err := ch.Consume(
    q.Name,
    "",
    true,
    false,
    false,
    false,
    nil,
)
if err != nil {
    panic(err)
}

for msg := range msgs {
    fmt.Println(string(msg.Body))
}

Conclusion:

RabbitMQ is a powerful message broker that can be used to build scalable and reliable microservices. Go is a modern programming language that provides efficient and concurrent solutions for building microservices. Integrating RabbitMQ with Go can provide a reliable and scalable solution for building distributed systems. In this article, we covered the basics of RabbitMQ and Go integration by discussing the prerequisites, setup, and publishing and consuming messages using Go.

I hope this helps, you!!

More such articles:

https://medium.com/techwasti

https://www.youtube.com/channel/UCiTaHm1AYqMS4F4L9zyO7qA

https://www.techwasti.com/

\==========================**=========================

If this article adds any value to you then please clap and comment.

Let’s connect on Stackoverflow, LinkedIn, & Twitter.

Did you find this article valuable?

Support techwasti by becoming a sponsor. Any amount is appreciated!

See recent sponsors Learn more about Hashnode Sponsors
 
Share this