知识点
什么是node js
Node.js是一个Javascript运行环境(runtime)。实际上它是对Google V8引擎进行了封装。V8引 擎执行Javascript的速度非常快,性能非常好。Node.js对一些特殊用例进行了优化,提供了替代的API,使得V8在非浏览器环境下运行得更好。
Node.js是一个基于Chrome JavaScript运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞I/O 模型而得以轻量和高效,非常适合在分布式设备上运行数据密集型的实时应用。
创始人:Ryan Dalh,创建时间:2009年 ps:10年打磨一把兵器 ,虽然没有其它语言时间长,但是也是经历了时间洗礼
node js 的优点
- 一个字快
但相对耗费内存 有人测试过一个百万级并发测试,未经优化的情况下1M链接消耗了16G的内存 - restful API
- 单线程
有些人对单线程和多线程了解不是很清楚,甚至认为单线程一定没有多线程好,给大家举个例子来描述中餐馆和肯德基完美的诠释了个中区别,我们可以把中餐馆看作多线程,我们去点餐,服务人员很多(多线程),人多我们催菜的时候,不同的服务人员多会说我帮你催下,但其实不解决问题,上菜速度还是取决于后厨制作的速度,而肯德基大家也不陌生了可以理解为一个典型的单线程,只有一个点餐窗口,我们只需要进去排队点单后在旁边等下就好,食物上来的速度很快,因为后厨人员效率高。 - 非阻塞IO
- V8虚拟机
- 事件驱动
- 可以对任务进行并行处理 (解决大数量请求阻塞问题)
- 应用广泛,开发桌面应用,electron框架,使JS 脱离浏览器环境…
NodeJs劣势及解决方式
- 默认不支持多核,但可以用cluster解决
- 默认不支持服务器集群,node-http-proxy可以进行解决
服务器集群就是指将很多服务器集中起来一起进行同一种服务,在客户端看来就像是只有一个服务器。集群可以利用多个计算机进行并行计算从而获得很高的计算速度,也可以用多个计算机做备份,从而使得任何一个机器坏了整个系统还是能正常运行。 - 使用nginx做负载均衡,静态的由nginx处理,动态的由NodeJs处理
- forever或者node-cluster实现灾难恢复
框架的选择
- Express:完善、稳定、文档全、社区大
- Koa:超前
- Hapi:复杂(一个简单的HelloWorld都需要进行很多的堆砌,适合做复杂又大型的项目)