我在一个udp-port上写了一个小脚本,并将所有传入的消息(一个JSON对象)存储在一个文件中。空文件包含JSON格式的数组。 我正在寻找一种有效的方法来存储来自这个单个文件中的多个客户端的所有(并发)传入消息。 文件大小可以是几百兆字节。解析文件并附加新对象根本不会有效。
你有办法吗?
修改 我的解决方案,基于@ t-j-crowder方法:
var dgram = require("dgram");
var fs = require("fs");
var udp_server = dgram.createSocket("udp4");
var udp_server_port = 5000
udp_server.on("message", function (msg, rinfo) {
var json_part = "{\"message\": " + msg + "}";
fs.open('./data/stats.json','r+',function(err,fd){
if(err) throw err
fs.fstat(fd,function(err,stats){
if(err) throw err
if(stats.size>2){
json_part = new Buffer(','+json_part+']','utf-8');
var pos = parseInt(stats.size)-1;
}else{
json_part = new Buffer('['+json_part+']','utf-8');
var pos = 0;
}
fs.write(fd,json_part, 0, json_part.length, pos, function(err,written,buffer){
if(err) throw err
fs.close(fd,function(){
});
});
});
});
});
udp_server.bind(udp_server_port);
问候,马库斯
答案 0 :(得分:3)
从根本上说,你需要:
使用可搜索的可写流打开文件。
寻求结束。
备份一个字符(在数组的结尾]
之上)。
写出一个逗号(如果这不是第一个条目)和新条目的JSON。
写一个结束]
。
关闭文件。
查看NodeJS文档,看起来步骤2-4(可以说是5)使用fs.write
的position
参数一起完成。 (确保使用r+
打开文件,而不是“附加”模式之一。)