Bird
Raised Fist0
Node.jsframework~8 mins

Reading files with promises (fs.promises) in Node.js - Performance & Optimization

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Performance: Reading files with promises (fs.promises)
MEDIUM IMPACT
This affects how quickly file data is read and made available without blocking the main event loop, improving server responsiveness.
Reading a file in Node.js without blocking the event loop
Node.js
import { promises as fs } from 'fs';
async function readFile() {
  const data = await fs.readFile('file.txt', 'utf8');
  console.log(data);
}
readFile();
Reads file asynchronously, allowing Node.js to handle other tasks while waiting for file I/O.
📈 Performance GainNon-blocking I/O improves input responsiveness and server throughput.
Reading a file in Node.js without blocking the event loop
Node.js
const fs = require('fs');
const data = fs.readFileSync('file.txt', 'utf8');
console.log(data);
This blocks the entire Node.js event loop until the file is fully read, causing delays in handling other requests.
📉 Performance CostBlocks event loop for duration of file read, causing poor input responsiveness (INP).
Performance Comparison
PatternEvent Loop BlockingThroughput ImpactResponsivenessVerdict
Synchronous fs.readFileSyncBlocks event loopReduces throughputPoor (blocks input)[X] Bad
Asynchronous fs.promises.readFileNon-blockingImproves throughputGood (responsive)[OK] Good
Rendering Pipeline
Reading files with promises does not directly affect browser rendering but impacts server responsiveness and how fast data can be sent to clients.
Event Loop
I/O Operations
⚠️ BottleneckBlocking synchronous file reads block the event loop, delaying all other operations.
Optimization Tips
1Never use synchronous file reads in production server code.
2Use fs.promises to read files asynchronously and keep the event loop free.
3Asynchronous file reads improve server responsiveness and throughput.
Performance Quiz - 3 Questions
Test your performance knowledge
What is the main performance benefit of using fs.promises.readFile over fs.readFileSync?
AIt reduces file size on disk
BIt reads files without blocking the event loop
CIt reads files faster from disk
DIt caches files automatically
DevTools: Node.js Inspector (Debugger)
How to check: Run your Node.js app with --inspect flag, open Chrome DevTools, record CPU profile while reading files synchronously and asynchronously.
What to look for: Look for event loop blocking time and CPU idle time; synchronous reads show blocking, async reads show free event loop.

Practice

(1/5)
1. What does fs.promises.readFile return when reading a file in Node.js?
easy
A. The file content directly as a string
B. A promise that resolves with the file content
C. A callback function to handle the file content
D. An event emitter for file reading progress

Solution

  1. Step 1: Understand fs.promises.readFile behavior

    This method returns a promise that will resolve when the file is read successfully.
  2. Step 2: Identify the return type

    Since it returns a promise, you can use await or .then() to get the file content asynchronously.
  3. Final Answer:

    A promise that resolves with the file content -> Option B
  4. Quick Check:

    fs.promises.readFile returns a promise [OK]
Hint: Remember: fs.promises methods always return promises [OK]
Common Mistakes:
  • Thinking it returns file content directly
  • Confusing with callback-based fs.readFile
  • Expecting an event emitter
2. Which of the following is the correct syntax to read a file using fs.promises.readFile with async/await?
easy
A. const data = await fs.promises.readFile('file.txt');
B. const data = fs.promises.readFile('file.txt');
C. fs.promises.readFile('file.txt', (err, data) => {});
D. await fs.readFile('file.txt', 'utf8');

Solution

  1. Step 1: Use async/await with promises

    To get the file content, you must await the promise returned by fs.promises.readFile.
  2. Step 2: Check syntax correctness

    const data = await fs.promises.readFile('file.txt'); correctly uses await with fs.promises.readFile. const data = fs.promises.readFile('file.txt'); misses await, C uses callback style which is incorrect here, and D uses wrong module method.
  3. Final Answer:

    const data = await fs.promises.readFile('file.txt'); -> Option A
  4. Quick Check:

    Use await with fs.promises.readFile [OK]
Hint: Always await promises to get their resolved value [OK]
Common Mistakes:
  • Omitting await and expecting immediate data
  • Using callback style with promises API
  • Mixing fs and fs.promises methods
3. What will be logged by this code snippet?
import { promises as fs } from 'fs';

async function read() {
  const content = await fs.readFile('example.txt', 'utf8');
  console.log(typeof content);
}

read();
medium
A. 'undefined'
B. 'object'
C. 'string'
D. Throws an error

Solution

  1. Step 1: Understand readFile with encoding

    When you pass 'utf8' as the second argument, the promise resolves with a string containing the file content.
  2. Step 2: Check the logged type

    The typeof operator on a string returns 'string', so the console logs 'string'.
  3. Final Answer:

    'string' -> Option C
  4. Quick Check:

    readFile with 'utf8' returns string [OK]
Hint: Add 'utf8' to get string, else Buffer is returned [OK]
Common Mistakes:
  • Forgetting encoding returns Buffer, not string
  • Expecting 'object' type for file content
  • Not awaiting the promise before logging
4. Identify the error in this code snippet:
import { promises as fs } from 'fs';

async function readFile() {
  const data = fs.readFile('data.txt', 'utf8');
  console.log(data);
}

readFile();
medium
A. Missing await before fs.readFile call
B. Wrong import syntax for fs.promises
C. readFile does not exist in fs.promises
D. Encoding 'utf8' is invalid here

Solution

  1. Step 1: Check asynchronous call handling

    The fs.readFile returns a promise, so to get the file content, you must await it.
  2. Step 2: Identify the missing await

    Without await, data is a promise object, so logging it shows a promise, not file content.
  3. Final Answer:

    Missing await before fs.readFile call -> Option A
  4. Quick Check:

    Always await promises to get resolved value [OK]
Hint: Await promises before using their results [OK]
Common Mistakes:
  • Logging promise instead of awaited result
  • Confusing import syntax for fs.promises
  • Passing wrong encoding string
5. You want to read multiple files ['a.txt', 'b.txt', 'c.txt'] concurrently using fs.promises.readFile and get their contents as strings. Which code snippet correctly does this?
hard
A. const contents = await fs.readFile(files, 'utf8');
B. const contents = files.map(f => await fs.readFile(f, 'utf8'));
C. const contents = files.forEach(async f => await fs.readFile(f, 'utf8'));
D. const contents = await Promise.all(files.map(f => fs.readFile(f, 'utf8')));

Solution

  1. Step 1: Understand concurrent reading with Promise.all

    To read multiple files concurrently, map each filename to a promise and use Promise.all to await all results.
  2. Step 2: Analyze each option

    const contents = await Promise.all(files.map(f => fs.readFile(f, 'utf8'))); correctly maps files to promises and awaits them all. const contents = files.map(f => await fs.readFile(f, 'utf8')); uses await inside map callback which is invalid syntax. const contents = files.forEach(async f => await fs.readFile(f, 'utf8')); uses forEach which returns undefined. const contents = await fs.readFile(files, 'utf8'); tries to read multiple files at once, which is invalid.
  3. Final Answer:

    const contents = await Promise.all(files.map(f => fs.readFile(f, 'utf8'))); -> Option D
  4. Quick Check:

    Use Promise.all with map for concurrent reads [OK]
Hint: Use Promise.all with map to await multiple promises [OK]
Common Mistakes:
  • Using await inside map callback directly
  • Using forEach which returns undefined
  • Trying to read multiple files in one readFile call