web前端培训nodejs异步IO
1.IO了解
IO分类(是否立即获取到调用之后的结果):
阻塞IO:
重复调用IO操作,判断IO是否结束(任务轮询:read、select、poll、kqueue、event ports)因为在轮询的过程中,程序再等待IO的结果,对于代码而言,还是同步的效果。
非阻塞IO:
实现无需判断的非阻塞IO,通过某种信号或者回调的形式传回给当前的代码进行使用
文件IO:
放入到node实现的线程池中
异步网络IO:
利用到了node的核心库libuv库
可判断所运行的平台
根据平台调用不同的异步IO处理的方法(做到了类似于跨平台的效果)
实现异步IO的过程:
2.为什么要使用异步I/O
在不同模式下执行两任务,显然,异步使用的时间,比同步使用的时间少
3.事件驱动架构
事件轮询是异步IO的实现,对异步IO结果的处理(利用事件驱动、发布订阅、观察则模式),依赖于nodejs的events库;
代码层面展示:
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单线程
怎么实现并发:异步非阻塞IO配合事件事件回调通知
运行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('服务启动了');
})
适合IO密集型任务处理,nodejs作为中间层,搭建bff层服务器(提高吞吐量,方便处理数据):
文章来源于SegmentFault思否
举报/反馈
最近更新安全教育
- 高淳古柏:双百共建社区行 凝青聚力促发展
- 博弈激烈、分化加剧 上海楼市新政落地调查丨深度
- 原创35岁老将马龙宣布生涯重大决定,刘国梁批准,王皓遗憾
- 成人自考有入学考试吗?
- 高长力:以精品奉献人民,担负起新的文化使命
- 躬耕教坛育桃李
- 逐梦绿茵 快乐成长——峨眉二小夺冠之旅
- 促进交流合作 多方助推“一带一路”人才发展
- 慈利:全力打造高质量发展人才高地
- 2023年度宝山区促进人力资源服务产业高质量发展资助申报工作开始啦!
- 支持年轻人敢闯敢试 上海将愈发精彩
- 数商兴农!韶关三年将培育逾万名高素质电商人才
- 讲好国家级新区故事 兰州新区递出“名片”全球吸粉
- 托福阅读满分3阶段
- 强作风 展新貌 常德市城管执法支队开展军事化集训
- 违规组织学科培训,查处!
- 11月1日起试行!河北部署开展经营主体除名标记工作
- 老人术后体内发现5颗牙和牙套,直至离世仍有1颗未取出
- 成都高新区:加速打造创新人才集聚区
- 女子为减肥连吃3月胡萝卜变“小橘人”,当事人:还搭配姜黄粉一起吃;医生:被染色了
- 刚刚揭晓!厦大教授入选!5年将获资助2500万元
- 名单公布!黄石这些企业上了红黑榜→
- 台风“三巴”影响北部湾,北海提升防汛防台风应急响应至二级
- 吃喝都在路边?闵行这个物流园区外货车扎堆,居民吐槽半夜启动噪声大
- 反思后的小鹏,像华为?还是像特斯拉?