浏览器端的io操作
当浏览器中有io操作的时候,该操作会在事件轮询的外面执行,也就是脚本执行的主顺序之外,当这个io操作完成之后,会发出一个事件,此时会有一个函数来响应这个事件,异步操作不会阻塞脚本执行,事件轮询任然可以相应页面上执行的其他交互请求,这样,浏览器就会对客户做出回应,并且处理页面上的交互动作
服务端的异步事件
1 .如果程序在io上阻塞了,当有更多的请求过来的时候,服务器最常见的就是再开一个线程,并为那些连接设置一个线程池
2 .在node中,io总是处在主事件轮询之外,使得服务器可以一直处于高效并且随时能够做出响应的状态,就像NGINX一样,这样进程不受io的限制,因为io的延迟不会拖垮服务器,或者像是在阻塞方式下占用很多资源。因此在一些服务器上曾经是重量级的操作,在node上仍旧是非常轻量级的
优点
1 .restful api搭建非常方便
2 .单线程:所有的代码都是单线程执行,宿主环境会维护一个执行队列,循环检测并调度js线程来执行,实现不冲突的单线程和并发操作。
3 .事件轮询:node可以在不增加额外线程的情况下,实现对并行任务实时处理。
4 .非阻塞的io:使用了时间循环来解决io操作带来的瓶颈问题,在node中,一个io带有一个执行函数,当io操作完成之后,调用这个函数,主线程继续执行下面的代码。
5 .一个线程,不会出现死锁的现象,在执行较长时间的访问数据库代码的操作之后,立即执行后面的代码,提高执行效率
6 .java处理后台每连接一个用户需要创建一个新的线程,2mb大小,所以服务器理论上是有最大连接数量的限制,但是node为每个客户连接只是触发一个事件,因此可以同时处理几万个用户的连接,支持大量的高并发连接
7 .事件驱动:客户端的请求建立,并通过此链接而接受客户端提交数据,停止客户端提交数据的接受等行为而出发的事件。在node中,一个时刻只能执行一个事件的回调函数,但是在执行一个事件回调函数的途中可以去处理其他事件,然后继续返回处理原事件的回调函数