RabbitMQ - Producer <-> Consumer

git clone https://github.com/knehez/isi.git
cd isi/rabbitmq-python
docker-compose up -d rabbitmq

This is a docker-compose.yml file that defines a single service called rabbitmq using the official rabbitmq Docker image with management plugin.

version: '3.7'
services:
  rabbitmq:
    image: 'rabbitmq:3-management'
    ports:
        - 5672:5672
        - 15672:15672

consumer.py

import pika
import sys
import os
 
connection = pika.BlockingConnection(pika.ConnectionParameters(host='rabbitmq'))
channel = connection.channel()
 
channel.queue_declare(queue='hello')
 
 
def callback(ch, method, properties, body):
    print(" [x] Received %r" % body)
 
 
channel.basic_consume(
    queue='hello', on_message_callback=callback, auto_ack=True)
 
print(' [*] Waiting for messages. ')
 
while (True):
    channel.start_consuming()

producer.py

import pika
 
connection = pika.BlockingConnection(pika.ConnectionParameters(host='rabbitmq'))
channel = connection.channel()
 
channel.queue_declare(queue='hello')
 
channel.basic_publish(exchange='', routing_key='hello', body='Hello World!')
print(" [x] Sent 'Hello World!'")
connection.close()

Task 1: open port: 15672 → RabbitMQ management extension pw: guest:guest

Launch producer

docker-compose up -d producer

Launch consumer

docker-compose up -d consumer

Check the hello queue form the management console.

Task 2: send a message by hand and check the console of the consumer:

docker-compose logs -f consumer