node.js到底提高了什么效率,能应对高并发?

fdjkalfjklajdf 2013-12-07 06:24:19
node.js为什么能解决高并发?单线程的事件驱动怎么就能提高高并发?还不是要对每个请求进行生成数据响应吗,当请求多了不还是处理不过来吗?他这种设计方式到底提高了处理中的哪个环节的效率啊?
...全文
4290 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
ftiger 2013-12-08
  • 打赏
  • 举报
回复
异步的优势,可以参考ajax,ajax全称是异步的javascript和xml,为什么要异步,HttpRequest是可以同步操作的,但同步时如果HttpRequest没有返回时,浏览器就象给卡住了,什么都动不了。 同理在服务器端,异步最大的好处就是最大限度的消除了IO等待的问题。 不过在多并发的生产环境中,最后系统的瓶颈还是会卡在IO上,nodejs对此帮助有限,所以还是要考虑内存数据之类的方案提高IO性能,开发语言还是按自己喜好和团队优秀合理选择。
xuzuning 2013-12-08
  • 打赏
  • 举报
回复
那是忽悠人的,或者说是介绍者的“口误” 如果是“不用维护维护多个连接请求”,那么处理结束后把结果返回给谁? node.js 支持 server push 不维护连接向谁“推”?广播?
fdjkalfjklajdf 2013-12-07
  • 打赏
  • 举报
回复
引用 5 楼 ftiger 的回复:
简单的理解在异步的优势,就是导弹中的发射后用不用管的做法。同步,你去操作IO,IO没有返回,你就在那等着吧,所以同步的程序象apache,就要开很多的进程,专门存放存放这此同步的操作,关键是一整套的操作全在那里挂着耗内存和别的资源呢。 异步,发送IO操作请求后,你可以去做别的事,IO返回后会自动做下一步的,而且你可以同时发起多个IO然后一起汇总。所以只用单线程就可以了,每一步的操作可以用整体更少的资源满足要求。
谢谢详细的指导。 我关于node.js长处的理解: 1、node.js通过明确分工的方式,将接收请求和处理请求分开,让接待和生产各司其职。这样就不用维护维护多个连接请求,节约内存,解决需要多开服务器的问题。 2、通过事件回调机制,自然解决I/O阻塞问题,提高处理速度。
fdjkalfjklajdf 2013-12-07
  • 打赏
  • 举报
回复
引用 4 楼 shendaowu 的回复:
Node.js好像号称除了代码全都是并发的。要理解Node.js的原理你可能需要了解一些多线程或者并发的基本知识,否则就算解释也有牵强附会的嫌疑,而就算你感觉明白了也不是一种本质上的理解。
我觉得一个编程技术都是人想出来的,肯定有现实的类似的模型做为基础。一个东西的本质就应该是简单明了的。
ftiger 2013-12-07
  • 打赏
  • 举报
回复
简单的理解在异步的优势,就是导弹中的发射后用不用管的做法。同步,你去操作IO,IO没有返回,你就在那等着吧,所以同步的程序象apache,就要开很多的进程,专门存放存放这此同步的操作,关键是一整套的操作全在那里挂着耗内存和别的资源呢。 异步,发送IO操作请求后,你可以去做别的事,IO返回后会自动做下一步的,而且你可以同时发起多个IO然后一起汇总。所以只用单线程就可以了,每一步的操作可以用整体更少的资源满足要求。
申祷无 2013-12-07
  • 打赏
  • 举报
回复
Node.js好像号称除了代码全都是并发的。要理解Node.js的原理你可能需要了解一些多线程或者并发的基本知识,否则就算解释也有牵强附会的嫌疑,而就算你感觉明白了也不是一种本质上的理解。
KK3K2005 2013-12-07
  • 打赏
  • 举报
回复
就是快餐店和 多列排队的比较 那段
fdjkalfjklajdf 2013-12-07
  • 打赏
  • 举报
回复
引用 1 楼 KK3K2005 的回复:
http://www.cnblogs.com/sysuys/p/3460614.html
就是看的这个产生的问题。。
KK3K2005 2013-12-07
  • 打赏
  • 举报
回复
http://www.cnblogs.com/sysuys/p/3460614.html

87,997

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧