How NodeJS Works?

แชร์
ฝัง
  • เผยแพร่เมื่อ 6 ม.ค. 2025

ความคิดเห็น • 194

  • @piyushgargdev
    @piyushgargdev  3 หลายเดือนก่อน +7

    Updated and More Detailed Video: th-cam.com/video/_eJ6KAb56Gw/w-d-xo.htmlsi=ddtvGQ0KGNxttB2u

    • @pranav_arya
      @pranav_arya 3 หลายเดือนก่อน

      please provide the link of the slides

  • @AkshaySharma-bg3oj
    @AkshaySharma-bg3oj ปีที่แล้ว +139

    I got this after some research, hope it helps.
    The statement "blocking threads are non-blocking" is not entirely accurate. It's important to make a distinction between the nature of the operation and the execution model:
    Nature of the operation: A blocking operation is one that suspends the execution of the current thread until it completes. This means that while the thread is waiting, it cannot execute any other code.
    Execution model: Node.js utilizes a single-threaded event loop with a pool of worker threads. The event loop is responsible for handling non-blocking I/O and scheduling tasks. Worker threads are used to execute blocking operations asynchronously.
    Therefore, while an individual operation might be blocking, the execution model in Node.js utilizes worker threads and the event loop to manage these blocking operations in a non-blocking manner. This allows the main thread to remain responsive and handle other tasks while the blocking operations are running in the background.
    Here's a more accurate way to express the concept:
    Node.js can handle blocking operations in a non-blocking way by utilizing worker threads and the event loop.
    This statement clarifies that the blocking nature of individual operations doesn't prevent Node.js from being a non-blocking environment overall.
    ------------------------------------------------------------------------------------
    Yes, that's correct. Node.js internally decides whether a task will run on the main thread or a worker thread based on several factors, including:
    * **Nature of the operation:** Long-running and blocking operations are more likely to be assigned to worker threads, while short-lived and non-blocking tasks are typically handled by the main thread.
    * **Available resources:** Node.js considers the available CPU cores and memory when deciding whether to utilize worker threads. If resources are limited, it might prefer to run even blocking tasks on the main thread to avoid overhead.
    * **Application configuration:** Some libraries and frameworks might specify how certain tasks should be handled, influencing whether they run on the main thread or a worker thread.
    * **Node.js version and configuration:** Different versions of Node.js and specific configurations might have different heuristics for deciding when to use worker threads.
    Even for blocking operations like `fs.readFileSync`, Node.js might choose to execute them on the main thread if:
    * The operation is very fast and doesn't significantly block the main thread.
    * Utilizing a worker thread would introduce more overhead than simply waiting for the operation to finish on the main thread.
    * The application is running on a system with limited resources, and using a worker thread would be detrimental to performance.
    Ultimately, Node.js aims to optimize performance and resource utilization by intelligently allocating tasks between the main thread and worker threads. While developers can influence this behavior through libraries, frameworks, and application architecture, the final decision ultimately rests with the Node.js runtime based on its internal analysis.

    • @bm9code
      @bm9code 10 หลายเดือนก่อน

      such deep info in simple terms; thank you

    • @kaustubh9605
      @kaustubh9605 9 หลายเดือนก่อน

      @AkshaySharma-bg3oj great info, where did you found this? can you share any resources

    • @haseebsheikh6101
      @haseebsheikh6101 9 หลายเดือนก่อน

      You explained very well and i hope it would also help others

    • @ashishsharma-uv5un
      @ashishsharma-uv5un 9 หลายเดือนก่อน

      great , thanks for sharing

    • @mecodes
      @mecodes 8 หลายเดือนก่อน

      Thanks for explaining things in very simple terms.

  • @tensorbaba7687
    @tensorbaba7687 2 หลายเดือนก่อน +11

    synchronous (blocking) tasks are handled by the main thread (event loop), while asynchronous (non-blocking) tasks are offloaded to the thread pool (via libuv) or system APIs, allowing the main thread to continue processing other tasks. When async tasks (like I/O or database queries) complete, their callbacks are queued in the event loop for execution. This ensures non-blocking behavior for async operations, while blocking tasks can halt the event loop if not managed properly.

    • @TejasMore-y5r
      @TejasMore-y5r 20 วันที่ผ่านมา

      thanks man i was confused btwn blocking and non-blocking

    • @tensorbaba7687
      @tensorbaba7687 20 วันที่ผ่านมา +1

      @TejasMore-y5r anytime brother ✌️

  • @crix_05
    @crix_05 8 หลายเดือนก่อน +21

    Blocking Requests:
    1. When your code encounters a blocking request (like synchronously reading a large file), it goes directly onto the call stack.
    2. The event loop prioritizes the call stack, and the blocking request is executed immediately.
    3. The entire main thread of Node.js gets tied up waiting for the blocking operation to finish.
    4. The event queue and any asynchronous tasks have to wait until the blocking request completes.
    Asynchronous Tasks and Callbacks:
    1. When your code initiates an asynchronous operation (like reading a file asynchronously), the callback function representing that task is added directly to the event queue.
    2. The callback function doesn't go on the call stack immediately because the asynchronous operation takes time to complete (e.g., waiting for the file to be read).
    3. The event loop continues processing tasks on the call stack, focusing on synchronous tasks.
    4. Only once the call stack is empty does the event loop check the event queue for waiting callbacks.
    5. The event loop picks up the oldest callback from the queue (FIFO) and pushes it onto the call stack.
    6. Now, the callback function gets its turn for execution on the call stack.
    I hope this would help...

  • @Suyash_D
    @Suyash_D 2 หลายเดือนก่อน +5

    One correction: 8 CPU cores don't necessarily mean we can only assign 8 threads. We can assign many more threads, but if the number of threads exceeds the number of cores, the CPU will context switch between them, leading to performance degradation. This happens because each thread consumes system memory in the form of a Thread Control Block (TCB). If frequent Context Switches occur, the CPU core has to frequently read and write the TCB from main memory to the CPU registers, which can degrade the performance.

  • @Raw_Matter
    @Raw_Matter ปีที่แล้ว +5

    Great sir... Really helped me to understand this whole working. Am a fresher and wanted to learn node.js.. literally feels like my elder brother is teaching.. thankyou so much sir

  • @CodeSmasher-o4o
    @CodeSmasher-o4o 9 หลายเดือนก่อน +1

    Wow sir
    I wish I would have got this playlist earlier
    Great Explaination
    👏👏👏

  • @ronaksurve9168
    @ronaksurve9168 7 หลายเดือนก่อน +5

    The synchronous tasks run on a single thread, because JS is a single-threaded language. The thread pool is used only for blocking operations that are CPU-intensive.

  • @sameeravhad6266
    @sameeravhad6266 3 หลายเดือนก่อน +3

    I think, there is mistake. File reading is itself a Async operation.
    If this async task run on main thread (e.g. readFileSync), it will block other operation. That is why this is blocking operation.
    If this async task run on another thread using threadPool, it will not block other operation. That is why this is non- blocking operation.

  • @codeshahar
    @codeshahar 9 หลายเดือนก่อน

    Bro, amazing video with full clarity and increases curiosity to watch ur next videos, great work mate

  • @Omarfaruk-wq5hl
    @Omarfaruk-wq5hl หลายเดือนก่อน

    Thanks for the series learned a lot ❤❤

  • @pabitrapradhan2428
    @pabitrapradhan2428 8 หลายเดือนก่อน +3

    I think you missed to mention one important concept about event demultiplexer. Event demultiplexer watches the I/O resources and once they are done with I/O task then it pushes set of events to the Event Queue and then the callbacks are executed and control comes back to the event queue. It goes in a cycle or loop which we called an event loop.

  • @Solo_playz
    @Solo_playz 10 หลายเดือนก่อน

    You and Telusko sir made it very easy to understand the architecture(how node js works) of node js in a very simplified way. Thank u piyush bhai

  • @Jisto_mj
    @Jisto_mj 2 หลายเดือนก่อน

    After all the confusing tutorials, I found the perfect tutorial to learn Node js

  • @santoshmehla8504
    @santoshmehla8504 9 หลายเดือนก่อน

    You are the one who explain the things in a way to make one comprehend easily.

  • @Nothing-eg9ol
    @Nothing-eg9ol ปีที่แล้ว

    Great Sir understood each line now i can also teach these topics to anyone😍

  • @zafariqbal92
    @zafariqbal92 ปีที่แล้ว +2

    Got a very good clarity. THANKS PIYUSH. Liked and Subscribed. Can we have more of these videos please, that should help in coding interviews!

  • @hack4one
    @hack4one ปีที่แล้ว +5

    hi, i am confused now, i think non-blocking operations are handled by worker threads and blocking operations are handled by main thread. please clear it out.

  • @muhammadnomanamin6650
    @muhammadnomanamin6650 ปีที่แล้ว

    akheer kar diya....
    bhout great
    Ma Sha Allah

  • @AnmolThakur-vv9lf
    @AnmolThakur-vv9lf ปีที่แล้ว

    Understood everything very grateful for this amazing content.

  • @jaikrishna3586
    @jaikrishna3586 4 หลายเดือนก่อน

    You explained it very well. Thank you!

  • @pubgshorts5660
    @pubgshorts5660 9 หลายเดือนก่อน

    great Lecture sir😍

  • @not_amanullah
    @not_amanullah 9 หลายเดือนก่อน

    this series is helpful ❤

  • @pushkargoyal4278
    @pushkargoyal4278 ปีที่แล้ว +19

    Just need to confirm
    Non blocking is asynchronous
    And blocking is synchronous

    • @8creators
      @8creators ปีที่แล้ว +2

      Non blocking is asynchronous!
      And blocking is synchronous !

  • @bulbergaming9142
    @bulbergaming9142 ปีที่แล้ว +4

    brother i think your statement is wrong.Asynchronous task is handled by thread pool while synchronous or blocking task is handled by the main thread.if i am wrong please i am open to your explanation

  • @GoogleUser-nx3wp
    @GoogleUser-nx3wp 2 หลายเดือนก่อน

    Thank you Piyush bhai your lectures help a lot

  • @ishikatiwari1238
    @ishikatiwari1238 ปีที่แล้ว

    Very well explained!
    Thanks!

  • @AkshaySharma-bg3oj
    @AkshaySharma-bg3oj ปีที่แล้ว +8

    thanks dude for the video. Just a sort of suggestion, I think you should not fear on explaining complex topics, thinking viewers if not get it might dislike that.
    I am confused now , node is single threaded. So how come a thread pool with so many threads.
    Secondly if it goes for a worker thread than it should be non blocking no? as each of the task has its own independent thread?
    @Piyush can you help here man.
    Or anyone?

    • @imNavneet_
      @imNavneet_ 11 หลายเดือนก่อน +1

      in blocking opertion node use's C library which is libuv library using this it achives mutli threading and in node cluster module can achive same feature

    • @abhinavsharma7916
      @abhinavsharma7916 10 หลายเดือนก่อน

      bro nodejs is synchronous architecture but it is asynchronous by default just sort it out in a way blocking request executes line by line but when it comes to non blocking operation it executes the operation like which was simple adn easy adn further move to the execution or loops part

  • @technologicalvivek7510
    @technologicalvivek7510 10 หลายเดือนก่อน

    Bhaiya aap bahut sache padhate ho.Aapki voice bahut aachi hai ek dum polite.Aap dikhte bhi bahut smart ho.Thank you bhaiya for this amazing playlist ❤❤❤

  • @shubhamgupta-bl1tr
    @shubhamgupta-bl1tr ปีที่แล้ว +7

    One question.. blocking request run by thread, then who is running non blocking request .. please answer sir

    • @tarushchandra8993
      @tarushchandra8993 ปีที่แล้ว +5

      I'm having the same doubt but lets discuss our points here. So, as per my research, I think in both the cases requests are exceuted by the thread pool only,
      in the blocking requests (Sync) - only 1 thread is used to execute the operation and when it is done, then only 2nd request comes in. so it's like we're not using node.js to its fullest (working as a single threaded system),
      in the non blocking requests (Async) - all the requests gets parallelly exceuted, but still it will be limited to its max thread pool size (for example - 4 or 8 in Piyush's laptop) but here we have the advantage of nodeJS can work on the next task rather than gets stuck like in the case of blocking requests. (working as a multi-threaded system).

    • @piyushgargdev
      @piyushgargdev  ปีที่แล้ว +6

      Node.js uses an event-driven, non-blocking I/O model which makes it well suited for handling concurrent connections and handling a high number of requests. When a request is received, the server creates an event and adds it to an event queue. The event loop then runs and processes the events in the queue one by one. This allows Node.js to handle many requests simultaneously without blocking the execution of other requests. Node.js also uses a callback function, which is executed once the request has been processed, to return the response to the client.
      The event loop is responsible for executing non-blocking requests in Node.js. The event loop is a mechanism that allows Node.js to perform non-blocking I/O operations. It works by continuously running and checking the event queue for new events to process. When a new request is received, it is added to the event queue in the form of an event. The event loop then picks up the event and starts executing it. Once the event has been processed, the callback function associated with the event is called, which sends the response back to the client. This entire process happens in a non-blocking manner, allowing Node.js to handle multiple requests simultaneously without blocking the execution of other requests.

    • @tarushchandra8993
      @tarushchandra8993 ปีที่แล้ว

      @@piyushgargdev Thank you Piyush for clarifying our doubt :)

    • @vaibhavsingh3617
      @vaibhavsingh3617 ปีที่แล้ว +1

      ​​@@piyushgargdevbookish definition, good answer from @tarush

    • @prathameshkambli6991
      @prathameshkambli6991 ปีที่แล้ว

      Its done by thread pool

  • @harleenkaur7751
    @harleenkaur7751 ปีที่แล้ว

    Thanks bhaiya, u really made it easy.

  • @fatimaiqra2169
    @fatimaiqra2169 3 หลายเดือนก่อน

    well explained, thanks!

  • @SanketGanorkar-lb3xn
    @SanketGanorkar-lb3xn 9 หลายเดือนก่อน

    Nicely explained sir

  • @humanAbsu
    @humanAbsu หลายเดือนก่อน +1

    YOU DID MISTAKE "No, blocking operations do not go to the thread pool. Instead, they execute directly on the main thread, which is why they are considered "blocking."

    • @StudyHacksWithAbdullah
      @StudyHacksWithAbdullah หลายเดือนก่อน

      Nope you are wrong
      Non-blocking requests are handled by the Event Loop, which processes tasks asynchronously. This is the ideal behavior for Node.js, as it allows the main thread to handle multiple requests at the same time without being blocked.
      Blocking requests, such as those involving file system operations (e.g., reading large files) or CPU-intensive computations, can block the Event Loop. However, to prevent the main thread from becoming unresponsive, Node.js offloads these blocking operations to worker threads or uses the libuv thread pool. The thread pool handles these operations in parallel, so the Event Loop can continue processing other events while waiting for the blocking task to finish.

  • @8creators
    @8creators ปีที่แล้ว

    Awesome lots of doubt clear !

  • @harshitbhargav6288
    @harshitbhargav6288 9 หลายเดือนก่อน

    Great... Nice explanation

  • @RamrachaiMarma
    @RamrachaiMarma ปีที่แล้ว

    Good explanation. Liked it.

  • @rahul-adani
    @rahul-adani 6 หลายเดือนก่อน

    I first like the lecture then poceed with watching it :)

  • @poojaganvir5631
    @poojaganvir5631 11 หลายเดือนก่อน

    Great explanation. Thank you

  • @shubhamyadav-pf6bv
    @shubhamyadav-pf6bv 9 หลายเดือนก่อน +1

    I think blocking (synchronous) code is executed by single main thread while non- blocking (async) code is delegated to thread from thread pool.

  • @MohammedMusaib-x9e
    @MohammedMusaib-x9e 4 หลายเดือนก่อน

    Superb 🎉🎉

  • @ashmikashandilya9544
    @ashmikashandilya9544 ปีที่แล้ว

    Amazing explanation Thank you so much

  • @kaushikkundu
    @kaushikkundu ปีที่แล้ว

    Excellent video, this video will reach lakhs of views in future

  • @mohsinalijafery2217
    @mohsinalijafery2217 4 หลายเดือนก่อน

    Amazing tutorials 🎉...

  • @aqeelsiddique3471
    @aqeelsiddique3471 ปีที่แล้ว

    very good and easy way explain , i like it thanku

  • @lalitverma8634
    @lalitverma8634 ปีที่แล้ว

    Very good explanation ❤

  • @ASD-mt4mf
    @ASD-mt4mf 10 หลายเดือนก่อน +2

    if my cpu has 8 cores then it has 16 threads right? so why cant i use those 16 threads?

  • @divyanshsharma673
    @divyanshsharma673 5 หลายเดือนก่อน +6

    It's wonderful to see many people pointing out the mistake of Piyush sir, while they know other people have said it already..still writing. I wonder why the Indians perform poor in open-source when such great minds exist !! The comment section is full with the correction of that mistake !!

  • @sugrivlodhi2607
    @sugrivlodhi2607 ปีที่แล้ว

    Good explanations I love it
    Thanks bhaiya

  • @sandeepsolanki193
    @sandeepsolanki193 ปีที่แล้ว +1

    Beautiful explanation
    Easy understood
    Please react ki playlist bhi lekar aao..

  • @chetangoyll6496
    @chetangoyll6496 7 หลายเดือนก่อน

    bhai tu mst pdata hia bro ❤❤❤❤❤❤❤❤❤❤

  • @mitrajanumishra8071
    @mitrajanumishra8071 ปีที่แล้ว +2

    Great explanation bro but can you please make a video on how to fetch data quickly from mongo db with huge number of collection with aggregation and indexing

  • @mpkumar7786
    @mpkumar7786 ปีที่แล้ว

    Good explaination.

  • @varunupadhyay2488
    @varunupadhyay2488 9 หลายเดือนก่อน

    Very good explanation

  • @kamaleshpramanik7645
    @kamaleshpramanik7645 หลายเดือนก่อน

    Piyush - we should write asyn function if it is related to read/write file or network operation .. otherwise other program execution will be blocked for unecessary time ..

  • @topchannel433
    @topchannel433 6 หลายเดือนก่อน

    Very Useful

  • @SonuKumar-uq2rb
    @SonuKumar-uq2rb ปีที่แล้ว

    very easy explaination ever great

  • @deependu__
    @deependu__ ปีที่แล้ว +2

    is 'await' a blocking or non-blocking operation? What about 'then'?

    • @iampiyush100
      @iampiyush100 ปีที่แล้ว

      Now you question is: But if I am using await I need to wait until the response not coming
      So the answer is: Yes, that is correct. When using await, the code will wait for the asynchronous operation to complete before moving on to the next line of code. This means that if the response is not yet available, the code will wait until it is before continuing. However, this does not block the event loop, so other operations can still be processed while waiting for the response.

  • @supergaur3106
    @supergaur3106 หลายเดือนก่อน +1

    thank u sir ji

  • @sammykumar1777
    @sammykumar1777 ปีที่แล้ว +1

    One question,in file system lect you told we should use readSync i.e blocking function but here you told to use non blocking operation.pls ans

  • @kunalkumar2717
    @kunalkumar2717 ปีที่แล้ว

    conclusion - it's always a good practice to write non blocking (asynchronous) code, meaning in which the there is no blocking of threads. we can only have workers equal the number of cores in our CPU in the thread pool.

  • @coding8061
    @coding8061 11 หลายเดือนก่อน

    Awesome ❤

  • @ShivendraPratap524
    @ShivendraPratap524 2 ปีที่แล้ว +3

    it means non-blocking operations are recommended to use
    ??

  • @वृषालीहळदणकर
    @वृषालीहळदणकर 7 หลายเดือนก่อน

    can you please also make also videos on Mocha -Chai Framework .. you are brilliant ..:)

  • @sufiyanpatel6241
    @sufiyanpatel6241 6 หลายเดือนก่อน

    Perfect 👌

  • @sainaid
    @sainaid 7 หลายเดือนก่อน

    Key takeaways from this video:-
    ## how nodejs works? nodejs architecture:-
    -> the architecture of nodejs or it's flow starts with a client (a user of our server).
    -> so what does this client do? this client makes a request to our server, so this request comes to our server.
    -> whatever request comes to us, it is first of all within this *event queue*. for example, if the user-1 has made a request, that will first go in the event queue. after that if user-2 requests something then that will also go in the event queue.
    -> so whatever requests come they all will go inside the event queue, all these request goes to the event loop.
    -> event loop? it's a loop which is always watching our event. it picks the requests based on FIFO (first in first out) principle.
    -> so what does this event loop do? it's work is to watch over the event queue, and remove these requests one by one from the queue.
    -> when a request is picked up from this queue, that request can be of two types: blocking operations (sync), and non-blocking operations (async). so what does this event loop do? it first checks whether this particular request is blocking or non-blocking operation.
    -> if it's a non-blocking operation, event loop will pick it up, process it and sent the response to the user.
    -> if it's a blocking operation, then to solve this particular request, this blocking operation goes to the thread pool (a pool which has all the threads), these threads are responsible to fulfill your blocking operation. i.e., a thread is assigned to every request.
    -> this blocking operation requests the thread pool that i need a thread or a worker. so this thread pool will check is there any thread or worker available, as it has limited threads.
    -> if a thread or a worker is available, then it will put it to work and when the work gets completed, then that worker will comeback in the thread pool and return the result, that result will be returned to us and we will send the response to the user.

  • @MATH_VIBE
    @MATH_VIBE 6 หลายเดือนก่อน

    crystall and clear

  • @naturesboy7482
    @naturesboy7482 หลายเดือนก่อน

    how event loop able to understand that the coming request is as blocking operaton/non-blocking operation

  • @sharmashubham6827
    @sharmashubham6827 6 หลายเดือนก่อน

    sir why blocking operations done directly and non-blocking operation went to thread pool??

  • @VarinderSingh-ec5ec
    @VarinderSingh-ec5ec 10 หลายเดือนก่อน

    For Non-Blocking or Async code , how it will work behind the scenese like how it will let other code to execute first and then it will execute at the end ??

  • @kreevek
    @kreevek 7 หลายเดือนก่อน

    learned you are real teacher

  • @shashankjangir1873
    @shashankjangir1873 11 หลายเดือนก่อน

    great video

  • @SonuKumar-uq2rb
    @SonuKumar-uq2rb ปีที่แล้ว

    wow great job bro .......

  • @amityadav-vu5he
    @amityadav-vu5he ปีที่แล้ว

    Great🎉❤

  • @WithBhavnish
    @WithBhavnish ปีที่แล้ว +15

    bro why are you so confused between non blocking and Blocking operations

    • @user-og2lt8ou8i
      @user-og2lt8ou8i ปีที่แล้ว +3

      Who's?

    • @Ddot-cd1in
      @Ddot-cd1in 5 หลายเดือนก่อน +1

      I think you are confused 😂

  • @msaleem9704
    @msaleem9704 4 หลายเดือนก่อน

    Good effort but sir confuses the both async and sync
    For better clarification watch chai aur code/chai aur javascript/ Async vedio

  • @Ganesh-fk4wc
    @Ganesh-fk4wc ปีที่แล้ว

    Impressive!! The way of teaching is faboulous. Thanks for your effort . @piyush Garg

  • @drj20.05
    @drj20.05 4 หลายเดือนก่อน

    bro please share notes of the video in description , it helps us a lot.

  • @surajmaurya1515
    @surajmaurya1515 6 หลายเดือนก่อน

    Thank You Bhai

  • @abhilashsharma7166
    @abhilashsharma7166 2 หลายเดือนก่อน

    thanks a lot sir

  • @jagdishchoudhary7944
    @jagdishchoudhary7944 ปีที่แล้ว

    if sync function uses thread of cpu to perform the tasks, what async function uses to perform a task?

  • @ashkshah4043
    @ashkshah4043 9 หลายเดือนก่อน

    Js is a single threaded so, how thread pool use 4 thread ?

  • @weforyouweb1165
    @weforyouweb1165 ปีที่แล้ว +1

    Hello Piyush ji I want to ask one question that if node server is running with web socket server then at that time should there is any role of request of http blocking or non blocking?

  • @SulavGhimireeee
    @SulavGhimireeee ปีที่แล้ว

    Thanks Bro!

  • @paraskakkar9237
    @paraskakkar9237 3 หลายเดือนก่อน

    I was watching this series and on reaching this Video, i thought why i haven't subscribed n just subscribed the channel..and boom just saw the comment section 🤡😐😵‍💫💀
    Dear Piyush its better to update this video
    Regards
    A happy Learner from your channel.

  • @कम्प्युटरविज्ञान
    @कम्प्युटरविज्ञान 9 หลายเดือนก่อน

    Do we not require worker threads for non blocking as well?

  • @akshayagulhane3304
    @akshayagulhane3304 10 หลายเดือนก่อน +1

    Node js is a single threaded..Then how it use multiple thread?

    • @bhushanambhore8378
      @bhushanambhore8378 9 หลายเดือนก่อน

      Event loop is responsible to make it multithreaded

  • @umangkumar2005
    @umangkumar2005 10 หลายเดือนก่อน +56

    Bro ,you are teaching wrong synchronous task of nodejs is only run in main thread , they dont utilize thread pool , thread pool is availble in libuv to do.........In Node.js, the thread pool is primarily available for handling certain types of asynchronous tasks, such as file system operations, network I/O, and cryptographic operations. It's important to note that the thread pool is not used for executing synchronous tasks; those tasks are executed on the main thread.

    • @mohammedputhawala5055
      @mohammedputhawala5055 6 หลายเดือนก่อน +3

      Yes correct, if the task is cpu extensive then only node will use the thread pool.

    • @Veer.onwheels
      @Veer.onwheels 6 หลายเดือนก่อน +1

      Yes and also thread pool size is not directly proportional to cpu cores. One core can handle many threads

    • @rishabhsingh453
      @rishabhsingh453 4 หลายเดือนก่อน +1

      Yes, Synchronous tasks are executed in main thread, and async tasks, event loop handles the async tasks, and then adds the callback fn in callback queue

  • @ExtraAccount-e8l
    @ExtraAccount-e8l 3 หลายเดือนก่อน

    Thankyou Sir

  • @Sports_info12
    @Sports_info12 ปีที่แล้ว

    hello sir please tell me how
    Will get to know this is block operation code or non blocking code

  • @arshitcc
    @arshitcc 13 วันที่ผ่านมา

    amazing

  • @bm9code
    @bm9code ปีที่แล้ว +1

    blocking will make use of threads to complete it task, synchronous are blocking code will stop the code there and do not allow execution to next line, then what is the point in having multiple threads when each blocking code do not allow other code to execute ("correct me if any wrong in my understanding")

  • @not_amanullah
    @not_amanullah 9 หลายเดือนก่อน

    thanks ❤

  • @mohdyasir5421
    @mohdyasir5421 11 หลายเดือนก่อน

    Thank you

  • @fardinkhan3620
    @fardinkhan3620 10 หลายเดือนก่อน

    As I know non blocking operation that is asynchronous operation gandle by thread pool

  • @ChinmayBhadang
    @ChinmayBhadang ปีที่แล้ว

    Hey Piyush, I have a question if nodeJS is single-threaded then how thread pool have 4 threads by default and we can increase it by increasing the number of CPU cores. Can you please help me here, I am quite confused.

    • @omkarporlikar6225
      @omkarporlikar6225 9 หลายเดือนก่อน

      Yeah That's true, It all depends on the capabilities of system OS / Core . If it is good the no of worker threads may increase or vice-versa. Also no of worker threads depends upon version of node js so there no thing as default. Also u can increase the no of workers manually although value depends of Capacity of core we are using

  • @asc9360
    @asc9360 2 หลายเดือนก่อน

    Hi piyush, can you please make a seperate dedicated video over this is quite confusing for me at a angle to me. like do we need to use async syntaxes for those blocking code so that the node will assign to another thread or once it understand itself that the code is a blocking code then it's decide to assign a new threads for that perticular task. does a single thread has it's own callstack. all this is confusing for me because I thought all tasks execute in call stack but you overview is quite differnt than the normal event loop concept the concept which says that engine execute line by line once it read the any async syntax it put it aside and start executing the it's sync tasks after all the sync tasks end the event loop then check for the task queue or the microtask queue then if there is any then then event loop will send it to the callstack to execute. but then where is the role of thread in this thoery? or if there is already a video could please share me a link?

  • @SAQIB-u9z
    @SAQIB-u9z ปีที่แล้ว

    we always says nodejs is single threaded, then how can have 4 threads?

  • @daaamn6414
    @daaamn6414 หลายเดือนก่อน +1

    Gaming laptop PEEPS having 16 Threads / Workers

  • @Rajeev-Verma
    @Rajeev-Verma ปีที่แล้ว +1

    Sorry, but i learnt that in Node.js, the blocking (synchronous) operations are handled by the main thread, while the non-blocking (asynchronous) operations are offloaded to the thread pool.