NodeJS全栈开发面试题讲解——P1Node.js 基础与核心机制

1.1 Node.js 的事件循环原理?如何处理异步操作?

面试官您好,我理解事件循环是 Node.js 的异步非阻塞编程核心。

Node.js 构建在 V8 引擎与 libuv 库之上。虽然 Node.js 是单线程模型,但它通过事件循环(event loop)机制实现了异步 IO 和高并发能力。

🔁 事件循环核心阶段(简略版):

每一轮事件循环分为多个阶段,关键阶段有:

  1. timers:执行 setTimeoutsetInterval 的回调;

  2. pending callbacks:处理某些系统延迟回调;

  3. poll:执行 IO 回调,如网络、磁盘读取;

  4. check:执行 setImmediate() 回调;

  5. close callbacks:如 socket.on('close')

  6. 每个阶段结束后,还会处理 microtasks(如 process.nextTick()Promise.then());

🧠 异步操作如何配合事件循环?

比如我们调用异步文件读写:

fs.readFile('a.txt', () => {console.log('读文件完成');
});
  1. 任务由 libuv 线程池处理;

  2. 完成后注册回调,等待事件循环进入相应阶段;

  3. 在 poll 阶段执行对应的回调。


1.2 process.nextTick()、setImmediate()、Promise 的执行顺序?

这是一个非常容易被问到的陷阱问题,我用执行模型来解释它的顺序。

Node.js 将任务划分为两类:

  • Microtasks(微任务)process.nextTick()Promise.then()

  • Macrotasks(宏任务)setTimeoutsetImmediate

每个事件循环阶段后,都会清空微任务队列。

📌 执行优先级(从高到低):

1. process.nextTick()       // Node独有,优先级最高
2. Promise.then()           // 标准微任务
3. setTimeout(fn, 0)        // timers 阶段
4. setImmediate()           // check 阶段

🧪 示例代码:

setTimeout(() => console.log('timeout'), 0);
setImmediate(() => console.log('immediate'));
process.nextTick(() => console.log('nextTick'));
Promise.resolve().then(() => console.log('promise'));

📌 输出顺序:

nextTick
promise
timeout
immediate

补充:过多使用 process.nextTick() 会造成主线程“饿死”(starvation),所以要慎用。


1.3 如何避免阻塞主线程?举例说明

面试官,Node.js 是单线程的,一旦主线程执行了重 CPU 运算,就会阻塞事件循环,影响并发。

🧨 示例:阻塞代码

// 计算大量斐波那契数
function fibonacci(n) {if (n <= 1) return 1;return fibonacci(n - 1) + fibonacci(n - 2);
}
fibonacci(40); // 卡住主线程

✅ 避免方法:

✅ 1. 使用 worker_threads 执行 CPU 密集型任务
const { Worker } = require('worker_threads');
new Worker('./compute.js');
✅ 2. 拆分任务(分段执行)
function heavyTask() {let count = 0;function loop() {for (let i = 0; i < 10000; i++) count++;if (count < 1e6) setImmediate(loop);}loop();
}
✅ 3. 借助外部服务(如 Redis 缓存、Nginx 静态托管)减少计算需求

1.4 Node.js 如何实现定时任务?和浏览器定时器有区别吗?

面试官,Node.js 提供和浏览器相同 API,但其实现机制完全不同。

📌 相同点:

  • setTimeout(fn, ms)setInterval(fn, ms) 可用;

  • 支持取消:clearTimeout()clearInterval()

📌 不同点:

特性Node.js(libuv)浏览器(Web APIs)
核心实现libuv 的事件循环浏览器引擎 + 宿主环境
最小时间精度非实时,受事件循环影响一般为 4ms 最小
setImmediate()Node 独有,check 阶段执行无此函数


📌 高级定时任务方案(Node 专属):

  1. node-cron:cron 表达式任务调度;

  2. Agenda / Bree:基于数据库/文件持久化的任务调度;

  3. Redis 轮询 + 消息队列:实现分布式定时触发;

const cron = require('node-cron');
cron.schedule('0 0 * * *', () => console.log('每天零点执行'));

1.5 cluster 模块的原理及适用场景?如何实现负载均衡?

面试官,cluster 是 Node.js 提供的多进程扩展机制,用于充分利用多核 CPU 提升吞吐量。

🔧 原理:

  • 主进程(Master)通过 cluster.fork() 创建多个 worker 子进程;

  • 所有 worker 共享同一个 server 端口;

  • 实际请求由主进程分发给 worker 处理;

  • 每个 worker 都是独立的 Node 实例,进程隔离、内存独立;

const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;if (cluster.isMaster) {for (let i = 0; i < numCPUs; i++) cluster.fork();
} else {http.createServer((req, res) => {res.end(`Worker ${process.pid} handled request`);}).listen(3000);
}

⚖️ 负载均衡策略:

  • Linux:基于 SO_REUSEPORT,内核自动均衡分发请求;

  • Windows/macOS:Node 内部使用 Round-Robin 分发策略;

  • Node v16+ 支持与 worker_threads 混合使用,提高 CPU 利用率;


✅ 适用场景:

  • 高并发 API 服务(如网关、接口层);

  • IO 与 CPU 混合负载应用;

  • 可与 pm2 配合实现进程守护 + 负载均衡;


❗ 注意事项:

  • 不共享内存,通信需用 IPC(如 worker.send());

  • 状态同步麻烦(需借助 Redis 等中间件);

  • cluster 并不适合细粒度计算,适合粗粒度多请求任务;


✅ 总结回顾

问题核心关键词
1.1libuv、事件循环、阶段、异步 IO
1.2微任务 vs 宏任务、执行优先级
1.3阻塞避免、worker_threads、任务拆分
1.4Node 定时器机制、cron、高级调度
1.5cluster 原理、多进程、负载均衡策略

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/82115.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【深度学习】sglang 的部署参数详解

SGLang 的部署参数详解 SGLang(Structured Generation Language)是一个高性能的大语言模型推理框架,专为结构化生成和多模态应用设计。本文将全面介绍SGLang的部署参数,帮助你充分发挥其性能潜力。 🚀 SGLang 项目概览 SGLang是由UC Berkeley开发的新一代LLM推理引擎,…

MATLAB实战:机器学习分类回归示例

以下是一个使用MATLAB的Statistics and Machine Learning Toolbox实现分类和回归任务的完整示例代码。代码包含鸢尾花分类、手写数字分类和汽车数据回归任务&#xff0c;并评估模型性能。 %% 加载内置数据集 % 鸢尾花数据集&#xff08;分类&#xff09; load fisheriris; X_i…

数组。。。。。

//创建Book 对象&#xff0c;放入相关的属性private String name;//书名private String[] writer;//作者private List<String> reader;//读者private Map<String, Object> topics;//评讲Book book new Book();book.setName("昆虫总动员");book.setWrite…

day16 leetcode-hot100-31(链表10)

25. K 个一组翻转链表 - 力扣&#xff08;LeetCode&#xff09; 1.模拟法 思路 将这个过程拆解为两个步骤&#xff0c;第一步将单分组的节点反转&#xff0c;第二步将反转后的链表加入原链表。 针对节点反转很容易&#xff0c;参考之前的206. 反转链表 - 力扣&#xff08;Le…

测试总结(二)

持续集成 软件开发实践 开发提交代码到gitlab上 自动化构建&#xff08;编译、打包、部署、自动化测试&#xff09; 尽早发现集成问题 过程&#xff1a; 提交代码-人工/定时触发-自动构建-自动部署-构建成功-获取构建环境信息-邮件通知-自动测试 快速集成、快速反馈、快速解决…

(二)微服务(grpc/grpc消费者)

文章目录 项目地址一、grpc介绍1.1 项目初始化1. 创建grpc项目2. 项目结构二、Discount grpc创建2.1 实体层1. Coupon实体2.2 Protos1. 创建discount.proto2. 配置proto3. 创建DiscountService4. Program里注册服务2.3 Seed 数据1. 创建表和Seed数据2. 自动migration2.4 更新Do…

InfluxQL 数据分析实战:聚合、过滤与关联查询全解析

InfluxQL 作为时序数据库的专用查询语言&#xff0c;在处理时间序列数据时展现出独特优势。本文深入探讨 聚合计算、数据过滤和跨测量关联 三大核心操作&#xff0c;通过真实代码示例展示如何从海量时序数据中提取关键洞察。文中涵盖从基础平均值计算到复杂多维度分析的完整流程…

TDengine 运维——巡检工具(安装前检查)

简介 本文档旨在介绍 TDengine 安装部署前后配套的巡检工具。 相关工具的功能简介&#xff1a; 工具名称功能简介安装前检查部署前对 TDengine 安装部署的依赖要素进行安装前检查安装前预配置部署前对 TDengine 安装部署的依赖要素进行安装前预配置安装部署指定环境安装部署…

大语言模型(LLM)入门 - (1) 相关概念

文章来自&#xff1a;大语言模型(LLM)小白入门自学项目-TiaoYu-1 GitHub - tiaoyu1122/TiaoYu-1: For People! For Freedom!For People! For Freedom! Contribute to tiaoyu1122/TiaoYu-1 development by creating an account on GitHub.https://github.com/tiaoyu1122/TiaoYu…

LearnOpenGL-笔记-其十一

Normal Mapping 又到了介绍法线贴图的地方&#xff0c;我感觉我已经写了很多遍了... 法线贴图用最简单的话来介绍的话&#xff0c;就是通过修改贴图对应物体表面的法线来修改光照效果&#xff0c;从而在不修改物体实际几何形状的前提下实现不同于物体几何形状的视觉效果。 因…

Spring Boot 读取.env文件获取配置

Spring Boot 读取.env文件获取配置 在Resouce 目录下创建.env文件 # DEEP SEEK TOKEN DEEP_SEEK_TOKENyour_deep_seek_key # 阿里云百炼 TOKEN ALI_BAILIAN_TOKENyour_ali_bailian_keyyml引入.env文件 spring:config:import: optional:classpath:.env[.properties]使用.env文…

【C++高级主题】命令空间(三):未命名的命名空间

目录 一、未命名的命名空间的基本概念 1.1 定义与特点 1.2 基本语法 1.3 访问方式 1.4 未命名的命名空间的作用 二、未命名的命名空间与静态声明的比较 2.1 静态声明的作用 2.2 未命名的命名空间的优势 2.3 示例代码比较 2.4. 未命名的命名空间的作用域和链接属性 三…

【Unity】AudioSource超过MaxDistance还是能听见

unity版本&#xff1a;2022.3.51f1c1 将SpatialBlend拉到1即可 或者这里改到0 Hearing audio outside max distance - #11 by wderstine - Questions & Answers - Unity Discussions

多个vue2工程共享node_modules

手头有多个vue2项目&#xff0c;它们每个都需要一个node_modules&#xff0c;拷贝起来超级麻烦。于是想到能否共享一个node_modules呢&#xff1f;&#xff1f; 方法其实挺多&#xff0c;我选择了一个较简单的&#xff1a;符号连接法(win11平台) 创建方法很简单&#xff1a;比…

C语言-10.字符串

10.1字符串 10.1-1字符串 字符数组 char word[] = {‘H’,‘e’,‘l’,‘l’,‘o’,‘!’}; word[0]Hword[1]eword[2]lword[3]lword[4]oword[5]!这不是C语言的字符串,因为不能用字符串的方式做计算 字符串 char word[] = {‘H’,‘e’,‘l’,‘l’,‘o’,‘!’}; word[0]Hwo…

Python训练营打卡Day41(2025.5.31)

知识回顾 数据增强卷积神经网络定义的写法batch归一化&#xff1a;调整一个批次的分布&#xff0c;常用与图像数据特征图&#xff1a;只有卷积操作输出的才叫特征图调度器&#xff1a;直接修改基础学习率 卷积操作常见流程如下&#xff1a; 1. 输入 → 卷积层 → Batch归一化层…

乐观锁:高效并发无锁方案

4.乐观锁 这一章主要介绍乐观锁。前面的管程部分讲了悲观锁&#xff0c;现在做一些总结&#xff1a; 悲观锁&#xff08;Pessimistic Lock&#xff09;&#xff1a;悲观锁认为数据在多线程或多进程环境下总是容易发生冲突/冲突的概率高&#xff0c;所以在数据操作前&#xff…

山海鲸轻 3D 渲染技术深度解析:预渲染如何突破多终端性能瓶颈

在前期课程中&#xff0c;我们已系统讲解了山海鲸两大核心渲染模式——云渲染与端渲染的技术特性及配置方法。为满足复杂场景下的差异化需求&#xff0c;山海鲸创新推出轻3D渲染功能&#xff0c;本文将深度解析该技术的实现原理与操作实践。 一、轻3D功能研发背景 针对多终端协…

【合集】Linux——31个普通信号

Linux普通信号总表&#xff08;1-31&#xff09;​​ ​编号​​信号名​​触发原因​​默认动作​1SIGHUP终端连接断开&#xff08;如SSH会话终止&#xff09;或守护进程重载配置&#xff08;如nginx -s reload&#xff09;终止进程2SIGINT用户输入CtrlC中断前台进程终止进程…

小程序使用npm包的方法

有用的链接 npm init -y 这个命令很重要, 会初始化 package.json 再重新打开微信小程序开发工具 选择工具中npm构建 在程序中引用时在main.js中直接使用包名的方式引用即可 如安装的是generator包&#xff0c;npm构建后就会生成 const myPackage require(***-generato…