完全用python 实现消息中间件6

为了展示如何使用这个消息中间件,我们将创建一个简单的客户端脚本,它将发布一条消息,并消费该消息。

首先,我们需要安装fastapiuvicorn

bash 复制代码
pip install fastapi uvicorn

然后,我们将使用以下客户端脚本来演示如何使用消息中间件:

python 复制代码
import requests
import time
# 消息中间件的URL
message_broker_url = "http://localhost:8000"
# 发布消息
def publish_message(channel, message):
    response = requests.post(f"{message_broker_url}/publish/{channel}", json=message)
    return response.json()
# 消费消息
def consume_message(channel):
    response = requests.get(f"{message_broker_url}/consume/{channel}")
    return response.json()
# 发布一条消息
channel = "test_channel"
message = {"content": "Hello, World!"}
publish_response = publish_message(channel, message)
print(f"Published message: {publish_response}")
# 等待一段时间,以便消息被存储
time.sleep(1)
# 消费消息
consume_response = consume_message(channel)
print(f"Consumed message: {consume_response}")

在运行客户端脚本之前,请确保消息中间件正在运行,并且监听在8000端口上。

运行客户端脚本后,它将执行以下操作:

  1. 发布一条消息到名为test_channel的频道。

  2. 等待一段时间,以便消息被存储。

  3. test_channel频道消费消息。
    输出应该类似于:

    Published message: {'message': 'Message published successfully', 'message_id': '...'}
    Consumed message: {'id': '...', 'content': 'Hello, World!', 'status': 'received'}

请注意,由于消息中间件在内存中存储消息,重启中间件后,所有消息都会丢失。此外,这个示例没有实现完整的错误处理和重试机制,因此在生产环境中使用时,你可能需要添加这些功能。

相关推荐
skywalk81635 分钟前
记录段言的开发过程
开发语言·学习·编程
TickDB11 分钟前
Python 调用实时行情 API:ticker 返回成功后,如何校验字段再入库或展示
python·websocket·行情数据 api
未若君雅裁13 分钟前
JVM 垃圾回收器全景与G1深度解析
java·开发语言·jvm
霸道流氓气质14 分钟前
Java 大数据量异步处理方案:线程池 vs 消息队列
java·开发语言
devilnumber14 分钟前
想真正吃透 + 灵活运用 Java 代理模式
java·开发语言·代理模式
AC赳赳老秦19 分钟前
OpenClaw 助力技术面试:自动生成面试题、模拟面试、整理面试知识点
开发语言·python·面试·职场和发展·自动化·deepseek·openclaw
刘科领21 分钟前
修改jdk 第一步: 仓库以及构建(jdk17)
java·开发语言
Hali_Botebie23 分钟前
PyTorch 2.x核心变革torch.compile(),Triton 是其中最重要的 kernel 生成方式之一
人工智能·pytorch·python
C+-C资深大佬28 分钟前
C++ 中的 constexpr与 const区
java·开发语言·c++
仙俊红32 分钟前
Java 单例模式:类里面为什么可以有自己类型的字段?
java·开发语言·单例模式