Skip to main content

"NodeJS Basics" Theory That You Should Know

To know better about NodeJS, you should know Javascript. So I start with Javascript

  • Javascript is in top 3 language.
  • JavaScript is developed on December 4, 1995. It was a client-side scripting language. So it was used only in browsers.
  • Javascript uses Javascript engine that is used by browsers to convert code into machine code.
  • We have multiple JavaScript engines just like we have different browsers like Firefox, Chrome, internet explorer, edge etc.
  • First JavaScript engine was SpiderMonkey developed by Netscape Communication by the creator of JavaScript Brendan Eich and it was developed in 10 days.
  • Different browsers are using a different type of Javascript Engine:-
    • Internet Explorer is using Chakra
    • Firefox is using Spidermonkey
    • Chrome is using V8
    • Microsoft Edge is rebuild using a chromium-based browser and now it is using V8 engine.
  • Most Famous engine is now V8 Javascript engine because it is faster and can be used for mobile development, desktop app development and now server-side development.
  • For server-side development, V8 engine is used to build a Runtime Environment which will work on the machine and it is named as NodeJS.
NodeJS is not a programming language and not a framework. It is a basically a Runtime Environment where you can run JavaScript.
  • Using NodeJS, you can run javascript code on a standalone physical machine.
  • You can build a standalone application using NodeJS.
  • NodeJS is not a framework so we need some framework to work with NodeJS, So we got ExpressJS.
  •  NodeJS has NPM (Node Package Manager) that has a huge database of modules that you can use them or you can publish your own module in NPM.

In simple words, NodeJS is the Javascript runtime environment which uses Javascript V8 engine.

What is NodeJS?
  • NodeJS uses a single thread to handle the request/response from clients.
  • Suppose, you have 100 clients and server takes 3 seconds to complete the one client's request then 100th client needs to wait for 3000 sec to get served by the NodeJS application.
  • So, resolve the above issue single thread don’t wait for the response from the server and then the single thread will not be blocked for a single client.
  • But how it will work? NodeJS uses two concepts:-
    •     Asynchronous
    •     Non-blocking I/O
  • Non-blocking I/O means whenever you get the request from the client then the single thread will send the request to someone else, So current thread will not be busy working with that request.

  • In the above image, Single thread will send the request to the worker and will take another request from the client. If a single thread gets another request from the client then again single thread assign the task to another worker and that worker will process the task and then the single thread will come back to accept the response. This is done by Asynchronous function using callback from the individual workers.
  • So we have one question, If NodeJS does not support the multiple threads then how we are able to create these workers?
  • To answer the above question, NodeJS uses the concept of “libuv”. libuv is the special library built for NodeJS but we can use other applications as well.
  • Libuv provides the concept of non-blocking I/O. It is built in C language which uses the system kernel and kernel has multiple threads. So, In NodeJS, you are not using multiple threads. behind the scene, your kernel is implementing the multiple threads. So above these workers are threads that make NodeJS fast and flexible.

What is NPM?
  • NPM stands for Node Package Manager.
  • NPM provides various types of already built modules like api for connecting the application with database
  • Modules can be built by anyone and distribute to the NPM for sharing with others.
  • Modules can be anything like a simple calculation program, array handling etc.
  • NodeJS has lots of inbuilt modules like http, fs(file system) to access system files for read/write operations, cryptography for security. 


Popular posts from this blog

LinkList implementation with Insert, InsertAt, Delete Methods in Java

Linklist Representation   public class Node { int data ; Node next ; Node( int data , Node next ){ this . data = data ; this . next = next ; } } public class LinkList { Node head ; public void insert( int data ) { Node node = new Node( data , null ); if ( head == null ) { head = node ; } else { Node currentNode = head ; while ( currentNode . next != null ) { currentNode = currentNode . next ; } currentNode . next = node ; } } public void inserAtStart( int data ) { Node node = new Node( data , null ); node . next = head ; head = node ; } public void insertAt( int index , int data ) { Node node = new Node( data , null ); // if index is 0 or head is null then insert at start if ( index == 0 || head == null ) { inserAtStart( data ); } els

How to kill a process running on particular port in Linux

  If port 8080 needs to be kill use below single command: kill -9 $(lsof -t -i:8080) Note: remove -9 from the command, if you don't want to kill the process violently. To list any process listening to the port 8080: lsof -i:8080 Use any port number that you want to kill.

Basics of Java Programming - Part 1

Datatypes in Java int 4 bytes short int 2 bytes long int 8 bytes byte 1 byte float  4 bytes double 8 bytes char 2 bytes Character to ASCII conversion in JAVA          class CharToASCII { public static void main(String a []) { char c1 = 'A' ; char c2 = 'a' ; System. out .print(( int ) c1 ); // OUTPUT: 65 System. out .print(( int ) c2 ); // OUTPUT: 97 System. out .print(( char )66); // OUTPUT: B  --> ASCII to i nt conversion           }        } "printf" is also available in JAVA            class  PrintfInJava {              public   static   void  main(String  a []) { int   i  =  4 ; int   j  =  7 ;                   int   k  =  i+j ; System. out .printf("Addition of %d and %d is %d", i, j, k);  // OUTPUT: 65            }        } Binary  Literals