Nodejs - fs.appendFileSync抛出错误EBUSY

时间:2015-12-24 15:08:42

标签: javascript node.js fs

我正在尝试将行添加到nodejs中的文件中。我写了以下代码。

/* Name :  test.js */
/* globals require,__dirname */
var fs = require("fs");
for (var i = 0; i < 100000; i++) {
    fs.appendFileSync(__dirname+'/out.txt', "line " + i + "\n");
}

但是当我运行这个程序时,我收到以下错误。

$ node test.js
fs.js:584
  return binding.open(pathModule._makeLong(path), stringToFlags(flags), mode);
                                                  ^

Error: EBUSY: resource busy or locked, open 'd:\<redacted>\out.txt'
    at Error (native)
    at Object.fs.openSync (fs.js:584:18)
    at Object.fs.writeFileSync (fs.js:1224:33)
    at Object.fs.appendFileSync (fs.js:1283:6)
    at Object.<anonymous> (d:\<redacted>\test.js:3:8)
    at Module._compile (module.js:425:26)
    at Object.Module._extensions..js (module.js:432:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:313:12)
    at Function.Module.runMain (module.js:457:10)

我搜索过但找不到任何理由或解决方法。有人可以解释为什么会出现此错误以及如何解决它?

当我尝试以下方法时,它可以工作,但这对我试图解决的问题不太可行。

/* globals require,__dirname */
var fs = require("fs");
var buffer = "";

for (var i = 0; i < 100000; i += 1) {
    var line =  'line ' + i + '\n';
    buffer += line;                 // keep the line in buffer    
}

fs.appendFileSync(__dirname+'/out.txt', buffer);   // now write the buffer

提前致谢。

1 个答案:

答案 0 :(得分:2)

你的代码对我有用,但速度非常慢,完成文件写入需要几分钟(确切地说是269621.425ms)。您的问题可能是因为在很短的时间内有这么多的访问,我想这对我有用,因为我使用的是SSD。

对于您的问题,streams可能会非常有帮助。它快速且内存效率高(您不必存储巨大的缓冲区变量)。我不知道你想要做什么,所以这里是你用流编写的例子(为方便起见,我使用了event-stream):

var fs = require('fs');
var es = require('event-stream');

console.time('done in');
es.readable(function (count, next) {
    for (var i = 0; i < 100000; i++) {
        this.emit('data', 'line ' + i + "\n");
    }
    this.emit('end');
    console.timeEnd('done in');
    next();
}).pipe(fs.createWriteStream('out.txt'));
  

完成于:90.561ms