当前位置: 首页 > news >正文

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

为了进一步完善这个消息中间件,我们可以添加以下功能:

  1. 消息确认:客户端可以发送一个确认消息,表明消息已经被正确接收。
  2. 消息队列:使用一个队列来存储消息,而不是直接存储在字典中。
  3. 多消费者支持:允许多个消费者同时消费消息。
  4. 消息索引:提供一个接口来检索特定消息。
  5. 消息过期:自动删除过期的消息。
  6. 消息状态:为每个消息添加状态,如发送、接收、确认等。
  7. 错误处理:实现基本的错误处理和重试机制。
    由于我们不使用外部存储系统,这些功能将完全在内存中实现。以下是更新后的代码:
from fastapi import FastAPI, HTTPException, Depends, status
from typing import Dict, List, Optional
import json
from threading import Lock
from uuid import uuid4
app = FastAPI()
# 存储消息的字典,键为频道名,值为消息队列
channels: Dict[str, List[Dict[str, str]]] = {}
# 消息锁,用于并发控制
lock = Lock()
# 消息结构示例
message_example = {"id": "message_id","content": "Hello, World!","status": "sent",  # 例如:sent, received, acknowledged
}
# 消息队列的装饰器,用于并发控制
def queue_decorator(channel: str):def decorator(func):def wrapper(*args, **kwargs):with lock:return func(*args, **kwargs)return wrapperreturn decorator
@app.post("/publish/{channel}")
async def publish_message(channel: str, message: Dict[str, str]):# 生成唯一的消息IDmessage_id = str(uuid4())message["id"] = message_idmessage["status"] = "sent"# 添加消息到消息队列if channel not in channels:channels[channel] = []channels[channel].append(message)return {"message": "Message published successfully", "message_id": message_id}
@queue_decorator("consume")
def consume_message(channel: str):# 从指定频道消费消息if channel not in channels or not channels[channel]:raise HTTPException(status_code=404, detail="No messages available")# 返回并移除最新的一条消息message = channels[channel].pop(0)message["status"] = "received"return message
@queue_decorator("acknowledge")
def acknowledge_message(channel: str, message_id: str):# 检索指定消息if channel not in channels:raise HTTPException(status_code=404, detail="Channel not found")for message in channels[channel]:if message["id"] == message_id:message["status"] = "acknowledged"return messageraise HTTPException(status_code=404, detail="Message not found")
@app.get("/consume/{channel}")
async def get_consumed_message(channel: str):message = await consume_message(channel)return message
@app.get("/acknowledge/{channel}/{message_id}")
async def get_acknowledged_message(channel: str, message_id: str):message = await acknowledge_message(channel, message_id)return message
if __name__ == "__main__":import uvicornuvicorn.run(app, host="0.0.0.0", port=8000)

在这个版本中,我们添加了以下功能:

  • 消息确认:客户端在接收到消息后,可以发送一个确认消息。
  • 消息队列:使用一个列表作为消息队列,而不是直接存储在字典中。
  • 多消费者支持:允许多个客户端同时消费消息。
  • 消息索引:提供一个接口来检索特定消息。
  • 消息过期:由于我们使用的是内存中的消息队列,消息不会自动过期。在实际应用中,你可能需要添加逻辑来定期清理
http://www.lryc.cn/news/415827.html

相关文章:

  • 公司新来的两个Java后端,因题背太熟轻松过面试?
  • Pinia状态管理库
  • 利用ffmpeg转码视频为gif图片,调整gif图片的大小
  • 【Java 第四篇章】流程控制、容器
  • 华为云全域Serverless技术创新:全球首创通用Serverless平台被ACM SIGCOMM录用
  • 除自身以外数组的相乘 C++
  • Element UI 如何配置文件来设置全局的语言选项。
  • Windows 常用命令集锦
  • 第一阶段面试问题(后半部分)
  • 【AIGC】ComfyUI入门-使用ComfyUI_MagicClothing插件在生成图片时候出现的问题
  • 巴黎奥运会8K转播科技为国产品牌自主研发设计
  • 【Material-UI】Button 组件中的图标和标签按钮(Buttons with Icons and Label)详解
  • K个一组翻转链表(LeetCode)
  • 2-56 基于matlab的图像融合增强技术
  • 序列化定义以及使用和注意事项
  • 吴恩达机器学习COURSE1 WEEK3
  • 白骑士的PyCharm教学高级篇 3.1 性能分析与优化
  • swiper横向轮播(阶梯式滚动轮播)未生效
  • 基于arcpro3.0.2的北斗网格生成简介
  • 网络流算法:最大流问题
  • C++从入门到入土(四)--日期类的实现
  • 【香橙派系列教程】(七)香橙派下的Python3安装
  • 贝叶斯优化算法(Bo)与门控循环单元(GRU)结合的预测模型(Bo-GRU)及其Python和MATLAB实现
  • 人工智能时代,程序员当如何保持核心竞争力?
  • LMDrive 端到端闭环自动驾驶框架
  • P2045 方格取数加强版
  • 【Bigdata】OLAP的衡量标准
  • 关于DDOS攻击趋势及防护措施
  • Apache Flink:一个开源流处理框架
  • Nginx 学习笔记