深入浅出node(1) Node简介

这一系列主要是自己在学习深入浅出node.js这本书的学习笔试,部分加入了自己的一些理解 分享给一起学习node的小伙伴 自己还是个初学者 有很多地方理解的不到位 一起交流

  一 什么是node

    1.1 对比node chrome

  二 node的特点

    2.1 异步I/O

    2.2 事件驱动

    2.3 单线程

  三 node的使用场景    

 一)什么是node

  node是一种单线程,单进程的系统,它具有事件驱动,非阻塞I/O的特性,通过node这个基础框架我们能实现多种应用(web服务器 桌面应用 命令行工具等) node在实现上将chrome的V8引擎移动到后端,充分利用的V8的事件驱动,来构造应用.

  1.1 对比node chrome  在浏览器中中通过事件驱动服务界面  在node通过事件驱动服务I/O

二)node的特点  

  2.1 异步I/O 异步是对比同步来理解的,并且在实现异步I/O的基础上是结合事件驱动来实现的 简单的图理解事件驱动

简单的理解异步I/O 就是我们不必关注请求完成的时间,发起调用后会自动的执行后面的调用,事件监听器会调用设置的回调函数(存在数据的话,会作为参数传入),来达到异步I/O

这就涉及到 完成A B 任务的问题  假设A B任务不相关  在同步的模式下   任务完成的时间取决于 time(A) + time(B)  在异步的模式下   任务完成的时间取决于 max(time(A),time(B)) 这样任务不仅能并行的处理,也存在提升效率的可能.

  2.2 事件驱动

    事件驱动的编程模型具有轻量级,松耦合,只关注业务点等优势,但在多个异步任务的场景下下,事件与事件之间如何协同合作(回调的嵌套)是一个问题(promise)

  2.3 单线程? 

    在浏览器中javascript和用户界面的UI是共享一个线程的,也就是当js长时间的执行的时候,页面会被锁死,在node中也保持了js单线程这个特点,其实这个单线程的概念可以理解为无论是浏览器还是node中只存在一个主线程,在主线程运行的事件循环的逻辑,事件监听器,在浏览器中我们可以通过web workers来通过事件与主线程通信,在node中可以通过child_process来与主线程通信

单线程存在着下面的几个问题

  • 无法利用多核CPU
  • 错误会引发整个应用退出,应用的健壮性考虑(做好错误的处理)
  • 大量的计算占用CPU导致无法继续调用异步I/O(浏览器中js长期执行锁死页面)

三) node的使用场景

  通过上面的分析node非常的适合I/O密集型的应用,但是V8引擎的性能也是不错的,它在CPU密集型的应用上的表现也是不错的,我们可以将CPU密集任务分配给子线程进行计算,或者对任务进行切分(将大块的任务切分成小的任务防止对CPU的长期占用 一个任务如果长期的占用CPU我们就要考虑他的场景了),也就是像书中写的CPU密集型任务并不可怕,合理的调度才是关键

posted on 2016-12-27 13:58  icantunderstand  阅读(535)  评论(0编辑  收藏  举报

导航