+
95
-

redis如何实现聊天最新消息?

redis如何实现聊天最新消息?

网友回复

+
15
-

设计一个即时通讯系统(包含单聊和群聊)并使用Redis存储和管理聊天数据,可以利用Redis的多种数据结构和特性来实现高效的消息存储和检索。以下是一个详细的设计方案:

1. 数据结构设计用户信息

可以使用HASH数据结构存储用户信息。

user:{user_id} -> { "username": "user1", "status": "online", ... }
单聊消息

使用LIST数据结构存储单聊消息,每个会话一个列表。

chat:{user1_id}:{user2_id} -> [ { "from": "user1", "to": "user2", "msg": "Hello", "timestamp": 1627890123 }, ... ]
群聊消息

使用LIST数据结构存储群聊消息,每个群一个列表。

group:{group_id} -> [ { "from": "user1", "msg": "Hello group", "timestamp": 1627890123 }, ... ]
最新消息

使用ZSET(有序集合)存储用户的最新消息,以时间戳作为分数。

latest_messages:{user_id} -> { "msg_id1": timestamp1, "msg_id2": timestamp2, ... }
2. 实现单聊和群聊单聊消息存储

当用户发送单聊消息时,将消息存储到对应的LIST中,并更新最新消息的有序集合。

import redis
import json
import time

r = redis.Redis(host='localhost', port=6379, db=0)

def send_private_message(from_user, to_user, message):
    chat_key = f"chat:{from_user}:{to_user}" if from_user < to_user else f"chat:{to_user}:{from_user}"
    msg = {
        "from": from_user,
        "to": to_user,
        "msg": message,
        "timestamp": int(time.time())
    }
    r.rpush(chat_key, json.dumps(...

点击查看剩余70%

我知道答案,我要回答