Node.js
- Summary
-
Discussion
- What's the context for the creation of Node.js?
- What sort of applications can benefit from Node.js?
- How does Node.js work under the hood?
- Could you share more details on the event loop?
- Could you share more details on workers?
- For my next web app, should I use Node.js or Express.js?
- What are some success stories with Node.js adoption?
- What are some useful resources for a Node.js developer?
- Milestones
- Sample Code
- References
- Further Reading
- Article Stats
- Cite As
Since its birth in 1995, JavaScript has established itself as the de facto programming language on the client side of a web application. It executes within a web browser and thereby delivers more dynamic content and makes user experience more interactive. However, to execute code on the server side, we had PHP, ASP, Perl, Python, etc. Until Node.js, there was no popular JavaScript support on the server side.
Node.js is a JavaScript runtime that can be executed on servers, that is, outside a web browser environment. By default, it's based on Google's V8 JavaScript engine. It's open source and cross platform. It's steered by the Node.js Foundation.
Node.js adopts an event-driven architecture and asynchronous I/O. This enables it to scale better, particularly for real-time web apps or apps that do a lot of I/O. The Node.js ecosystem includes thousands of packages and frameworks.
Discussion
-
What's the context for the creation of Node.js? The web was invented based on the client-server model. Clients (such as web browsers) request the server for a resource. The server serves the content as a response. In this model, the server cannot initiate a response. Even if data has changed on the server, it has to wait for the client to give a request. This was alright when users were passive consumers of information.
When social sites such as Facebook and Twitter arrived, everyone became a potential producer of information. There was a rise of chat apps, multi-user gaming and apps for real-time collaboration. We needed a method for servers to push data to clients. While Flash and Java Applets enabled this, they were isolated environments that used non-standard ports.
Secondly, typical web servers launch a new thread to handle every client request. This means that scalability is limited by memory and the penalty of switching across threads.
Node.js solves these problems by using single-threaded event-driven processing. It offloads I/O tasks to worker threads and processes them asynchronously via callbacks. Ultimately, this makes it easier for us to develop scalable real-time apps.
-
What sort of applications can benefit from Node.js? Node.js is suited for apps that have lots of database accesses or waits on network connections. When there's a need to scale your app to thousands of parallel requests, Node.js does this well without hitting performance limits. On the flip side, Node.js is not suited for CPU-intensive tasks, which will block the main thread.
With Node.js, stream processing of data is possible. Worker threads do this processing. It's also good for queueing inputs for later batch processing.
Node.js with Socket.IO makes it easy to build real-time apps such as chat apps or games. It can be used as a proxy to handle many simultaneous connections. Apps with rich real-time dashboards can be created. Microservices architecture can be implemented with Node.js.
If your codebase spans both client and server concerns, Node.js helps you to write in a single language, JavaScript. This makes it easier to later refactor the code if necessary. JavaScript is a natural fit for transferring JSON data or working with object databases such as MongoDB without the extra processing of encoding or decoding.
-
How does Node.js work under the hood? When a Node app starts, callbacks are registered for events. A callback is nothing more than executable code that must be called when the event occurs. After this initialization phase, Node enter the Event Loop. In this loop, Node waits for events to happen and trigger the appropriate callbacks. It's for this reason Node.js is said to use event-driven programming paradigm.
For example, a client requests a web page. Event loop will invoke the associated callback. This is synchronous: event loop will wait for the callback to complete. However, if the callback requires some data from a database, the event loop being a single thread will get blocked since I/O is slower compared to CPU. Other events will start queueing up.
To prevent this, Node.js adopts non-blocking asynchronous I/O: slow tasks will be handed over to the Worker Pool. This frees the event loop to move on the next event. When a worker completes its task, it will signal an event, at which point, the event loop will process its callback synchronously.
-
Could you share more details on the event loop? Event loop is also called main loop, main thread, or event thread. It's where code executes synchronously, that is, the event loop will wait until execution completes. If there are asynchronous calls to be made, event loop will register their callbacks and handover the tasks to worker pool. The idea is to perform only lightweight tasks on the event loop so that it can handle as many requests as possible. Throughput (requests per second) is an important concern for the event loop.
It's important to note that the application and the event loop run within a single thread. All events are processed in the same thread. Pending events are not stored in a single queue. Rather, the event loop is a set of phases, with each phase having events queued for processing.
-
Could you share more details on workers? Worker Pool manages a number of threads that can be used for both I/O-intensive or CPU-intensive tasks. The worker pool maintains a queue of tasks to be processed. When a worker becomes available, it's assigned a task.
Both event loop and worker threads make use of
libuv
, a multi-platform support library for asynchronous I/O. It's implemented in C. Since operating systems often provide asynchronous interfaces, libuv will use these in preference to its own thread pool.Since Node v10.5.0, on an experimental basis, it's been possible to create pools, specify the number of workers or have control of one worker communicating with another. This is part of the
worker-threads-pool
package. -
For my next web app, should I use Node.js or Express.js? Express is a web application framework built on top of Node. You can build a web app with either of these but development will be faster when built with Express. Even better is to adopt the MEAN stack. This is a technology stack that combines MongoDB, Express, Angular and Node.
Having said this, developers have a choice. Express is not the only Node.js framework. Others include hapi, koa or Sails. For fullstack, Meteor, Feathers or Keystone are alternatives to MEAN.
What if you're building a REST API? In this case, performance is important. Express may be too heavy and slow for building REST API endpoints or an API gateway. You could use Node directly but there are Node frameworks that are minimalistic and optimized for REST APIs: fastify, restana, restify, koa, polka.
-
What are some success stories with Node.js adoption? Paypal built a Node.js app in half the time with 33% fewer lines of code compared to its Java codebase. LinkedIn's mobile app using Node.js backend is 20x faster and uses only 3 servers compared to 30 that Ruby on Rails needed. At Netflix, Node.js has reduced app startup time by 70%. Groupon web pages are 50% faster with Node.js compared to Rails. They can also serve much higher traffic. At GoDaddy, they now require 10x fewer servers and time-to-first-byte is down to 12ms from 60ms.
Uber is able to process 2 million remote procedure calls per second, thanks to Node.js. Medium is now able to deploy faster. At NASA, by moving to a single database and Node.js they reduced access times by 300%.
-
What are some useful resources for a Node.js developer? Guides and official documentation are available from the main Node.js site. For latest news, you can follow the Node.js Foundation website. The Foundation's site includes resources and case studies.
Among the package managers for Node.js are npm and yarn. As of October 2018, the npm site hosts about 800,000 JavaScript packages. Node Frameworks gives a list of frameworks to consider. To install and manage multiple versions of Node, use Node Version Manager (NVM).
A video series by Net Ninja titled Node JS Tutorial for Beginners is a good place to start for beginners.
A curated list of Node.js resources is available from Angular Minds.
Milestones
1995
2014
Node.js community undergoes a split, with the fork named io.js. This is because some feel that Node.js updates are slow, and even after five years the library is still in version 0.x. Some also note that Node.js is controlled by Joyent and it's less open than desired. In January 2015, v1.0.0 of io.js is released.
2015
Joyent, IBM, Microsoft, PayPal, Fidelity, SAP and The Linux Foundation come together to establish Node.js Foundation. The Foundation will see that Node.js is managed in a more open manner and have regular releases. In June, Linux Foundation announces that Node.js and io.js will merge their codebases.
2015
2015
2016
Sample Code
References
- Agarwal, Rachit. 2014. "Why use ExpressJS over NodeJS for Server-Side Development?" Blog, Algoworks, August 22. Accessed 2018-10-27.
- Capan, Tomislav. 2013. "Why The Hell Would I Use Node.js? A Case-by-Case Tutorial." Toptal. Accessed 2018-10-27.
- Chauhan, Shailendra. 2015. "Brief history of node.js and io.js." DotNetTricks, December 31. Accessed 2018-10-27.
- Chrzanowska, Natalia. 2017. "6 Types of Applications You Can Build With Node.js." Netguru, September 14. Accessed 2018-10-27.
- Collina, Matteo and Jinwoo Lee. 2018. "Node.js can HTTP/2 push!" Node.js Collection, on Medium, April 12. Accessed 2018-10-27.
- Gopi, Arun. 2016. "MEAN Stack – A Getting Started Guide." Reflections, May 04. Accessed 2018-10-27.
- Hamedani, Mosh. 2018. "How Node.js Works." Programming with Mosh, YouTube, January 25. Accessed 2018-10-27.
- JSConf. 2009. "The Speakers of 2009." The European JavaScript Conference, JSConf Berlin, November 7 & 8. Accessed 2018-10-27.
- Jaiswal, Abhishek. 2014. "Client-Side vs Server-Side Programming Languages." C# Corner, February 25. Accessed 2018-10-27.
- Joyent. 2015. "Joyent Moves to Establish Node.js Foundation." Press Room, Joyent, February 10. Accessed 2018-10-27.
- Khan, Daniel. 2017. "What you should know to really understand the Node.js Event Loop." Node.js Collection, July 20. Accessed 2018-10-27.
- Langer, Mike. 2017. "Common Uses for Node.js." DZone, October 13. Accessed 2018-10-27.
- Mardan, Azat. 2018. "Node Frameworks." Accessed 2018-10-27.
- Maso, Rolando Santamaria. 2018. "NO, you most probably don’t need Express in your Node.js REST API." Medium, June 10. Accessed 2018-10-27.
- McKenzie, Sebastian, Christoph Nakazawa, and Jamie Kyle. 2016. "Yarn: A new package manager for JavaScript." Facebook, October 11. Accessed 2018-10-27.
- NPM. 2018. "Homepage." NPM. Accessed 2018-10-27.
- Nemeth, Gergely. 2018. "History of Node.js on a Timeline." Blog, RisingStack, March 21. Accessed 2018-10-27.
- Node. 2018a. "Resources." Accessed 2018-10-29.
- Node. 2018b. "2018 Node.js User Survey Report." Accessed 2018-10-27.
- Node Blog. 2015. "Node v4.2.0 (LTS)." October 12. Accessed 2018-10-27.
- Node Docs. 2018. "Don't Block the Event Loop (or the Worker Pool)." Guides, October 26. Accessed 2018-10-27.
- Node GitHub. 2015. "2015-01-14 io.js v1.0.0 Release." January 14. Accessed 2018-10-27.
- Node GitHub. 2018. "node-v0.x-archive: Releases." Accessed 2018-10-27.
- Node.js Foundation. 2018. "About The Node.js Foundation." Accessed 2018-10-27.
- Orsini, Lauren. 2013. "What You Need To Know About Node.js." ReadWrite, November 07. Accessed 2018-10-27.
- Pal, Prince. 2016. "12 Benefits of Using Node.js For Web Applications." Think 360 Solutions, November 21. Accessed 2018-10-27.
- Pluszczewska, Bianka. 2016. "9 Famous Apps Built with Node.js." Blog, Brainhub, May 30. Updated 2018-08-30. Accessed 2018-10-27.
- Prasad, Kiran. 2017. "10 best Node.js app examples." ThinkMobiles, May 10. Accessed 2018-10-27.
- Schlueter, Isaac. 2009. "Preview: npm, the node package manager." nodejs, Google Groups, October 01. Accessed 2018-10-27.
- Seth, Gaurav. 2016. "Submitting a Pull Request to Node.js with ChakraCore." Windows Blog, Microsoft, January 19. Accessed 2018-10-27.
- Tech Insider. 1995. "Netscape and Sun Announce JavaScript, the Open, Cross-Platform Object Scripting Language for Enterprise Networks and the Internet." December 05. Accessed 2018-10-27.
- Williams, Owen. 2015. "Node.js and io.js are settling their differences, merging back together." The Next Web, June 16. Accessed 2018-10-27.
- Worker Threads Pool GitHub. 2018. "watson/worker-threads-pool." GitHub, October 15. Accessed 2018-10-27.
- libuv GitHub. 2018. "libuv/libuv." GitHub, October 23. Accessed 2018-10-27.
Further Reading
- Posa, Rambabu. 2015. "Node JS Architecture – Single Threaded Event Loop." JournalDev, April 08. Updated 2016-07-21. Accessed 2018-10-29.
- Kadlecsik, Tamas. 2016. "Understanding the Node.js Event Loop." Blog, RisingStack, November 01. Accessed 2018-10-29.
- Pluszczewska, Bianka. 2016. "9 Famous Apps Built with Node.js." Blog, Brainhub, May 30. Updated 2018-08-30. Accessed 2018-10-27.
- Node Docs. 2018. "Don't Block the Event Loop (or the Worker Pool)." Guides, October 26. Accessed 2018-10-27.