nodejs单线程是js运行环境是单线程的,只有一个主线程。为什么一个单线程的效率可以这么高,处理数万级的请求并不会堵塞呢?这一切得益于nodejs 的事件驱动。
一.事件驱动 、事件循环、线程池
1.每个nodejs 进程只有一个主线程执行程序代码(单线程),形成一个执行栈。
2.主线程之外,还维护一个“事件队列”,当用户的网络请求或者其他异步操作的时候,node都会把操作放到事件队列中,此时并不会立即执行它,然后执行后面的代码,这时代码没有被阻塞,直到主线程代码执行完毕。
3.主线程代码执行完毕后,然后通过事件循环机制,到事件队列中取出第一个事件,然后从线程池分配一个线程去执行这个事件,然后取出第二个事件在分配一个线程去执行这个事件,然后一直循环。主线程不断的检查事件队列中是否有未执行的事件,直到所有事件执行完毕。此后每当有的事件加入到事件队列中,都会通知主线程按照顺序从事件队列中取出交给事件循环处理。当有事件执行完毕后,会通知主线程执行回调,返回结果,然后将线程交给线程池。
4.主线程重复执行第三步。