Node.JS的最大优点是它具有非阻塞性。它是单线程的,因此不需要为每个新的传入连接生成新线程。
在事件循环(实际上是单线程)的后面,有一个“非阻塞工作程序”。这个东西不再是单线程的,所以(据我了解),它可以为每个任务产生一个新线程。
也许我误会了一些东西,但是优势到底在哪里。如果要处理的任务很多,那么“非阻塞工作”会不会变成“阻塞工作人员”?
谢谢克里斯蒂安
您需要阅读libuv,它是节点非阻塞I / O背后的“魔术”。
从libuv书中摘录的重要一件事是libuv使用主机OS的异步 I / O 设施。它不只是为每个连接创建一个新线程。
libuv告诉操作系统,它想知道在一组特定的套接字上发生的任何更改(连接状态,接收到的数据等)。然后由操作系统来处理管理连接。操作系统本身可能会创建一个或多个线程来完成此任务,但这不是我们关心的问题。(它当然不会为每个连接创建一个线程。)
对于其他类型的操作,例如对C库的调用可能在计算上是昂贵的(即,加密),libuv提供了可以在其上运行这些操作的线程池。由于它是一个线程池,因此您不必担心线程数无限制地增长。当池完全繁忙时,操作将排队。
是的,JavaScript在单个线程上运行。是的,节点(通过libuv)在后台产生了许多线程来工作,因此它不需要阻塞JavaScript线程。但是,线程数始终受控制,并且I / O通常甚至不会获得其自己的节点分配线程,因为该线程是由OS处理的。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句