nodeJS理解

nodejs是一个基于Chrome V8 引擎的JS运行环境,也就是让javascript运行在服务器(server)端
NodeJS使用了一个事件驱动,非阻塞式的I/O模型,使得其轻量又高效。
Nodejs包管理器npm是全球最大的开源生态系统。

nodejs是服务端的js平台。

npm grunt express 等强大的代码与项目管理应用在nodeJS上。

关于NodeJS与传统服务器处理平台(Apache)的区别
Apache的多线程高并发模式

Apache是一种多线程处理并发,但是在一些大型的web应用上也会发生阻塞。

线程和进程

线程是可以独立运行的最小的CPU单位。
线程可以在同一个进程中并发运行,并共享该进程下的内存地址空间。

进程可以支持多个线程,它们看似同时执行,但是相互之间并不同步。
一个进程中的多个线程共享相同的内存地址空间,意味着可以访问相同的变量和对象,并且从同一堆中分配对象。

这样让线程之间共享信息变得容易,但是也要确保他们不会妨碍同一进程中想的其他线程。

NodeJS的异步I/O原理

用数据库的调用举例:

Apache,执行到第一个线程的时候会等待query返回结果,一方面会导致线程长期阻塞等待,另一方面会为了新请求不断增加线程,会浪费大量的资源,同时线程增加会占用大量的CPU时间来处理内存上下文切换。

NodeJS是异步单线程的,应用的是异步回调的方法,也就是异步的I/O
解释:当进程执行的时候,不会等待结果的返回,而是直接执行下面的语句,直到进入事件循环,当数据库执行返回结果的时候会将事件发送到事件队列,等线程进入事件循环之后才会调用之前的回调函数。
也就是nodejs的工作原理其实就是事件循环。每一条nodejs的逻辑都是写在回调函数里面的,而回调函数都是返回之后才异步执行的。

NodeJS也会发生阻塞,但是阻塞发生在自己的单个线程当中,不是发生在后续回调的流程当中。

与php区别

用node来做网站开应用的是分块加载的模式,不用像php那样把所有的数据一次性加载到客户端。

NodeJS相比于php和Apache开的新线程来讲,节省了CPU内存和上下文切换的时间。

NodeJS的应用场景

NodeJs适合应用在具有大量的细小的http请求环境下,例如web的即时聊天程序,或者上万人同时在线的游戏服务器。不用考虑http请求次数过多的问题。

转载于:https://www.cnblogs.com/this-xiaoming/p/5845099.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值