nodejs 单线程为什么效率这么高?

nodejs单线程是js运行环境是单线程的,只有一个主线程。为什么一个单线程的效率可以这么高,处理数万级的请求并不会堵塞呢?这一切得益于nodejs 的事件驱动。

一.事件驱动 、事件循环、线程池

1.每个nodejs 进程只有一个主线程执行程序代码(单线程),形成一个执行栈。

2.主线程之外,还维护一个“事件队列”,当用户的网络请求或者其他异步操作的时候,node都会把操作放到事件队列中,此时并不会立即执行它,然后执行后面的代码,这时代码没有被阻塞,直到主线程代码执行完毕。

3.主线程代码执行完毕后,然后通过事件循环机制,到事件队列中取出第一个事件,然后从线程池分配一个线程去执行这个事件,然后取出第二个事件在分配一个线程去执行这个事件,然后一直循环。主线程不断的检查事件队列中是否有未执行的事件,直到所有事件执行完毕。此后每当有的事件加入到事件队列中,都会通知主线程按照顺序从事件队列中取出交给事件循环处理。当有事件执行完毕后,会通知主线程执行回调,返回结果,然后将线程交给线程池。

4.主线程重复执行第三步。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值