Node.js的特点和应用场景介绍
Node.js应该是当今最火热的技术之一。本文主要介绍Node.js的特点及应用场景。
Node.js是一个基于ChromeJavaScript运行时建立的一个平台,用来方便地搭建快速的易于扩展的网络应用。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请求的写法很像:
varfs=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采用了与HTML5WebWorkers相同的思路,使用child_process来解决但单线程中大计算量的问题。通过将计算分发到各个子进程,可以将大量计算分解掉,然后再通过进程之间的事件消息来传递结果。
1.4跨平台
Node是跨平台的,即同样的一套JS代码都可以部署运行在Windows、Linux、OSX等平台。这主要得益于Node在操作系统与Node上层模块系统之间构建了一层平台层架构libuv。
2.应用场景
1)、实时应用:如在线聊天,实时通知推送等等(如socket.io)
2)、分布式应用:通过高效的并行I/O使用已有的数据
3)、工具类应用:海量的工具,小到前端压缩部署(如grunt),大到桌面图形界面应用程序
4)、游戏类应用:游戏领域对实时和并发有很高的要求(如网易的pomelo框架)
5)、利用稳定接口提升Web渲染能力
6)、前后端编程语言环境统一:前端开发人员可以非常快速地切入到服务器端的开发(如著名的纯Javascript全栈式MEAN架构)
相关文章
- Node.js 应用 peer dependency 的用法
- Node.js基本数据处理
- Node.js 应用访问 https 服务器时遇到的错误消息 unable to get local issuer certificate
- js中四舍五入的方法_JS取整
- node.js中间件multer的使用
- JavaScript、js文件、Node.js、静态文件
- Node.js 应用全链路追踪技术——全链路信息存储
- 关于 SAP Commerce Cloud 构建的 Node.js 版本号问题
- ThinkJS 3 正式版发布,Node.js Web 框架详解编程语言
- JS history对象详解
- 解除 Linux 上的 Node.js 安装(linux卸载node)
- Node.js连接MSSQL数据库的操作指南(node 链接mssql)
- 利用Node.js实现对MS SQL服务器的连接(node连MSsql)
- Linux下开发Node应用的新姿势(node linux)
- 数据JS技术实现实时获取Oracle数据(js实时获取oracle)
- 从前端JS里请求Redis资源,搭建高性能应用(前端js请求redis)
- js操纵跨frame的三级联动select下拉选项实例介绍
- js中数组Array的一些常用方法总结
- 解决css和js的{}与smarty定界符冲突问题的两种方法
- Node.js中AES加密和其它语言不一致问题解决办法
- 在Linux上用forever实现Node.js项目自启动
- Node.js服务器端应用开发框架--Hapi.js
- Node.js开源应用框架HapiJS介绍