3 回答

TA貢獻1789條經驗 獲得超8個贊

TA貢獻1804條經驗 獲得超2個贊
appendFile
, appendFile
EMFILE
appendFile
WriteStream
.
appendFile
:
console.log(new Date().toISOString());[...Array(10000)].forEach( function (item,index) { fs.appendFile("append.txt", index+ "\n", function (err) { if (err) console.log(err); });});console.log(new Date().toISOString());
{ Error: EMFILE: too many open files, open 'C:\mypath\append.txt' at Error (native) errno: -4066, code: 'EMFILE', syscall: 'open', path: 'C:\\mypath\\append.txt' }
appendFile
var stream = fs.createWriteStream("append.txt", {flags:'a'});console.log(new Date().toISOString());[...Array(10000)].forEach( function (item,index) { stream.write(index + "\n");});console.log(new Date().toISOString());stream.end();
stream.end()
AutoClose:true

TA貢獻1796條經驗 獲得超4個贊
使用createWriteStream的代碼為每次寫入創建一個文件描述符。因為它要求節點在寫入后立即關閉,因此log.end更好。
var fs = require('fs');
var logStream = fs.createWriteStream('log.txt', {'flags': 'a'});
// use {'flags': 'a'} to append and {'flags': 'w'} to erase and write a new file
logStream.write('Initial line...');
logStream.end('this is the end line');
- 3 回答
- 0 關注
- 642 瀏覽
添加回答
舉報