【发布时间】:2016-11-07 20:05:18
【问题描述】:
我有一个托管 WebSocket 服务器的 NodeJS。 WebSocket 从 Redis 重新分发消息。
整行是,我有一些 python 脚本在 Redis 中推送一些数据,之后 NodeJS 是 WebSocket,它将 Redis 新输入的数据读取到连接的客户端。我的问题是 NodeJs 总是占用内存,过了一会儿它就突然停止了。
我不知道我的问题是什么,因为我的代码很简单。
我不需要我的 WebSocket 从连接的客户端接收消息,因为我只需要向它们推送数据,但需要推送大量数据。
var server = require('websocket').server,
http = require('http');
var redis = require("redis"),
client = redis.createClient();
var socket = new server({
httpServer: http.createServer().listen(443),
keepalive: false
});
client.subscribe("attack-map-production");
socket.on('request', function(request) {
var connection = request.accept(null, request.origin);
connection.on('message', function(message) {
console.log(message);
client.on("message", function(channel, message){
connection.send(message);
});
});
connection.on('close', function(connection) {
console.log('connection closed');
});
});
我希望在不占用服务器上所有内存的情况下完成这项工作,并且可能会更快,但我认为它已经足够快了。
也许 NodeJS 不适合这种工作?
感谢任何帮助。 谢谢。
2016 年 11 月 8 日更新
根据下面提供的信息,我已经“更新”了我的代码。问题依然存在,我会继续四处寻找答案......但我真的没有得到这个。
var server = require('websocket').server,
http = require('http');
var redis = require("redis"),
client = redis.createClient();
var socket = new server({
httpServer: http.createServer().listen(443),
keepalive: false
});
client.subscribe("attack-map-production");
socket.on('request', function(request) {
var connection = request.accept(null, request.origin);
client.on("message", function(channel, message){
connection.send(message);
});
connection.on('close', function(connection) {
console.log('connection closed');
});
});
2016 年 11 月 16 日更新
这是我的新代码:
var io = require('socket.io').listen(443);
var sub = require('redis').createClient();
io.sockets.on('connection', function (sockets) {
sockets.emit('message',{Hello: 'World!'});
sub.subscribe('attack-map-production'); // Could be any patterni
sockets.on('disconnect', function() {
sub.unsubscribe('attack-map-production');
});
});
sub.on('message', function(channel, message) {
io.sockets.json.send(message);
});
即使是这段代码,也让 nodejs 以 100% 甚至更多的 CPU 运行,它开始变得非常缓慢,直到一切都停止。
我的数据的完整流程,是一个python脚本将数据推送到Redis,并通过我的订阅将我的数据通过webSocket和Socket.io推送回浏览器。
这么简单,怎么会这么慢?我就是不明白。
【问题讨论】:
-
感谢您的意见,我会检查并回复您。
标签: javascript node.js websocket redis socket.io