- 1、本文档共25页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NodeJS的特点概述
NodeJS的特点概述:? NodeJS宣称其目标是“旨在提供一种简单的构建可伸缩网络程序的方法”,那么它的出现是为了解决什么问题呢,它有什么优缺点以及它适用于什么场景呢? 本文就个人使用经验对这些问题进行探讨。?一. NodeJS的特点? 我们先来看看NodeJS官网上的介绍: Node.js is a platform built on?Chromes 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)异步、事件驱动模型 ? 我们同样是要发起请求,等待服务器端响应;但是与银行例子不同的是,这次我们点完餐后拿到了一个号码, 拿到号码,我们往往会在位置上等待,而在我们后面的请求会继续得到处理,同样是拿了一个号码然后到一旁等待,接待员能一直进行处理。 等到饭菜做号了,会喊号码,我们拿到了自己的饭菜,进行后续的处理(吃饭) 这个喊号码的动作在NodeJS中叫做回调(Callback),能在事件(烧菜,I/O)处理完成后继续执行后面的逻辑(吃饭), 这体现了NodeJS的显著特点,异步机制、事件驱动 整个过程没有阻塞新用户的连接(点餐),也不需要维护已经点餐的用户与厨师的连接? 基于这样的机制,理论上陆续有用户请求连接,NodeJS都可以进行响应,因此NodeJS能支持比Java、PHP程序更高的并发量 虽然维护事件队列也需要成本,再由于NodeJS是单线程,事件队列越长,得到响应的时间就越长,并发量上去还是会力不从心 总结一下NodeJS是怎么解决并发连接这个问题的: 更改连接到服务器的方式,每个连接发射(emit)一个在NodeJS引擎进程中运行的事件(Event),放进事件队列当中, 而不是为每个连接生成一个新的OS线程(并为其分配一些配套内存)? 2. I/O阻塞? NodeJS解决的另外一个问题是I/O阻塞,看看这样的业务场景:需要从多个数据源拉取数据,然后进行处理? (1)串行获取数据,这是我们一般的解决方案,以PHP为例 ? 假如获取profile和timeline操作各需要1S,那么串行获取就需要2S? (2)NodeJS非阻塞I/O,发射/监听事件来控制执行过程 ? NodeJS遇到I/O事件会创建一个线程去执行,然后主线程会继续往下执行的, 因此,拿profile的动作触发一个I/O事件,马上就会执行拿timeline的动作, 两个动作并行执行,假如各需要1S,那么总的时间也就是1S 它们的I/O操作执行完成后,发射一个事件,profile和timeline, 事件代理接收后继续往下执行后面的逻辑,这就是NodeJS非阻塞I/O的特点? 总结一下: Java、PHP也有办法实现并行请求(子线程),但NodeJS通过回调函数(Callb
您可能关注的文档
- net中的消息队列--博客园.docx
- 《电子商务技术概论》课程论文-宋雪琪-2014140084-Z计算机121.doc
- NewMicrosoftWordDocument标准.doc
- 《社会调查的理论与方法》期末复习串讲ppt与作业答案12月4日总结.doc
- 《第3课从汉至元政治制度的演变(人教版)》备课资料.doc
- Nero10刻录软件最新版图文教程.doc
- new委托业务设计编写提纲7.12.docx
- new工作总结与思路.doc
- 《经济法》08年1月考试题.doc
- 《职业生涯规划》教案3.doc
- 2025至2030年中国TPR合成橡胶粒市场现状分析及前景预测报告.docx
- 余代数的树结构剖析及其多元应用探究.docx
- 2025至2030年中国忍冬藤市场现状分析及前景预测报告.docx
- 2025至2030年中国肉鸡复合维生素预混料市场现状分析及前景预测报告.docx
- 逐行处理驱动的高光谱异常检测算法:高效性与精度的深度探索.docx
- 2025至2030年中国水辊调速装置市场现状分析及前景预测报告.docx
- 2025至2030年中国腺嘌呤市场现状分析及前景预测报告.docx
- 廉洁知识培训课件.pptx
- 2025至2030年中国钢制文件橱市场现状分析及前景预测报告.docx
- 装配式预应力鱼腹梁结构体系在深基坑支护中的应用.docx
文档评论(0)