我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Node.js 的异步 IO 性能探讨

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Node.js 的异步 IO 性能探讨

Python 和 Ruby 也有这样的框架,但因为在实际使用中会不可避免地用到含有同步代码的库,因此没能成长起来,而在 Node.js 之前,JavaScript 的服务器端编程几乎是空白,所以 Node.js 才得以建立起了一个所有 IO 均为异步的代码库。

大部分 Web 应用的瓶颈都在 IO, 即读写磁盘,读写网络,读写数据库。使用怎样的策略等待这段时间,就成了改善性能的关键点。

PHP 的策略:多进程运行,直接原地等待 IO 完成。缺点:多个进程会消耗多份内存,进程间难以共享数据。
C/C++ 通常的策略:多线程运行,程序自己维护锁的状态。缺点:开发成本高,容易出错,不易调试。
Python(Tornado): 多个请求在单个进程中轮流执行,遇到 IO 时切换到另一个请求。缺点:对于单个请求而言,依然没有最高效地利用时间。
何谓「最高效地利用时间」?比如现在有两个不相关的数据库查询,在 PHP 中通常会先执行一个,执行完成后再执行第二个(总时间是 a + b). 显然这不是最高效的,应该同时执行两个查询,时间是 max(a, b).

Python 和其他支持多线程的语言的问题就在于,在语言层面,程序员很难告诉虚拟机,应当将两个操作同时执行,即使有办法,也相当麻烦,大多数人懒得去用(也不值得去用)。而因为 Node.js 丧心病狂地强制所有 IO 异步执行,Node.js 的程序员也可以说是轻车熟路,配合一些改善代码可读性库(promise, async), 可以很轻松地让不相干的操作并行执行。

上面讲了异步 IO 的实现,那么异步 IO 的优势究竟体现在哪里呢。实际上异步 IO 并不能神奇地减轻服务器的压力,该加服务器还是一样要加服务器,只不过异步 IO 会减少单个请求的时间,去掉单个请求中那些无意义的等待时间。所以单位时间内处理的请求没有变化,但每个请求的处理时间却减少了。从这个角度,服务器也节约了一些资源——即维持每个请求的连接消耗的内存。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Node.js 的异步 IO 性能探讨

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Node.js 的异步 IO 性能探讨

Python 和 Ruby 也有这样的框架,但因为在实际使用中会不可避免地用到含有同步代码的库,因此没能成长起来,而在 Node.js 之前,JavaScript 的服务器端编程几乎是空白,所以 Node.js 才得以建立起了一个所有 IO
2022-06-04

Node.js 事件驱动编程与可伸缩性:探讨异步编程的伸缩策略

Node.js 采用事件驱动编程,支持高并发和可伸缩性。本文探讨异步编程的伸缩策略,帮助开发人员构建更具可扩展性的 Node.js 应用程序。
Node.js 事件驱动编程与可伸缩性:探讨异步编程的伸缩策略
2024-03-05

Golang中的异步IO如何优化高并发场景的性能?

在高并发场景中,异步 io 通过并发处理多个请求而不阻塞主线程的方式来提高应用程序性能。go 语言提供了丰富的异步 io 支持,包括 goroutine、channel 和 select 语句,可用于优化高并发场景。通过将 http 请求和
Golang中的异步IO如何优化高并发场景的性能?
2024-05-10

PHP 异步通知的应用场景及意义探讨

PHP 异步通知的应用场景及意义探讨随着互联网技术的不断发展,对于用户体验的要求越来越高,而异步通知作为一种提高系统效率、减少用户等待时间的方式,被广泛应用于各种互联网服务中。在PHP开发中,通过异步通知可以实现诸如支付结果回调、消息推送
PHP 异步通知的应用场景及意义探讨
2024-03-11

深入探讨:Golang异步编程的本质是什么?

go 语言的异步编程本质是通过协程和通道实现的。协程是共享内存空间的轻量级线程,可在单个线程上并行执行;通道用于在协程之间通信,强制执行控制流,避免竞态条件。实战案例:创建一个协程写入通道,主协程从通道读取值并打印,展示异步编程在不阻塞执行
深入探讨:Golang异步编程的本质是什么?
2024-04-04

Node.js EventEmitter 入门:探索异步编程的基石

Node.js 的 EventEmitter 是一个强大的工具,它使异步编程变得容易。通过发出和监听事件,应用程序可以协调不同任务的执行,实现高度响应和可扩展的系统。
Node.js EventEmitter 入门:探索异步编程的基石
2024-02-19

C++ 递归与尾递归:性能差异和优化实践探讨

c++++ 中标准递归会产生栈空间和时间开销,而尾递归不会。优化实践包括识别尾递归、转化为尾递归和启用编译器支持。尾递归比标准递归性能更高,因为它避免了创建额外活动记录和相关的开销。C++ 递归与尾递归:性能差异和优化实践探讨递归是一种强
C++ 递归与尾递归:性能差异和优化实践探讨
2024-05-04

Go函数性能优化:异步编程与非阻塞IO处理

异步编程和非阻塞 i/o 处理是两项针对 go 函数性能优化的重要技术。异步编程通过使用 goroutine 实现并发执行 i/o 操作,而非阻塞 i/o 处理允许立即返回而不等待 i/o 完成,从而提高应用程序的吞吐量。通过使用这些技术,
Go函数性能优化:异步编程与非阻塞IO处理
2024-04-30

C++图形编程:优化性能的深入探讨

提升c++++图形编程性能的深入探索:硬件优化:选择高性能显卡和多核处理器。代码优化:避免不必要拷贝,优化数据结构,使用内联和汇编。渲染优化:分批渲染,使用层次细分,避免过度绘制。实战案例:并行加载场景对象,优化复杂模型的渲染。C++图形编
C++图形编程:优化性能的深入探讨
2024-05-10

编程热搜

目录