mlczhg 发表于 2017-2-21 09:49:52

从nodejs看异步机制

  最近再写nodejs项目,都说nodejs是单个线程,是异步回调机制,我自己想了一下nodejs的异步线程模型和非异步机制的不同,认识比较肤浅,上图:
  我们先看第一个图(假设是一个java web系统):
  第一个图是一个同步机制的web系统。假设左边的IO是http请求,右边的IO是查询数据库。
  1,一个请求过来,经过左侧的IO系统创建一个新的线程,在这个线程中完成一些业务。
  2,这个线程中发起访问数据库,并开始等待右边的IO返回
  3,右边IO返回,这个线程返回(response)右边的线程。
  4,线程结束。
  整个过程从左边的IO到右边的IO,再到左边的IO是在一个线程中完成的,这个是需要耗时的;而一个线程是要占用系统资源的。线程生存时间越长,就导致系统并发量越低。
  

 
  我们再看第二个图(假设是一个nodejs的系统)
  1,一个请求过来,经过左侧的IO系统创建一个新的线程,在这个线程中完成一些业务。
  2,这个线程中发起访问数据库并结束。
  3,右边IO返回通过单个线程回调,建立另一个线程进行response,之后结束。
  我们不难看出,第二个图右侧IO的时候我们释放了之前的线程,这就可以让系统可以去处理更多的web请求。
  认识比较肤浅,不知道是不是确实是这样,
页: [1]
查看完整版本: 从nodejs看异步机制