Node.js的特点和应用场景介绍


Posted in Javascript onNovember 04, 2014

Node.js应该是当今最火热的技术之一。本文主要介绍Node.js的特点及应用场景。

Node.js是一个基于Chrome JavaScript运行时建立的一个平台,用来方便地搭建快速的 易于扩展的网络应用。Node.js借助事件驱动,非阻塞I/O模型变得轻量和高效,非常适合 运行在分布式设备的数据密集型实时应用。

1. 特点

1.1 异步I/O

所谓的异步I/O,是相对同步I/O而言的。程序执行过程中必然要进行很多I/O操作,如读写文件、输入输出、请求响应等等。通常来说,I/O操作是非常费时的。例如在传统的编程模式中,你要读一个几G的文件,整个线程都暂停下来,等待文件读完后继续执行。换言之,I/O操作阻塞了代码的执行,极大地降低了程序的效率。

关于异步I/O,其实对于前端工程师来说并不陌生,因为发起Ajax请求就是最常见的一种“异步”调用。在Node中,以读取文件(读文件是一种耗时的I/O操作)为例,它与发起Ajax请求的写法很像:

var fs = require('fs');

fs.readFile('/path', function(err, file) {

    console.log('读取文件完成');

});

console.log('开始读取文件');

上述代码在调用fs.readFile后,后续代码是被立即执行的,“读取文件完成”的时刻是无法预知的。当线程遇到I/O操作时不会以阻塞的方式等待I/O操作结束,而只是将I/O请求发送给操作系统,继续执行后续语句。当操作系统完成I/O操作时以事件的形式通知执行I/O操作的线程,线程会在特定时间处理这个事件。

1.2 事件循环与回调函数

所谓事件循环是指Node会把所有的异步操作使用事件机制解决,有个线程在不断地循环检测事件队列。事件循环会检查事件队列中有没有未处理的事件,直到程序结束。事件的编程方式具有轻量级、松耦合、只关注事务点等优势,但是在多个异步任务的场景下,事件与事件之间各自独立,如何协作是一个问题。在Javascript中,回调函数无处不在,回调函数是最好的接受异步调用返回数据的方式。

1.3 单线程

Node保持了JS在浏览器中单线程的特点。单线程的最大好处是不用像多线程编程那样出处在意状态的同步问题,没有死锁的存在,也没有线程上下文切换的开销。单线程也有其弱点,主要表现在三方面:无法利用多核CPU;错误会引起整个应用退出,应用的健壮性值得考研;大量计算会占用CPU导致无法继续调用异步I/O。

为了解决上述问题,Node采用了与HTML5 Web Workers相同的思路,使用child_process来解决但单线程中大计算量的问题。通过将计算分发到各个子进程,可以将大量计算分解掉,然后再通过进程之间的事件消息来传递结果。

1.4 跨平台

Node是跨平台的,即同样的一套JS代码都可以部署运行在Windows、Linux、OSX等平台。这主要得益于Node在操作系统与Node上层模块系统之间构建了一层平台层架构libuv。

Node.js的特点和应用场景介绍

2. 应用场景

1)、实时应用:如在线聊天,实时通知推送等等(如socket.io)
2)、分布式应用:通过高效的并行I/O使用已有的数据
3)、工具类应用:海量的工具,小到前端压缩部署(如grunt),大到桌面图形界面应用程序
4)、游戏类应用:游戏领域对实时和并发有很高的要求(如网易的pomelo框架)
5)、利用稳定接口提升Web渲染能力
6)、前后端编程语言环境统一:前端开发人员可以非常快速地切入到服务器端的开发(如著名的纯Javascript全栈式MEAN架构)

Javascript 相关文章推荐
JavaScript Base64编码和解码,实现URL参数传递。
Sep 18 Javascript
phpwind放自动注册方法
Dec 02 Javascript
JavaScript 对象成员的可见性说明
Oct 16 Javascript
jQuery插件 selectToSelect使用方法
Oct 02 Javascript
js单例模式的两种方案
Oct 22 Javascript
js实现可得到不同颜色值的颜色选择器实例
Feb 28 Javascript
JavaScript中利用for循环遍历数组
Jan 15 Javascript
JS实现二叉查找树的建立以及一些遍历方法实现
Apr 17 Javascript
详解vue2.0 不同屏幕适配及px与rem转换问题
Feb 23 Javascript
javascript之分片上传,断点续传的实际项目实现详解
Sep 05 Javascript
使用JS实现动态时钟
Mar 12 Javascript
如何在vue 中使用柱状图 并自修改配置
Jan 21 Vue.js
Node.js中的模块机制学习笔记
Nov 04 #Javascript
Node.js异步I/O学习笔记
Nov 04 #Javascript
JavaScript中的ubound函数使用实例
Nov 04 #Javascript
JavaScript实现检查页面上的广告是否被AdBlock屏蔽了的方法
Nov 03 #Javascript
网页中表单按回车就自动提交的问题的解决方案
Nov 03 #Javascript
详解jquery中$.ajax方法提交表单
Nov 03 #Javascript
jquery处理json对象
Nov 03 #Javascript
You might like
php隐藏IP地址后两位显示为星号的方法
2014/11/21 PHP
JavaScript 序列化对象实现代码
2009/12/18 Javascript
jQuery dialog 异步调用ashx,webservice数据的代码
2010/08/03 Javascript
取得窗口大小 兼容所有浏览器的js代码
2011/08/09 Javascript
javascript实现div的拖动并调整大小类似qq空间个性编辑模块
2012/12/12 Javascript
使用jQuery避免鼠标双击的解决方案
2013/08/21 Javascript
JQuery设置文本框和密码框得到焦点时的样式
2013/08/30 Javascript
JQUERY dialog的用法详细解析
2013/12/19 Javascript
BootStrap glyphicon图标无法显示的解决方法
2016/09/06 Javascript
微信小程序开发(二)图片上传+服务端接收详解
2017/01/11 Javascript
Node.js调试技术总结分享
2017/03/12 Javascript
Vue2递归组件实现树形菜单
2017/04/10 Javascript
简单实现js点击展开二级菜单功能
2017/05/16 Javascript
Node.js五大应用性能技巧小结(必须收藏)
2017/08/09 Javascript
vue2.0 和 animate.css的结合使用
2017/12/12 Javascript
vue下history模式刷新后404错误解决方法
2018/08/18 Javascript
vue弹窗插件实战代码
2018/09/08 Javascript
angular 服务的单例模式(依赖注入模式下)详解
2018/10/22 Javascript
JS+css3实现幻灯片轮播图
2020/08/14 Javascript
[03:42]2014DOTA2西雅图国际邀请赛 Navi战队巡礼
2014/07/07 DOTA
python函数返回多个值的示例方法
2013/12/04 Python
python使用xmlrpc实例讲解
2013/12/17 Python
Python中asyncore的用法实例
2014/09/29 Python
Django中更新多个对象数据与删除对象的方法
2015/07/17 Python
python中将正则过滤的内容输出写入到文件中的实例
2018/10/21 Python
Python实现病毒仿真器的方法示例(附demo)
2020/02/19 Python
django实现将后台model对象转换成json对象并传递给前端jquery
2020/03/16 Python
如何解决flask修改静态资源后缓存文件不能及时更改问题
2020/08/02 Python
医学专业职业生涯规划范文
2014/02/05 职场文书
119消防日活动总结
2014/08/29 职场文书
信访工作汇报材料
2014/10/27 职场文书
2015年暑假生活总结
2015/07/13 职场文书
会议新闻稿
2015/07/17 职场文书
MySQL七种JOIN类型小结
2021/10/24 MySQL
MySQL和Oracle批量插入SQL的通用写法示例
2021/11/17 MySQL
python opencv将多个图放在一个窗口的实例详解
2022/02/28 Python