电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

NodeJS的特点概述VIP免费

NodeJS的特点概述_第1页
1/25
NodeJS的特点概述_第2页
2/25
NodeJS的特点概述_第3页
3/25
NodeJS 的特点概述: NodeJS 宣称其目标是“旨在提供一种简单的构建可伸缩网络程序的方法”,那么它的出现是为了解决什么问题呢,它有什么优缺点以及它适用于什么场景呢? 本文就个人使用经验对这些问题进行探讨。 一. NodeJS 的特点 我们先来看看NodeJS 官网上的介绍: Node.js is a platform built on Chrome's JavaScript runtime for easily building fast, scalable network applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient, perfect for data-intensive real-time applications that run across distributed devices. 其特点为: 1. 它是一个Javascript 运行环境 2. 依赖于Chrome V8 引擎进行代码解释 3. 事件驱动 4. 非阻塞I/O 5. 轻量、可伸缩,适于实时数据交互应用 6. 单进程,单线程 二. NodeJS 带来的对系统瓶颈的解决方案 它的出现确实能为我们解决现实当中系统瓶颈提供了新的思路和方案,下面我们看看它能解决什么问题 1. 并发连接 举个例子,想象一个场景,我们在银行排队办理业务,我们看看下面两个模型 (1)系统线程模型: 这种模型的问题显而易见,服务端只有一个线程,并发请求(用户)到达只能处理一个,其余的要先等待,这就是阻塞,正在享受服务的请求阻塞后面的请求了 (2)多线程、线程池模型: 这个模型已经比上一个有所进步,它调节服务端线程的数量来提高对并发请求的接收和响应,但并发量高的时候,请求仍然需要等待,它有个更严重的问题: 回到代码层面上来讲,我们看看客户端请求与服务端通讯的过程: 服务端与客户端每建立一个连接,都要为这个连接分配一套配套的资源,主要体现为系统内存资源,以PHP 为例,维护一个连接可能需要20M 的内存 这就是为什么一般并发量一大,就需要多开服务器 那么NodeJS 是怎么解决这个问题的呢? 我们来看另外一个模型,想象一下我们在快餐店点餐吃饭的场景 (3)异步、事件驱动模型 我们同样是要发起请求,等待服务器端响应;但是与银行例子不同的是,这次我们点完餐后拿到了一个号码, 拿到号码,我们往往会在位置上等待,而在我们后面的请求会继续得到处理,同样是拿了一个号码然后到一旁等待,接待员能一直进行处理。 等到饭菜做号了,会喊号码,我们拿到了自己的饭菜,进行后续的处理(吃饭) 这个喊号码的动作在Nod...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

NodeJS的特点概述

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部