Skip to main content

NodeJS Internals and Architecture

21h 9m 56s
English
Paid

Course description

My favorite part of engineering is making complex systems transparent and understandable.

Node.js is one of the most popular runtimes for server development, yet it often remains a "black box" even for experienced developers. I myself have felt this many times.

This course is the result of months of work on dissecting the architecture and internal mechanisms of Node.js. It is designed for those engineers who cannot work with something opaque.

Read more about the course

This course is for you if you:

  • Want to understand what's happening "under the hood" of Node.js
  • Enjoy dissecting one line of code into hundreds of lines of implementation
  • Wonder why the behavior of a Node program is sometimes unpredictable
  • Want to know why a Node process can terminate - or not terminate
  • Are curious why Node sometimes takes a long time to start
  • Value cross-platform compatibility and want to learn how Node works on all OS

For instance, by knowing how the HTTP module is constructed, you will be able to write a server that handles more requests. Understanding the event loop and its phases will allow you to restructure code logic for improved performance and stability.

If your code "crashes" 1% of the time for reasons that aren't clear - this course will give you an understanding of how to make program behavior predictable. Not with chaotic "quick fixes," but through a deep understanding of the internal workings of Node.

The course will teach you to go in the same direction as Node, rather than "fighting" with its mechanisms.

The course program includes:

Node.js Architecture

  • Phases of the event loop and what happens in each of them
  • How promises work and why they are just "new type of callbacks"
  • Module loading and its impact on performance
  • The structure of Node packages and how it affects your code

Inside Node.js

  • How Node implements asynchronous I/O through libuv
  • Protocols and their implementation in Node
  • Streams and processes: how Node handles concurrency at the OS level

Optimization and Performance

  • Tips on speeding up code based on architectural understanding
  • How to identify "bottlenecks" and work with them
  • When and how to use C++ extensions if JavaScript is no longer sufficient

This course is designed for developers with an intermediate level of knowledge in Node.js who want to deepen their understanding of its architecture and increase their confidence in working with it.

It's advisable to have a general understanding of OS basics, although this is not strictly necessary.

Watch Online

This is a demo lesson (10:00 remaining)

You can watch up to 10 minutes for free. Subscribe to unlock all 43 lessons in this course and access 10,000+ hours of premium content across all courses.

View Pricing
0:00
/
#1: Introduction

All Course Lessons (43)

#Lesson TitleDurationAccess
1
Introduction Demo
01:57
2
Who this course for?
03:06
3
Course Data
00:50
4
Course Outline
06:59
5
What do you need?
06:24
6
Node JS Architecture Intro
09:30
7
Interpreted Languages and V8
49:02
8
The Event Loop
24:14
9
The Main Module
19:39
10
Timers Phase
26:11
11
Pending Callbacks Phase
14:03
12
Idle, Prepare Phase
18:23
13
Poll Phase (Updated)
47:49
14
Check Phase
23:07
15
Close Callbacks Phase
24:08
16
Process.nextTick
16:46
17
How Promises work under the hood
22:44
18
Require, Import Event
34:12
19
Anatomy of Node Packages
32:35
20
When does Node terminate?
20:31
21
Node Internals Section Intro
06:42
22
libuv Overview
08:05
23
Asynchronous IO in the Operating System
29:35
24
Inside Node Network IO
43:36
25
Inside Node File IO
51:51
26
Inside Node HTTP
01:14:04
27
Inside Node HTTPS
01:00:56
28
Inside Node DNS
48:00
29
Inside Node TCP
48:37
30
Inside Node UDP
34:03
31
Inside Node Streams
01:03:12
32
Process vs Thread
01:00:38
33
Worker Threads
51:55
34
Child Process and Cluster
36:31
35
Optimization Section Intro
13:23
36
Node Performance
39:36
37
Debugging NodeJS
08:07
38
Capturing Node's Traffic
32:36
39
Request modules performance showdown
22:24
40
C++ Add-ons
39:22
41
Course Summary
08:39
42
Proxy vs Reverse Proxy
20:06
43
Memcachd and NodeJS
01:05:48

Unlock unlimited learning

Get instant access to all 42 lessons in this course, plus thousands of other premium courses. One subscription, unlimited knowledge.

Learn more about subscription

Comments

0 comments

Want to join the conversation?

Sign in to comment

Similar courses

Understanding Node.js: Core Concepts

Understanding Node.js: Core Concepts

Sources: udemy
Welcome to the most comprehensive Node.js course on the internet! In this course, we're going to do a deep dive into Node.js itself without cluttering our minds
36 hours 3 minutes 40 seconds
Complete Node.js Developer in 2023: Zero to Mastery

Complete Node.js Developer in 2023: Zero to Mastery

Sources: zerotomastery.io
Learn from Node.js experts. This is the only Node JS tutorial + projects course you need to learn Node, build advanced large-scale applications from scratch & g
46 hours 5 seconds
Just Express (with a bunch of node and http). In detail.

Just Express (with a bunch of node and http). In detail.

Sources: udemy
You have some notion of what Node, Express, and http are or you wouldn't be here. Node and back-end JavaScript have taken the world by storm, [SOME BIG COMPANY] moved to node an...
12 hours 33 minutes 3 seconds
Docker for Node.js Projects From a Docker Captain

Docker for Node.js Projects From a Docker Captain

Sources: udemy
Welcome to the best course on the planet for using Docker with Node.js! With your basic knowledge of Docker and Node.js in hand, Docker Mastery for Node.js is a
8 hours 14 minutes 12 seconds
Learn Node

Learn Node

Sources: wesbos
Learn to build applications and APIs with Node.js Node.js, Express, MongoDB and friends are some of the most in-demand web development skills. This course is th
9 hours 52 minutes 53 seconds