Redis异步点对点聊天完美实现极致体验(redis 点对点聊天)

Redis异步点对点聊天:完美实现极致体验

Redis是一款高性能的开源Redis数据存储系统。它可以用来存储各种类型的数据,包括字符串、列表、哈希、集合和有序集合。Redis还提供了一些高级特性,例如发布/订阅、事务处理、Lua脚本和管道等。

在本文中,我们将探讨如何使用Redis构建一个异步点对点聊天应用程序。我们将使用Redis的发布/订阅模式和Websocket协议实现此功能。我们将使用Node.js和Express来构建我们的应用程序,并使用Socket.io作为我们的Websocket库。

在这个点对点聊天应用程序中,用户可以登录并与其他在线用户进行实时聊天。用户的聊天消息将通过Redis频道广播到其他在线用户。我们还将使用Redis列表数据类型来存储聊天消息的历史记录。

在我们开始之前,让我们确保我们已安装了Redis和Node.js。我们还需要安装一些Node.js依赖项,包括Express、Socket.io和Redis客户端。

在我们的应用程序中,我们将使用两个Redis频道:一个用于广播聊天消息,另一个用于广播用户状态更改。我们还将使用两个Redis列表:一个用于存储聊天消息的历史记录,另一个用于存储在线用户的ID。

让我们从创建我们的Express应用程序开始。在终端中,输入以下命令:

mkdir redis-chat-app
cd redis-chat-app
npm init -y
npm install express socket.io redis --save

创建一个名为index.js的文件,并将以下代码复制到文件中:

const express = require('express');
const http = require('http');
const socketIo = require('socket.io');
const redis = require('redis');

const app = express();
const server = http.createServer(app);
const io = socketIo(server);

const PORT = process.env.PORT || 3000;
const REDIS_PORT = process.env.REDIS_PORT || 6379;
const redisClient = redis.createClient(REDIS_PORT);
const redisSubscriber = redis.createClient(REDIS_PORT);
const redisPublisher = redis.createClient(REDIS_PORT);

redisClient.on('error', console.error);
redisSubscriber.on('error', console.error);
redisPublisher.on('error', console.error);

app.use(express.static('public'));

app.get('/', (req, res) => {
res.sendFile(__dirname + '/public/index.html');
});

io.on('connection', socket => {
socket.on('join', user => {
socket.userId = user.id;
redisClient.lpush('onlineUsers', socket.userId);
redisPublisher.publish('userJoined', JSON.stringify(user));
});
socket.on('sendMessage', message => {
const chatMessage = {
userId: socket.userId,
message,
timestamp: new Date().getTime()
};
redisClient.lpush('chatHistory', JSON.stringify(chatMessage));
redisPublisher.publish('chatMessage', JSON.stringify(chatMessage));
});

socket.on('disconnect', () => {
redisClient.lrem('onlineUsers', 1, socket.userId);
redisPublisher.publish('userLeft', socket.userId);
});
});

redisSubscriber.subscribe('chatMessage');
redisSubscriber.subscribe('userJoined');
redisSubscriber.subscribe('userLeft');

redisSubscriber.on('message', (channel, messageString) => {
const message = JSON.parse(messageString);
io.emit(channel, message);
});
server.listen(PORT, () => {
console.log(`Server listening on port ${PORT}`);
});

在上面的代码中,我们创建了一个Express应用程序和一个HTTP服务器。我们使用Socket.io将Websocket功能添加到我们的应用程序中,并使用Redis客户端来连接到Redis数据库。然后,我们创建一个具有三个事件监听器的Socket.io套接字:

– join:用户加入聊天室事件。我们将用户ID添加到Redis在线用户列表,并发布一个“用户加入”事件。

– sendMessage:用户发送消息事件。我们将用户ID、消息和时间戳组成的聊天消息对象添加到Redis聊天消息历史记录列表,并发布一个“聊天消息”事件。

– disconnect:用户离开聊天室事件。我们将用户ID从Redis在线用户列表中删除,并发布一个“用户离开”事件。

我们还创建了一个Redis订阅器来监听来自Redis频道的事件。每当有消息发布到一个频道中时,我们都会将其发送到所有连接的客户端。

现在,让我们创建我们的前端代码。在public文件夹中,创建一个名为index.html的文件,将以下代码复制到文件中:




Redis Chat App


#messages {
border: 1px solid black;
height: 400px;
overflow-y: scroll;
padding: 10px;
}



Online Users:



Send



const socket = io();

const onlineUsersElement = document.getElementById('onlineUsers');
const messagesElement = document.getElementById('messages');
const messageInputElement = document.getElementById('messageInput');
const messageButtonElement = document.getElementById('messageButton');

let currentUser;

const addMessage = message => {
const messageElement = document.createElement('div');
messageElement.innerText = `${message.userId}: ${message.message}`;
messagesElement.appendChild(messageElement);
};

const updateOnlineUsers = users => {
onlineUsersElement.innerText = users.join(', ');
};

socket.emit('join', {
id: Date.now().toString(36)
});

messageButtonElement.addEventListener('click', () => {
const message = messageInputElement.value.trim();

if (message) {
socket.emit('sendMessage', message);
messageInputElement.value = '';
}
});

socket.on('chatMessage', addMessage);

socket.on('userJoined', user => {
currentUser = user;
});

socket.on('userLeft', () => {
currentUser = null;
});

socket.on('onlineUsers', updateOnlineUsers);

socket.on('connect', () => {
console.log('connected');
});

socket.on('disconnect', () => {
console.log('disconnected');
});

socket.on('reconnect', () => {
console.log('reconnected');
});

socket.on('reconnecting', () => {
console.log('reconnecting');
});

socket.on('reconnect_fled', () => {
console.log('reconnect_fled');
});



在上面的代码中,我们使用Socket.io客户端连接到Socket.io服务器并与聊天室连接。我们还创建了一个功能来将收到的消息添加到消息列表视图中,并更新在线用户UI。

现在我们完成了我们的Redis异步点对点聊天应用程序。运行以下命令启动应用程序:

node index.js

访问http://localhost:3000,你应该能看到我们的点对点聊天应用程序。输入用户名,点击“Join”按钮加入聊天室。你现在可以和其他在线用户进行聊天。所有的聊天消息都将被保存在Redis聊天历史记录列表中。

在这个应用程序中,我们使用Redis的发布/订阅模式和Socket.io实现了一个高性能的异步点对点聊天应用程序。使用这种方法,我们可以轻松地扩展我们的应用程序,以处理成千上万的并发用户,并享受极致的聊天体验。

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/240437.html<

(0)
运维的头像运维
上一篇2025-04-23 21:07
下一篇 2025-04-23 21:09

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注