node特性以及优缺点
来源:互联网 发布:唐努乌梁海 知乎 编辑:程序博客网 时间:2024/05/22 13:23
node特性
1. 它是一个Javascript运行环境(简单容易上手)
2. 依赖于Chrome V8引擎进行代码解释(号称世界上最快的解释器)
3. 事件驱动(高并发处理速度优势)
4. 非阻塞I/O(创建新的线程去执行,不会阻塞主线程。动作并行执行,速度更快)
5. 轻量、可伸缩,适于实时数据交互应用(由高并发特性决定)
6. 单进程,单线程(不会占用大量的内存,但同时也是缺点)
优点:
1. 高并发(最重要的优点)
2. 适合I/O密集型应用
缺点:
1、不适合CPU密集型应用;CPU密集型应用给Node带来的挑战主要是:由于JavaScript单线程的原因,如果有长时间运行的计算(比如大循环),将会导致CPU时间片不能释放,使得后续I/O无法发起;
解决方案:分解大型运算任务为多个小任务,使得运算能够适时释放,不阻塞I/O调用的发起;
2、只支持单核CPU,不能充分利用CPU;
3、可靠性低,一旦代码某个环节崩溃,整个系统都崩溃
原因:单进程,单线程
解决方案:(1)Nnigx反向代理,负载均衡,开多个进程,绑定多个端口;
(2)开多个进程监听同一个端口,使用cluster模块;
4. 开源组件库质量参差不齐,更新快,向下不兼容
5. Debug不方便,错误没有stack trace
适合NodeJS的场景
1. RESTful API
这是NodeJS最理想的应用场景,可以处理数万条连接,本身没有太多的逻辑,只需要请求API,组织数据进行返回即可。它本质上只是从某个数据库中查找一些值并将它们组成一个响应。由于响应是少量文本,入站请求也是少量的文本,因此流量不高,一台机器甚至也可以处理最繁忙的公司的API需求。
2. 统一Web应用的UI层
目前MVC的架构,在某种意义上来说,Web开发有两个UI层,一个是在浏览器里面我们最终看到的,另一个在server端,负责生成和拼接页面。
不讨论这种架构是好是坏,但是有另外一种实践,面向服务的架构,更好的做前后端的依赖分离。如果所有的关键业务逻辑都封装成REST调用,就意味着在上层只需要考虑如何用这些REST接口构建具体的应用。那些后端程序员们根本不操心具体数据是如何从一个页面传递到另一个页面的,他们也不用管用户数据更新是通过Ajax异步获取的还是通过刷新页面。
3. 大量Ajax请求的应用
例如个性化应用,每个用户看到的页面都不一样,缓存失效,需要在页面加载的时候发起Ajax请求,NodeJS能响应大量的并发请求。 总而言之,NodeJS适合运用在高并发、I/O密集、少量业务逻辑的场景。
1. 它是一个Javascript运行环境(简单容易上手)
2. 依赖于Chrome V8引擎进行代码解释(号称世界上最快的解释器)
3. 事件驱动(高并发处理速度优势)
4. 非阻塞I/O(创建新的线程去执行,不会阻塞主线程。动作并行执行,速度更快)
5. 轻量、可伸缩,适于实时数据交互应用(由高并发特性决定)
6. 单进程,单线程(不会占用大量的内存,但同时也是缺点)
优点:
1. 高并发(最重要的优点)
2. 适合I/O密集型应用
缺点:
1、不适合CPU密集型应用;CPU密集型应用给Node带来的挑战主要是:由于JavaScript单线程的原因,如果有长时间运行的计算(比如大循环),将会导致CPU时间片不能释放,使得后续I/O无法发起;
解决方案:分解大型运算任务为多个小任务,使得运算能够适时释放,不阻塞I/O调用的发起;
2、只支持单核CPU,不能充分利用CPU;
3、可靠性低,一旦代码某个环节崩溃,整个系统都崩溃
原因:单进程,单线程
解决方案:(1)Nnigx反向代理,负载均衡,开多个进程,绑定多个端口;
(2)开多个进程监听同一个端口,使用cluster模块;
4. 开源组件库质量参差不齐,更新快,向下不兼容
5. Debug不方便,错误没有stack trace
适合NodeJS的场景
1. RESTful API
这是NodeJS最理想的应用场景,可以处理数万条连接,本身没有太多的逻辑,只需要请求API,组织数据进行返回即可。它本质上只是从某个数据库中查找一些值并将它们组成一个响应。由于响应是少量文本,入站请求也是少量的文本,因此流量不高,一台机器甚至也可以处理最繁忙的公司的API需求。
2. 统一Web应用的UI层
目前MVC的架构,在某种意义上来说,Web开发有两个UI层,一个是在浏览器里面我们最终看到的,另一个在server端,负责生成和拼接页面。
不讨论这种架构是好是坏,但是有另外一种实践,面向服务的架构,更好的做前后端的依赖分离。如果所有的关键业务逻辑都封装成REST调用,就意味着在上层只需要考虑如何用这些REST接口构建具体的应用。那些后端程序员们根本不操心具体数据是如何从一个页面传递到另一个页面的,他们也不用管用户数据更新是通过Ajax异步获取的还是通过刷新页面。
3. 大量Ajax请求的应用
例如个性化应用,每个用户看到的页面都不一样,缓存失效,需要在页面加载的时候发起Ajax请求,NodeJS能响应大量的并发请求。 总而言之,NodeJS适合运用在高并发、I/O密集、少量业务逻辑的场景。
结尾
其实NodeJS能实现几乎一切的应用,我们考虑的点只是适不适合用它来做。 0 0
- node特性以及优缺点
- Node.js优缺点
- Node.js的优缺点
- flex特性及优缺点
- Memcached特性及优缺点
- 关系型数据库和非关系型数据库的特性以及各自的优缺点
- 关系型数据库和非关系型数据库的特性以及各自的优缺点
- 关系型数据库和非关系型数据库的特性以及各自的优缺点
- 关系型数据库和非关系型数据库的特性以及各自的优缺点
- 关系型数据库和非关系型数据库的特性以及各自的优缺点
- 关系型数据库和非关系型数据库的特性以及各自的优缺点
- 决策树的特性及优缺点
- 决策树的特性及优缺点
- HTML5的特性与优缺点
- node.js优缺点及适用场景讨论
- 什么是node.js?node.js的优缺点说明
- MVC概念详解以及优缺点
- 多态以及其优缺点
- tomcat优化
- 什么是阿里云数加大数据计算服务MaxCompute?
- js和php中if判断空数组的差异
- 解决公务车Bug:过路过桥费用管理中导入路桥费用时,付费方式为苏通卡时不能正常导入
- 浅谈TCP和UDP的区别
- node特性以及优缺点
- idea 使用 mybatis-generator
- C 和C++ 对定义结构体的区别
- laravel validator验证
- DDL、DML和DCL的区别与理解
- Android知识点之延迟加载:ViewStub的使用
- Android 去掉标题栏,状态栏,导航栏
- 5分钟学会使用DataHub接入实时数据到MaxCompute(原ODPS)
- iOS 自定义转场动画初探