资讯专栏INFORMATION COLUMN

大话-node真的是单线程吗?

Yang_River / 1114人阅读

摘要:当你使用的活动监视器你会发现,实际的进程数为菜鸟是因为线程池的原因吗老鸟不错嘛,还知道线程池呢但非也非也。菜鸟竟然不是线程池老鸟你忽视了集成了引擎。启动后会创建实例,而实例是多线程的。

老鸟:伸着懒腰,看着窗外明媚的阳光,喝一口清茶,心情大美。一天的好心情莫过于此。
老鸟:菜鸟,你这消失了大半个月,忙什么呢?
菜鸟:听说node最近很火,这不趁着年轻,多储存点知识储备呢!
老鸟:那你说说你对node的理解?
菜鸟:node的三大特点:单线程,事件驱动,非阻塞I/O...
老鸟:说说你理解的单线程?
菜鸟:打个比方:皇上处理朝政时,不需要事必躬亲,要学会放权。所有的朝政大臣向丞相报告,由丞相进行整理,并把最后的方案向皇上报告。由皇上进行定夺。
老鸟:理解的不错嘛,可你有没有想过,node既然是单线程,又是如何实现异步和非阻塞I/O呢?
菜鸟:node是事件驱动,所有的事件做成一个队列,顺序执行的呀
老鸟:你这样说也没错,但node是支持多线程的。当你使用MAC的活动监视器你会发现,实际的进程数为6

  const http = require("http");
  http.createServer((req, res) => {
    res.end("hello");
  }).listen(8000, () => {
    console.log("server is listening: " + 8000);
  });


菜鸟:是因为线程池的原因吗?
老鸟:不错嘛,还知道线程池呢?但非也非也。
老鸟:首先,线程池是按需创建的,当你加载文件IO时,通过ab模拟访问后,你会发现,线程数发生了变化,这是因为,线程池中默认的默认值为4。
菜鸟:竟然不是线程池?
老鸟:你忽视了node集成了V8引擎?Node.js启动后会创建V8实例,而V8实例是多线程的。
菜鸟:若有所思中...
老鸟:主线程在任何时候,都不会阻塞吗?
菜鸟:老鸟,经你这么一分析,我可不敢肯定的回答了
老鸟:当然不是的。主线程在特定条件下也是会阻塞的。Node.js的事件循环中有一个阶段是Poll。poll阶段在特定情况下是会阻塞的。
老鸟:当然,你也不要羞愧,知识是永无止境的,我只是提醒你,要不断探索,不断质疑,才能不断求知。
菜鸟:受教了,给你点个赞,顺便收藏一下

参考资料

https://nodejs.org/en/docs/gu...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/105112.html

相关文章

  • 只为那句承诺-大话Promise

    摘要:什么是是异步编程的一种解决方案,比传统的解决方案回调函数和事件更合理和更强大。函数可以将状态转变为状态。对象通过方法来添加回调函数。当发生错误的时候可以通过方法,来定义回调函数。接受数组作为参数传入,每个元素都是一个对象。 大家周末好,要说最近几年什么语言大红大紫,当属JavaScript了。话说虽然是10天就创造出的语言,但是人家能文能武。web前端自然不必多说了,各种框架你方登罢我...

    EastWoodYang 评论0 收藏0
  • 大话javascript 4期:事件循环(3)

    摘要:令人困惑的是,文档中称,指定的回调函数,总是排在前面。另外,由于指定的回调函数是在本次事件循环触发,而指定的是在下次事件循环触发,所以很显然,前者总是比后者发生得早,而且执行效率也高因为不用检查任务队列。 一、定时器 除了放置异步任务的事件,任务队列还可以放置定时事件,即指定某些代码在多少时间之后执行。这叫做定时器(timer)功能,也就是定时执行的代码。 定时器功能主要由setTim...

    liujs 评论0 收藏0
  • 大话javascript 4期:事件循环(1)

    摘要:脚本执行,事件处理等。引擎线程,也称为内核,负责处理脚本程序,例如引擎。事件触发线程,用来控制事件循环可以理解为,引擎线程自己都忙不过来,需要浏览器另开线程协助。异步请求线程,也就是发出请求后,接收响应检测状态变更等都是这个线程管理的。 一、进程与线程 现代操作系统比如Mac OS X,UNIX,Linux,Windows等,都是支持多任务的操作系统。 什么叫多任务呢?简单地说,就是操...

    codergarden 评论0 收藏0
  • Node.js:浅析高并发与分布式集群

    摘要:而在单线程环境下,绕不过错误就意味着导致应用退出,重启恢复的间隙会导致服务中断,这是我们不愿意看到的。这也是支持高并发的重要原因之一实际上不光是操作,的绝大多数操作都是以这种异步的方式进行的。 本文首发于我的个人博客: kmknkk.xin 不足之处欢迎斧正! Node特性:高并发 在解释node为什么能够做到高并发之前,不妨先了解一下node的其他几个特性: 单线程 我们先来明确...

    Lin_YT 评论0 收藏0
  • 深入理解Node.js 进程与线程(8000长文彻底搞懂)

    摘要:在单核系统之上我们采用单进程单线程的模式来开发。由进程来管理所有的子进程,主进程不负责具体的任务处理,主要工作是负责调度和管理。模块与模块总结无论是模块还是模块,为了解决实例单线程运行,无法利用多核的问题而出现的。 前言 进程与线程是一个程序员的必知概念,面试经常被问及,但是一些文章内容只是讲讲理论知识,可能一些小伙伴并没有真的理解,在实际开发中应用也比较少。本篇文章除了介绍概念,通过...

    Harpsichord1207 评论0 收藏0

发表评论

0条评论

Yang_River

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<