Read large text files in nodejs
I've been playing around with NodeJS recently and got the following error when trying to read a very large text file:
FATAL ERROR: CALL_AND_RETRY_0 Allocation failed - process out of memory
The following solution allows you to stream a file instead of reading it all into memory:
var fs = require('fs');
var readline = require('readline');
var stream = require('stream');
var instream = fs.createReadStream('your/file');
var outstream = new stream;
var rl = readline.createInterface(instream, outstream);
rl.on('line', function(line) {
// process line here
});
rl.on('close', function() {
// do something on finish here
});
Written by Bala Clark
Related protips
11 Responses
Hi,
I tried this solution, but I still have the same exception on large files (log files ~200Mb)
The only way i found is to use line-by-line plugin : https://npmjs.org/package/line-by-line
data:image/s3,"s3://crabby-images/5a39d/5a39d06e289867a6eadd09c357735800feab1d9a" alt=""
snake51's setup must have been faulty because this code works great. I read a 7.5GB file containing over 800 million lines.
data:image/s3,"s3://crabby-images/bbbde/bbbde1aaf93504916352605a5cdeaab22cbf13a0" alt=""
Nice and clean solution without requiring any third party modules.
data:image/s3,"s3://crabby-images/bf688/bf688707d39e29ff98e2714bb515221dc2188baa" alt=""
For some reason, it works up until the last line.
data:image/s3,"s3://crabby-images/57bbf/57bbf49a92d70dc6e06a84e7fab404b8d9b56d8a" alt=""
I'm having the same issue as jake_nerdist. Thinking I'll just append a \n to the file before I start processing it.
data:image/s3,"s3://crabby-images/6bfbd/6bfbdee842b8504f181e589d3d1c13f77ca9f277" alt=""
how do you limit the number of lines to look at. I'm just trying to debug the workflow and don't want to read the whole file every time.
data:image/s3,"s3://crabby-images/6bfbd/6bfbdee842b8504f181e589d3d1c13f77ca9f277" alt=""
also how do you change the encoding to utf-8?
data:image/s3,"s3://crabby-images/b3f46/b3f4687aef6130e2d23116e6ea75d1bc4b15ae51" alt=""
Is there a way to read with a different separator (',' or '#' instead of '\n')? official documentation do not specify a parameter for that.
data:image/s3,"s3://crabby-images/5f32f/5f32f872654d44d8348e3ab90e2be60ea6f65957" alt=""
I'm trying to build a Straming for big audio files and serve to the browser,
I'm try with this part of code:
res.setHeader("content-type", "audio/mpeg");
var stream = fs.createReadStream('record.mp3', { bufferSize: 64 * 1024 });
stream.pipe(res);
But the problem with this is that when I put the URL into the audio tag (for example).
audio>
source src="http://127.0.0.1:8080/record.mp3" />
/audio>
Node.js read the entire file and send the complete file to the browser.
I'm working with audio files that they size is biggest that 500 mb.
Thanks.
data:image/s3,"s3://crabby-images/bd9c3/bd9c32f6481ab51e5428d6a87ae21488cef39fa5" alt=""
Great article. I haven't been able to find something so clear on this type of issue. Great job.
data:image/s3,"s3://crabby-images/cf039/cf03982990311cc14c653fe7f7676677720d174a" alt=""
getting errors in for extended ascii chars °C. Do you have any clue why this happens. fs.createReadStream seems to work fine...but createInterface seems to give problems.