我目前正在使用Node.js开发聊天系统。我的问题是,如何处理与Node.js的多个聊天会话。这有点模糊,所以我会解释......
例如,两个人可能会参与聊天会话。 Node.js每隔几秒检查一次新消息。这很简单,因为我可以使用下面的代码使其正常工作。
我的问题是,当另外两个人同时在另一个聊天会话中时。
目前我发送两个名为“chat_id”和“check_date”的查询字符串,以便在特定日期和时间之后检查新的聊天消息。
问题是,每次启动新聊天时都会覆盖“chat_id”和“check_date”,因为两个聊天室都在使用该服务器。
我有道理吗?
我的代码如下:
var chat_id, check_date;
var sys = require("sys"),
http = require("http"),
url = require("url"),
path = require("path"),
fs = require("fs"),
events = require("events");
// Conntect to database
var Client = require('mysql').Client;
var client = new Client();
client.host = 'localhost';
client.port = 3306;
client.database = '****';
client.user = '****';
client.password = '****';
client.connect(function(error, results) {
if(error) {
console.log('Connection Error: ' + error.message);
return;
}
console.log('Connected to MySQL');
});
// Check for chat updates
function getChatUpdates() {
if (typeof(check_date) == 'undefined')
return;
client.query('SELECT name, message FROM chat WHERE chat_id = "' + chat_id + '" AND date_entered > "' + check_date + '"',
function selectCb(error, results, fields) {
if (error) {
console.log('GetData Error: ' + error.message);
client.end();
return;
}
if (results.length > 0) {
for(var i = 0;i<results.length;i++) {
console.log('Name: ' + results[i]['name']);
console.log('Message: ' + results[i]['message']);
}
}
});
}
// Set interval to check for chat updates every 2 seconds
setInterval(getChatUpdates, 2000);
http.createServer(function(request, response) {
// Get the query strings
var uri = url.parse(request.url, true);
chat_id = uri.query.chat_id;
check_date = uri.query.check_date;
console.log('Chat ID: ' + chat_id);
console.log('Last Check: ' + check_date);
// we'll do something here later.
}).listen(8080);
sys.puts("Server running at http://localhost:8080/");
答案 0 :(得分:7)
您似乎拥有PHP背景,并且在node.js中进行编程时,您应该拥有完全不同的心态。你不应该轮询(setInterval(getChatUpdates, 2000);
)用于消息,但在事件上向用户推送(回调/事件)消息。我建议你看看socket.io并使用像redis这样的内存数据库(而不是mysql)来存储你的消息。当你这样编码时,你的网站会表现得更好,并且将会是实时的(更多)。另外,我建议您使用express作为开发网站的框架,而不是使用原始http
模块。我不知道您是否已经了解npm,但您应该使用它来管理您的依赖项。
答案 1 :(得分:4)
var chat_id,check_date;
是全局变量。您将在每个连接上覆盖chat_id
(在createServer
中。您可能需要某种会话存储(以关联用户和他们的聊天),例如,Array,Redis等。< / p>
答案 2 :(得分:2)
看起来您正在尝试将MySQL用作消息队列。 RabbitMQ?