日期:2014-05-16  浏览次数:20461 次

从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请求。

?

认识比较肤浅,不知道是不是确实是这样,

?

?