Node.js系列——(4)优势及场景
背景
之前几篇系列文章简单介绍了node.js的安装配置及基本操作:
Node.js系列——(1)安装配置与基本使用
Node.js系列——(2)发起get/post请求
Node.js系列——(3)连接DB
接下来,我们就来整体认识下node.js
node.js
node.js官网对它的介绍是这样的:
Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。
Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。
V8引擎
V8使用C++开发,并在谷歌浏览器中使用。在运行JavaScript之前,相比其它的JavaScript的引擎转换成字节码或解释执行,V8将其编译成原生机器码(IA-32, x86-64, ARM, or MIPS CPUs),并且使用了如内联缓存(inline caching)等方法来提高性能。
有了这些功能,JavaScript程序在V8引擎下的运行速度媲美二进制程序。
具体内容可参考:为什么V8引擎这么快?
事件驱动
传统技术实现下,当一个请求到达时,会分配一个线程,该线程会占用内存,当请求的任务做完时,线程才会退出并释放内存。但node.js只有一个单线程,所有的连接都由这一个线程来处理。
网上流传着一个生动的例子:
传统技术下的处理方式——>餐馆里一个服务员接待一桌客人,服务这一桌客人点餐、上菜、陪侍,到客人离开;
node.js的处理方式——>餐馆里只有一个服务员,当有客人来,他就去招待点餐,点餐结束后就去处理其他事情,可以去招待其他客人,也可以去上菜。
Node.js是单进程单线程的,那他是如何做到高性能的呢?
主要通过事件驱动和异步回调。node中几乎所有的事件机制都是使用观察者模式实现的。
说到观察者模式,就要先明确主题Subject(即被观察者)和观察者Observer。
如下图所示,在node中事件扮演者Subject的角色,而这个事件上的处理函数就是观察者。还拿上面的餐馆服务员的例子来说,客人进入餐馆这一动作就是一个事件,当这一事件触发时,他的观察者就会进行一系列操作(比如招待入座、点餐等)。
由于node是单线程的,因此在实际场景中会有很多事件堆积到一起,这也就是事件队列。
在上图中所示:
1) 如果有任务或请求到达,会被放入右侧的Event Queue(事件队列)中。事件队列中每个任务会存放两个东西,处理方法和回调方法,即function和callback。
2)事件循环Event Loop会根据事件队列中的任务列表进行执行,这时分两种情况:
- 如果取到的任务是non-Blocking非阻塞的,那么可以直接执行然后调用他相对应的回调函数。
- 如果任务是Blocking阻塞的(如IO操作等),就不会直接执行,而是从线程池Thread Pool中取出一个线程来执行,当该线程完成后,就会调用回调函数,接下来的操作跟上一种情况一样了。到最后该线程的任务执行完毕,那么线程所占用的资源被释放。
Tips:
当执行过程中遇到I/O阻塞(读取文件、查询数据库、请求套接字、访问远程服务等)时,事件循环线程不会停下等待结果,转而继续执行队列中的下一个任务,不会在事件循环线程中执行。在函数执行时,Node.js在事件队列中放置回调函数,它的顺序根据函数的完成快慢决定。
具体内容参考:Node.js的事件驱动模型
Rest API
Rest API 这部分就不用多说了,node采用这种方式来规范接口和数据的形式,用法也很简单。
场景
前面说了这么多node.js的优点,那是不是任何场景都优先选择他呢?肯定不是的,我们来看下他的缺点。
1、node.js不适合做CPU密集型的工作
我们不能说node.js完全是单线程的,因为当遇到阻塞式的任务时,他会交给其他线程去处理。但除此之外,node是单线程的。因此,如果是CPU密集的场景下,选择使用node,无法使他的优势发挥出来。
2、大量的计算可能会使node单线程暂时失去反应
3、如果有一个Exception影响到了node的核心事件循环,那么整个实例就会崩溃。
Node.js系列——(4)优势及场景的更多相关文章
- node.js系列笔记之node.js初识《一》
node.js系列笔记之node.js初识<一> 一:环境说明 1.1 Linux系统CentOS 5.8 1.2 nodejs v0.10.15 1.3 nodejs源码下载地址 htt ...
- Node.js系列-http
前言: 最近一直忙着公司项目的事,战友们的留言也没空回复,博客也有段时间没有更新了,年底了就是一个的忙啊~~~(ps:同感的也给个赞吧) 现在前端的就是一直地更新一直有新的东西出来,什么ES2015, ...
- Node.js系列-express(上)
前言 Node.js系列的第一篇:http,大概描述了通过使用node.js内置的api创建一个服务并监听request实现简单的增删改查.现在,我们就通过通读express官网及使用express框 ...
- 《唐三学node.js系列》—魂士篇&&三哥初始node.js
前言 如果你有一定的前端基础,比如 HTML.CSS.JavaScript.jQuery.那么Node.js 能让你以最低的成本快速过渡成为一个全栈工程师(我称这个全栈为伪全栈,我认为的全栈也要精通数 ...
- Node.js系列——(3)连接DB
背景 node.js,有人称之为运行在服务器端的JavaScript.以往我们使用JavaScript时,都是依赖后端查询数据库并返回数据,而JavaScript只需要展示即可.问题来了,就不能绕开后 ...
- Node.js介绍、优势、用途
一.Node.js介绍Node.js是一个javascript运行环境.它让javascript可以开发后端程序,实现几乎其他后端语言实现的所有功能,可以与PHP.Java.Python..NET.R ...
- Node.js系列之node.js初探
官方介绍:Node.js is a platform built on Chrome's JavaScript runtime for easily building fast, scalable n ...
- Node.js系列基础学习-----回调函数,异步
Node.js基础学习 Node.js回调函数 Node.js异步编程的直接体现就是回调,异步编程依托回调来实现,但不是异步.回调函数在完成任务后就会被调用,Node有很多的回调函数,其所有的API都 ...
- Node.js系列基础学习----安装,实现Hello World, REPL
Node.js基础学习 简介 简单的说 Node.js 就是运行在服务端的 JavaScript.Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台.Node.js是一 ...
随机推荐
- anaconda安装包找不到
Anaconda作为一个工具包集成管理工具,下载python工具包是很方便的,直接敲: conda install package_name 1 但是有时候安装一个工具包(如skimage)的时候,在 ...
- (数据科学学习手札48)Scala中的函数式编程
一.简介 Scala作为一门函数式编程与面向对象完美结合的语言,函数式编程部分也有其独到之处,本文就将针对Scala中关于函数式编程的一些常用基本内容进行介绍: 二.在Scala中定义函数 2.1 定 ...
- 20155207王雪纯 2006-2007-2 《Java程序设计》第二周学习总结
20155207王雪纯 2006-2007-2 <Java程序设计>第二周学习总结 教材学习内容总结 整数类型:short(占2字节).int()占4字节.long(占8字节) " ...
- 20155327 信息安全技术 实验二 Windows口令破解
课程:信息安全概论 班级:1553 姓名:了李百乾 学号:20155327 成绩: 指导教师: 李冬冬 实验日期及时间: 2017年10月11日 15:30-18:00 必修/选修:必修 实验序号:0 ...
- java开发划分级别的标准
一.史诗序: java开发也有一段时间了,整天茫茫碌碌,除了偶尔的小有成就感,剩下的大部分好像都在重复,你是否也遇到了这样的情况? 遇到一个小细节问题,之前不久解决过,现在却是什么都记不起来了 面对每 ...
- javaweb(三十八)——mysql事务和锁InnoDB(扩展)
MySQL/InnoDB的加锁分析,一直是一个比较困难的话题.我在工作过程中,经常会有同事咨询这方面的问题.同时,微博上也经常会收到MySQL锁相关的私信,让我帮助解决一些死锁的问题.本文,准备就My ...
- Swoole实现h5版聊天室笔记
声明:该聊天室目前只有一对多,一对一的聊天功能,另外,因为没有使用到mysql,所以还存在比较多的缺陷地方,但知道原理就差不多了,这里主要分享下swoole简易的聊天室制作思路. 开发环境:cento ...
- dalao自动报表邮件2.0
经过昨天的修改优化后,dalao收到了不是“木马”的邮件,欣慰地点了点头,“不错,不错,这几张表设计的简洁明了,看着有货!不过呀,,,这些表的数据太多了一点,十几天的数据一大溜,能不能再简洁一点,做一 ...
- 从零开始的Python学习Episode 9——集合
集合 集合是一个无序的,不重复的数据组合,是python基本的数据类型,把不同的元素组成一起就形成集合. 一.创建集合 s = set('smile')list = ['1','2','3']prin ...
- ZOJ 3962
就是统计1~n中出现的各个数字的次数,当然是在16进制下. 不过有个区间问题的小技巧,统计从 [x,y] 可以转换成 从 [1,y] 减去 [1,x-1]. 不过要分类讨论一下,因为有可能会出现溢出, ...