曾经的单线程模型在同步I/O的影响下,因为I/O调用缓慢,应用层面CPU和I/O没法重叠进行。可是该模型符合编程人员的阅读思惟习惯,所以同步I/O盛行了不少年。可是该模型存在性能问题,过去能够经过多线程的方式提高性能。可是从操做系统调度多线程的上下文切换开销,到实际编程里锁,同步等问题,让开发人员头疼的时候并很多。javascript
Node带来的最大优点是基于事件驱动的非阻塞I/O模型。Node经过事件循环的方式实现异步I/O,javascript线程负责分配任务和处理结果。I/O线程池里的线程完成分配的任务。因此能够保持总体的高效率。java