Skip to content

Instantly share code, notes, and snippets.

@firstrow
Forked from svcavallar/rabbitmq_reconnect.go
Created April 24, 2017 13:03
Show Gist options
  • Save firstrow/412f5b2444db10bfc532ec0e87d6ea1e to your computer and use it in GitHub Desktop.
Save firstrow/412f5b2444db10bfc532ec0e87d6ea1e to your computer and use it in GitHub Desktop.
Golang example to reconnect to RabbitMQ on a connection closed event
package main
import (
"flag"
"github.com/streadway/amqp"
"log"
"time"
)
var amqpUri = flag.String("r", "amqp://guest:guest@127.0.0.1/", "RabbitMQ URI")
var (
rabbitConn *amqp.Connection
rabbitCloseError chan *amqp.Error
)
// Try to connect to the RabbitMQ server as
// long as it takes to establish a connection
//
func connectToRabbitMQ(uri string) *amqp.Connection {
for {
conn, err := amqp.Dial(uri)
if err == nil {
return conn
}
log.Println(err)
log.Printf("Trying to reconnect to RabbitMQ at %s\n", uri)
time.Sleep(500 * time.Millisecond)
}
}
// re-establish the connection to RabbitMQ in case
// the connection has died
//
func rabbitConnector(uri string) {
var rabbitErr *amqp.Error
for {
rabbitErr = <-rabbitCloseError
if rabbitErr != nil {
log.Printf("Connecting to %s\n", *amqpUri)
rabbitConn = connectToRabbitMQ(uri)
rabbitCloseError = make(chan *amqp.Error)
rabbitConn.NotifyClose(rabbitCloseError)
// run your setup process here
}
}
}
func main() {
flag.Parse()
// create the rabbitmq error channel
rabbitCloseError = make(chan *amqp.Error)
// run the callback in a separate thread
go rabbitConnector(*amqpUri)
// establish the rabbitmq connection by sending
// an error and thus calling the error callback
rabbitCloseError <- amqp.ErrClosed
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment