RabbitMQ通信模式(Simplest)Python示例

RabbitMQ通信模式-Python示例

0.RabbitMQ官网通信模式

1.Simplest(简单)模式

1.1 发送端

python 复制代码
# -*- coding: utf-8 -*-
"""
Author: xxx
date:   2025/5/19 11:30
Description:    
    Simaple简单模式,生产者
    简单的RabbitMQ消息队列(不安全,不能持久化)
"""

import pika

# RabbitMQ 服务器地址
rabbitmq_host = '192.168.120.19'
# RabbitMQ 服务器端口
rabbitmq_port = 5672
# RabbitMQ 用户名
rabbitmq_username = 'rabbitmq'
# RabbitMQ 密码
rabbitmq_password = 'rabbitmq@123'

# 根据用户名和密码,创建凭证对象
credentials = pika.PlainCredentials(rabbitmq_username, rabbitmq_password)
# 创建连接参数对象,指定主机、端口、凭证等信息
connection = pika.BlockingConnection(
    pika.ConnectionParameters(
        host=rabbitmq_host,
        port=rabbitmq_port,
        credentials=credentials
    )
)
# 创建通道对象
channel = connection.channel()

# 定义消息队列名称
queue_name = 'hello'
# 声明消息队列,如果没有队列会自动创建
channel.queue_declare(
    queue=queue_name
)

# 定义消息内容
message = 'Hello, World!'
# 发布消息到消息队列,routing_key为队列名称,body为消息内容,properties为属性,其中delivery_mode为2表示持久化
channel.basic_publish(
    exchange='',
    routing_key=queue_name,
    body=message
)
print(" [x] Sent '{}'".format(message))

# 关闭通道和连接
connection.close()

1.2 接收端

python 复制代码
# -*- coding: utf-8 -*-
"""
Author: tanggaomeng
date:   2025/5/19 11:44
Description:    
    Simaple简单模式,消费者
    简单的RabbitMQ消息队列(不安全,不能持久化)
"""

import pika

# RabbitMQ 服务器地址
rabbitmq_host = '192.168.120.19'
# RabbitMQ 服务器端口
rabbitmq_port = 5672
# RabbitMQ 用户名
rabbitmq_username = 'rabbitmq'
# RabbitMQ 密码
rabbitmq_password = 'rabbitmq@123'

# 根据用户名和密码,创建凭证对象
credentials = pika.PlainCredentials(rabbitmq_username, rabbitmq_password)
# 创建连接参数对象,指定主机、端口、凭证等信息
connection = pika.BlockingConnection(
    pika.ConnectionParameters(
        host=rabbitmq_host,
        port=rabbitmq_port,
        credentials=credentials
    )
)
# 创建通道对象
channel = connection.channel()

# 定义消息队列名称
queue_name = 'hello'
# 声明消息队列,如果没有队列会自动创建
channel.queue_declare(
    queue=queue_name
)

# 将ReceivedMessage添加到队列中,同时替换通道实现。
# 返回的结果,会返回到这里面,如果有兴趣可以点开basic_consume方法去看看源代码
# 订阅消息队列,设置自动应答(auto_ack=False),并指定回调函数
def callback(ch, method, properties, body):
    print(" [x] Received %r" % (body,))


# 从服务器队列中消费
# no_ack=True ,是需要是否确定消息的处理了,告诉服务端
# no_ack=False ,默认是False,可以不写
channel.basic_consume(queue=queue_name, on_message_callback=callback, auto_ack=False)

print(' [*] Waiting for messages. To exit press CTRL+C')
channel.start_consuming()

'''
注意:接收到处于死循环,一直在等待接收,发送一个数据,就收到一个数据
'''
python 复制代码
基于上面的代码不做任何修改
把上面的消费者开N个就是想要的结果。
如下:
运行3个消费者,生产者生成的消息队列依次被接收者接收,每次只有一个消费者接收到信息,3个消费者接收顺序依次进行

参考:
https://www.rabbitmq.com/tutorials

相关推荐
爱喝白开水a9 分钟前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
酷ku的森22 分钟前
RabbitMQ七种工作模式介绍:
分布式·rabbitmq
济南java开发,求内推1 小时前
单个服务器部署多个rabbitmq
运维·服务器·rabbitmq
默 语2 小时前
消息中间件选型的艺术:如何在RocketMQ、Kafka、RabbitMQ中做出正确决策
java·架构·kafka·消息队列·rabbitmq·rocketmq·技术选型
默默coding的程序猿2 小时前
3.git的分支携带问题是什么?怎么解决?
java·git·python·svn·gitee·github·intellij-idea
新子y3 小时前
【小白笔记】PyTorch 和 Python 基础的这些问题
pytorch·笔记·python
我是李武涯3 小时前
PyTorch DataLoader 高级用法
人工智能·pytorch·python
Lynnxiaowen4 小时前
今天我们开始学习python语句和模块
linux·运维·开发语言·python·学习
ThreeAu.4 小时前
pytest 实战:用例管理、插件技巧、断言详解
python·单元测试·pytest·测试开发工程师
资源补给站5 小时前
服务器高效操作指南:Python 环境退出与 Linux 终端快捷键全解析
linux·服务器·python