nodejs异步IO
SegmentFault
共 1826字,需浏览 4分钟
· 2022-04-27
作者:小江不可求
来源:SegmentFault 思否社区
1.IO了解
IO分类(是否立即获取到调用之后的结果):
阻塞IO:
重复调用IO操作,判断IO是否结束(任务轮询:read、select、poll、kqueue、event ports)因为在轮询的过程中,程序再等待IO的结果,对于代码而言,还是同步的效果。
文件IO: 放入到node实现的线程池中 异步网络IO: 利用到了node的核心库libuv库 可判断所运行的平台 根据平台调用不同的异步IO处理的方法 (做到了类似于跨平台的效果)
2.为什么要使用异步I/O
3.事件驱动架构
代码层面展示:
const EventEmitter = require('events');
const emitter = new EventEmitter();
// 订阅1
emitter.on('event',(result)=>{
console.log('event1 fired');
console.log(result);
})
// 订阅2
emitter.on('event',(result)=>{
console.log('event2 fired');
})
// 发布
emitter.emit('event','event_result');
/*结果
event1 fired
event_result
event2 fired
*/
4.nodejs单线程
运行js代码的主线程是单线程(减少了多线程切换的cpu开销与内存开销),但是在libuv库中,使用到了node实现的线程池
缺点:处理cpu密集型的任务时,无法体现多核cpu的优势
代码展示单线程处理cpu密集型任务时出现的阻塞现象:
const http = require('http');
function sleepTime(time){
const sleep = Date.now() + time * 1000;
// 同步代码,等待时间
while(Date.now() < sleep){};
return;
}
sleepTime(4);
const server = http.createServer((req,res)=>{
res.end('server starting ...');
});
server.listen('8080',()=>{
console.log('服务启动了');
})
5.nodejs应用场景
评论
AIO4J异步 IO 框架
AsynchronousIOforJava(AIO4J)提供在套接字和文件上执行异步IO的功能。AIO4J可以替代经典的同步IO,并且还可以替代Java1.4中引入的NewIO包(java.nio),
AIO4J异步 IO 框架
0
aiodockerDocker 异步 IO 绑定
aiodocker——AsyncIObindingsfordocker.io示例代码:#!/usr/bin/env python3import asynciofrom aiodocker.docker
aiodockerDocker 异步 IO 绑定
0
uvloopPython 异步 IO 事件循环
uvloop是python异步io事件循环第三方实现,基于Node.js底层异步io库libuv,可以轻松替换python标准库asyncio的事件循环,大幅提高io性能。使用方法非常简单:impor
uvloopPython 异步 IO 事件循环
0
libuv跨平台异步 IO 库
libuv是Node的新跨平台抽象层,用于抽象Windows的IOCP及Unix的libev。作者打算在这个库的包含所有平台的差异性。特性:非阻塞TCP套接字非阻塞命名管道UDP定时器子进程生成通过u
libuv跨平台异步 IO 库
0
vibe.d异步 IO 和 Web 开发框架
vibe.d是一个D语言开发的异步I/O框架和Web开发框架。高性能异步IO,最大化速度,最小化内存占用;编译期模版,无与伦比的动态页面性能;编译为机器码;集成的负载均衡;更多...简单基于纤程(协程
vibe.d异步 IO 和 Web 开发框架
0
kbio基于 io-uring 的异步 IO 框架
kbio是基于io_uring的异步IO框架,被用于实现 KuiBaDB 的异步I/O。特性支持多线程并发任务提交速度快实现在tokio中引入的AsyncRead/AsyncWritetrait示例a
kbio基于 io-uring 的异步 IO 框架
0