一、Nodejs介绍
1、nodejs是ecma 的runtime
2、nodejs使用了event-driven(事件驱动)和non-blocking I/O model(无阻塞的io模型)
- 非阻塞:I/O时函数立即返回,进程不等I/O完成
- event-driven:Nodejs靠事件进行驱动
3、cpu密集 vs I/O密集
- cpu密集:压缩、解压、加密、解密
- I/O密集:文件操作、网络操作、数据库
因为JS操作是I/O密集,所以Nodejs是JS在serves上面的runtime
4、高并发应对之道
- 增加机器数
- 增加每台机器的cpu数
5、Nodejs单线程
- 单线程只针对主进程,I/O操作系统底层多线程调度(Nodejs自己是单线程,但它有一部分任务交给操作系统自己去做多线程)
- 单线程不是单进程
6、Nodejs应用场景
- Web Server
- 本地代码构建(编译之类)
二、Nodejs开发环境与调试工具
1、环境
- CommonJS 规范
- global 对象(类似于js里面的window对象)
- process 当前执行的进程
2、CommonJS规范
- 每个文件都是一个模块,都有自己的作用域
- 在模块内部module变量代表模块本身
- module.exports属性代表模块对外接口(将模块的一些东西输出)
- require规则
- / 表示绝对路径,. / 表示相对于当前文件的
- 支持js、json、node的拓展名
- require特性
- module被加载的时候会执行一遍,并进行缓存,第二次直接用缓存里面的结果
- 当一个模块被循环加载(a依赖b,然后b又依赖a),那么只会输出已经执行的部分(a执行在b依赖a之前a该执行的部分)
3、global全局对象
- CommonJS
- Buffer、process、console
- timer
继续阅读与本文标签相同的文章
上一篇 :
2018年DevOps的新趋势
下一篇 :
针对DevOps的10款最佳Jenkins插件
-
将阿里云产品整合成为高校课程实训的训练营产品的实践(四)
2026-05-18栏目: 教程
-
中间人攻击,HTTPS也可以被碾压
2026-05-18栏目: 教程
-
什么叫做IaC,与DevOps有什么关系?如何实现?
2026-05-18栏目: 教程
-
解读《运维知识体系》,直面自动化运维的“灵魂八问”
2026-05-18栏目: 教程
-
阿里99大促 | 模型识别背后的样本生成
2026-05-18栏目: 教程
