NodeJS Internals and Architecture
- Descrição
- Currículo
- FAQ
- Revisões
My favorite thing in software engineering is the art of making it transparent.
Node is one of the most popular runtimes used on backend engineering yet I feel it is the least understood. I surely felt this way at times.
I spent months working on a course to demystify NodeJS Internals and Architecture and distilled this in this comprehensive course.
I built this course is for the engineers who can’t stand working with something opaque.
They love to understand what is running behind the engine.
They enjoy tearing apart 1 the line of code into its original 1000 lines.
They question why is the output of a Node program is unpredictable.
They want to know when does the Node process exit.
They want to know why Node takes so long to start in some cases.
They appreciate how Node works on all operating systems and would like to know how it does that.
For example by understanding the internals of HTTP module, you can write a backend in Node that accepts and process more requests. Every line of code you write you would think of how and when Node will process it.
By understanding the event loop and the different stages you can tune and re-order your code to achieve best performance and even consistent result.
Ever wrote a program in Node that fails 1% of the time while succeeds 99%? Understanding Node architecture helps you make your program predicable. As opposed to adding workaround because you don’t understand. We all did that.
It is all about removing blockage and letting the main loop phases “breath”. When we build software the problem is we often go against the grain. Understanding where the friction is in Node allow you to work with it as oppose to against it.
In this course I cover the following
– NodeJS Architecture
I cover the various phases in the event loop and what exactly happens in each phase, how promises are just callbacks, how and when modules are loaded and their effect on performance, Node packages anatomy and more
– Node Internals
This is where we go one layer deeper, how Node truly achieves asynchronous IO with libuv, and how each protocol in node is implemented. How concurrent node works on both user level threads and process level.
– Node Optimization and Performance
Now that we understand the internals and architecture of Node, this is where we discuss tips how to make the code runs more efficiently and more performance. And only when we exhaust all other avenues Node provides ways to extend it with C++ add-ons where JavaScript just can’t no longer hold.
This course is for intermediate students who are familiar with Node and want to understand how it works. While not required, I recommend taking the fundamentals of operating system course as a prerequisite of this course.
-
1IntroductionVídeo Aula
Welcome to Node Internals and Architecture course. If you choose this course chances that you have already use Node. This is not a course about how to get started with NodeJS, it is a course to understand everything there is about the internals of NodeJS so you can take advantage of it.
-
2Who this course for?Vídeo Aula
This course for software engineers who use Node and want to take their understanding of this runtime to the next level. Write efficient code, optimize Node, and take advantage of Node various features to unlock potentials.
-
3Course DataVídeo Aula
Because this course will dive into the bowls of the OS, I recommend taking my fundamentals of operating systems.
-
4Course OutlineVídeo Aula
-
5What do you need?Vídeo Aula
Any OS will work, Linux or Mac machine preferred since we will use the various tooling on UNI* not available on Windows.
Node version 20-22
-
6Node JS Architecture IntroVídeo Aula
-
7Interpreted Languages and V8 (UPDATED)Vídeo Aula
We discuss how compiled and Interpreted languages work, and how V8 the engine behind Node can compile javascript to machine code if the function is hot.
-
8The Event LoopVídeo Aula
This is an overview of the event loop, a critical piece of the Node runtime.
-
9The Main ModuleVídeo Aula
Before anything can run, we synchronously execute all code in the main module before we event start the loop. This is called the initial phase.
-
10Timers PhaseVídeo Aula
-
11Pending Callbacks PhaseVídeo Aula
-
12Idle, Prepare PhaseVídeo Aula
-
13Poll PhaseVídeo Aula
-
14Check PhaseVídeo Aula
-
15Close Callbacks PhaseVídeo Aula
-
16Process.nextTickVídeo Aula
-
17How Promises work under the hoodVídeo Aula
We explain how promises, async await are callbacks behind the scenes.
-
18Require, Import EventVídeo Aula
-
19Anatomy of Node PackagesVídeo Aula
-
20When does Node terminate?Vídeo Aula
Node exits when there is no code to execute. While it may appear that we don't have any code executing, Node is working behind the scenes, example is listening, accepting and reading from connections.
We will do an strace to prove that while we appear to not have any code running, Node still does.
-
21Node Internals Section IntroVídeo Aula
-
22libuv OverviewVídeo Aula
Go through the libuv io phases, event loop, thread pool
-
23Asynchronous IO in the Operating SystemVídeo Aula
The OS course
-
24Inside Node Network IOVídeo Aula
In this lecture we discuss how node performs network io as a client and as a server
-
25Inside Node File IOVídeo Aula
show that passing file descriptors are faster.
how it works
reading sync vs async ,
do strace
-
26Inside Node HTTPVídeo Aula
What is really happening?
-
27Inside Node HTTPSVídeo Aula
-
28Inside Node DNSVídeo Aula
-
29Inside Node TCPVídeo Aula
-
30Inside Node UDPVídeo Aula
-
31Inside Node StreamsVídeo Aula
We discuss NodeJS streams
-
32Process vs ThreadVídeo Aula
OS course
-
33Worker ThreadsVídeo Aula
-
34Child Process and ClusterVídeo Aula
