node学习(一)基本使用

本文介绍了Node.js的基本原理和使用,包括其单线程、事件驱动的特点,以及如何利用事件循环处理高并发。同时,探讨了fs文件系统和http模块的同步、异步操作,并提及了Promise的使用。对于http服务,提到了Node.js原生API的底层特性,以及在实际应用中如何借助第三方模块如express和ejs简化开发。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

node学习(一)node的基本使用

Node是一个基于Chrome V8引擎的运行环境,使用了一个事件驱动、非阻塞式I/O模型,让JavaScript 运行在服务端的开发平台。

1. 原理初探

学一个框架时,弄清楚其原理是十分重要的,因为是初学,所以这里只给出了node的大体结构,深入探究将在最后几章给出。

1.1 node架构:

可以看到,除了node自己提供的标准库之外,node的底层操作主要由以下模块支持:

  • Node bindings: 将调用的java方法传递到c++层面执行,执行完毕后回调

  • V8引擎:v8是Google推出的java vm,其提供了javascript在非浏览器端的运行环境,并且十分高效

  • Libuv:其提供了跨平台、线程池、事件池、异步I/O的能力

  • C-ares:提供了异步处理DNS相关的能力

  • http_parser、OpenSSL、zlib等:提供包括 http 解析、SSL、数据压缩等其他的能力。

1.2. 底层交互

如图,我们在 Java 中调用的方法,最终都会通过 process.binding 传递到 C/C++ 层面,最终由他们来执行真正的操作。Node.js 即这样与操作系统进行互动。

1.3. 单线程应对高并发

node的主线程是单线程的,这意味着如果我们使用过多的同步代码,那么主线程中后面的代码就会被阻塞。那么,为什么单线程的node能够处理万级的并发呢?

1.4. 事件驱动/事件循环

为了效率,我们发现在node代码的编写时用到了大量的异步方法,这些方法是如何实现的呢?

1、每个Node.js进程只有一个主线程在执行程序代码,形成一个执行栈execution context stack)。

2、主线程之外,还维护了一个"事件队列"(Event queue)。当用户的网络请求或者其它的异步操作到来时,node都会把它放到Event Queue之中,此时并不会立即执行它,代码也不会被阻塞,继续往下走,直到主线程代码执行完毕。

3、主线程代码执行完毕完成后,然后通过Event Loop,也就是事件循环机制,开始到E

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值