-
Notifications
You must be signed in to change notification settings - Fork 0
messaging
Benjamin Bennett edited this page Dec 13, 2020
·
15 revisions
This is a simple implementation of message publishing using RabbitMQ and a Go RabbitMQ Client Library.
cd go-bits/messaging
docker-compose up
go run -race main.go
data:image/s3,"s3://crabby-images/4fafb/4fafbfd7465d3b905fc53e02393189ef2e6fda88" alt=""
- A connection manager is created and handles:
- Initial connection to RabbitMQ and automated re-connection if the connection is closed.
- Obtaining a server channel (not to be confused with a go channel).
- Connection to RabbitMQ is initiated.
- A queue is configured.
- A message publisher is created.
- Loop is used to publish messages.
data:image/s3,"s3://crabby-images/8d4e5/8d4e5c1d3d46fc8f9488dc460182640bc8d892d3" alt=""
Configuration for the connection manager is passed to NewConnManager
and used to set the address for RabbitMQ, the retry interval and the maximum number of retry attempts.