最近对Node.js产生了兴趣,就研究了一下,首先Node.js不是一种独立的语言,也不是一个javascript框架,它是一个让javascript运行在服务端的开发平台,它让javascript成为脚本语言世界的一等公民,在服务端堪舆php、python、perl、Ruby平起平坐。
Node.js可以作为服务器向用户提供服务,它跳过了Apache等Http服务器,直接面向前端开发。Node.js的作用:1、可以很轻松的开发具有复杂逻辑的网站,2、基于社交网络的大规模Web应用,3、Web Socket 服务器 ,4、TCP/UDP套接字应用程序 ,5、命令行工具,6、交互式终端程序,7、带有图形用户界面的本地应用程序,8、单元测试工具,9、客户端javascript编译器。Node.js内置了HTTP服务器支持,可以直接实现网站和服务器的组合。
Node.js的最大特点就是采用异步式I/O与事件驱动的架构设计。对于高并发的解决方案,传统架构是多线程模型,也就是为每个业务逻辑提供一个系统线程,通过系统线程的切换来弥补同步式I/O调用时的时间开销。Node.js使用的是单线程模型,对于所有的I/O都采用异步式的请求方式,避免了频繁的上下文切换。Node.js在执行过程中会维护一个事件队列,程序在执行时进入事件循环等待下一个事件到来,每个异步式I/O请求完成后会被推送到事件队列,等待程序进场进行处理。
数据库操作来体现传统的操作方式和Node.js的处理方式不同之处。
传统方式:
res = db.query('select * from some_table');
res.output();
Node.js方式:
db.query('select * from some_table', function(res){res.output();});
上面的代码中,db.query()的第二个参数是一个回调函数,进程在执行到db.query()的时候,不会等待结果的返回,而是直接继续执行后面的语句,直到进入事件循环。当数据库查询结果返回时,会将事件发送到事件队列,等到线程进入事件循环之后,才会调用之前的回调函数继续执行后面的逻辑。
Node.js的异步机制是基于事件的,所有的磁盘I/O、网络通信、数据库查询都已非阻塞的方式请求,返回的结果由事件循环来处理。由于Node.js用异步式I/O和事件驱动代替多线程,带来了可观的性能提升。