NodeJS全栈开发面试题讲解——P9性能优化(Node.js 高级)

news2025/6/5 9:37:08

✅ 9.1 Node.js 的性能瓶颈一般出在哪?如何排查?

Node.js 单线程 + 异步模型,瓶颈常出现在:

  • 阻塞操作(如:同步 I/O、CPU 密集型计算)

  • 数据库慢查询 / 索引失效

  • 外部接口慢响应

  • 大量并发请求导致内存泄漏、事件堆积

🔍 排查工具

工具/命令用途
Chrome DevTools分析 V8 的 CPU/内存使用
clinic / 0x分析 event loop 阻塞点
pm2 monit监控 Node 应用性能(内存/CPU)
APM 工具(如SkyWalking)服务调用链追踪


✅ 9.2 如何避免主线程阻塞?哪些操作容易阻塞线程?

Node.js 的主线程负责处理事件循环,一旦被阻塞,所有请求都会卡住。

🚫 易阻塞的操作:

  • 文件同步 I/O(如 fs.readFileSync

  • 压缩/加密计算

  • 图片处理(如 sharp)

  • JSON 大对象解析

  • 无限循环 / 大型 for 循环

✅ 避免方案:

  • 异步处理(如 fs.promises

  • 使用 worker_threads 或子进程处理 CPU 密集型任务

  • 使用消息队列进行任务拆分

  • 限流、分批、延迟处理(如 setImmediate)


✅ 9.3 说说你对 Stream 的理解,什么时候用它来提升性能?

Stream 是 Node.js 的核心模块,适用于处理大文件或连续数据流,可极大降低内存占用。

🧠 Stream 四种类型:

  • Readable(可读流)→ 如 fs.createReadStream()

  • Writable(可写流)→ 如 fs.createWriteStream()

  • Duplex(双工流)

  • Transform(转换流)

📌 用法场景:

  • 文件上传/下载

  • 视频转码

  • 日志写入

  • 大 JSON 文件处理

fs.createReadStream('input.txt')
  .pipe(transform)
  .pipe(fs.createWriteStream('output.txt'));

✅ 9.4 如何用 cluster 或 worker_threads 实现多核并发?

Node.js 是单线程,但服务器有多核,我们可以利用 cluster 或 worker_threads 实现并发处理。

🔧 cluster 模块(常用于 HTTP 服务多进程)

if (cluster.isMaster) {
  for (let i = 0; i < os.cpus().length; i++) cluster.fork();
} else {
  app.listen(3000);
}

缺点:内存独立、无法共享数据


🔧 worker_threads(适合 CPU 密集型计算)

new Worker('./heavy-task.js', { workerData: { n: 100000 } });

适合拆分密码加密、图像处理、复杂循环等任务


✅ 9.5 如何对接口进行性能监控和报警?用过什么工具?

✅ 方法:

  • 接口响应时间统计(可打 log / 中间件埋点)

  • 异常监控(如 5xx 报错、耗时超过阈值)

  • 服务健康监控(/healthz)

  • 报警机制(钉钉机器人/飞书 webhook)

🧰 工具:

类型工具名
日志监控Winston、Pino + ELK
性能/APMSkyWalking、Jaeger、Zipkin
监控平台Prometheus + Grafana
告警集成Sentry / OpenTelemetry


✅ 9.6 如何做数据库性能优化?举几个具体手段。

✅ 优化点:

  1. 建索引

    • WHERE, JOIN, ORDER BY 常用字段建索引

    • 覆盖索引,避免回表

  2. 慢查询优化

    • 分析执行计划 EXPLAIN

    • 拆分大查询(LIMIT 分页 + 子查询)

  3. 缓存热点数据

    • 查询 Redis 缓存,命中即返回

  4. 字段优化

    • 避免 SELECT *,控制字段数量

    • 精简 JSON 类型字段


✅ 9.7 静态资源 / CDN 如何优化访问性能?

✅ 优化手段:

  • 静态资源部署到 CDN 节点(如:Cloudflare、阿里 CDN)

  • 利用 HTTP 缓存:

    • Cache-Control: max-age

    • ETag / Last-Modified

  • 图片压缩(WebP)、字体子集化

  • 按需加载 + 懒加载


✅ 9.8 如何实现缓存机制?本地缓存 vs Redis 缓存?

类型优点缺点
本地缓存(Map/LRU)快速、0延迟多进程不共享、易失效
Redis 缓存跨服务共享、高容量需要维护 Redis 服务、网络延迟

🧩 典型使用场景:

  • 本地缓存:接口幂等性缓存(短时)、配置缓存

  • Redis 缓存:用户数据缓存、热门文章、排行榜等

const val = await redis.get(`post:${id}`);
if (val) return JSON.parse(val);

✅ 9.9 如何处理高并发下的“缓存击穿 / 雪崩 / 穿透”?

类型说明解决方案
缓存穿透请求的 key 在缓存和数据库都不存在(如 user:-1)设置空值缓存 / 使用布隆过滤器
缓存击穿某个热点 key 突然过期,瞬间大量请求打到 DB加锁(互斥锁)+ 预加载
缓存雪崩大量缓存同时过期随机过期时间 / 分批加载 / 限流


✅ 9.10 前后端性能联调你做过哪些?前端也会影响响应时间吗?

是的,前端性能直接影响首屏加载时间、交互速度等用户体验。

✅ 联调优化经验:

  • 用 Chrome DevTools + Network 面板分析接口时间

  • 后端压缩响应(gzip)

  • 减少接口数量(合并请求)

  • 异步加载不影响首屏的数据

  • 数据分页 / 虚拟滚动

✅ 前端常见性能问题:

  • 不必要的 re-render(React)

  • Vue 的 computed 缓存未用好

  • 图表 / 表格渲染数据量过大

  • 图片未压缩、未懒加载


✅ 总结一图

编号关键点涉及知识
9.1性能瓶颈排查Chrome DevTools / APM
9.2主线程阻塞来源文件同步、CPU 任务、JSON大对象等
9.3Stream 用法文件处理、内存控制
9.4多核并发方案cluster + worker_threads
9.5接口监控与报警Prometheus、Grafana、Sentry
9.6数据库优化索引、分页、缓存
9.7静态资源优化CDN、缓存、压缩
9.8缓存策略本地缓存 vs Redis
9.9缓存三难问题击穿、雪崩、穿透
9.10前后端性能联调接口压缩、延迟分析、懒加载等

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

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

相关文章

基于FPGA的DES加解密系统verilog实现,包含testbench和开发板硬件测试

目录 1.课题概述 2.系统测试效果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于FPGA的DES加解密系统verilog实现,包含testbench和开发板硬件测试。输入待加密数据&#xff0c;密钥&#xff0c;输出加密数据&#xff0c;然后通过解密模块输出解密后的原…

Python----目标检测(《用于精确目标检测和语义分割的丰富特征层次结构》和R-CNN)

一、《用于精确目标检测和语义分割的丰富特征层次结构》 1.1、基本信息 原文标题&#xff1a;Rich feature hierarchies for accurate object detection and semantic segmentation 中文译名&#xff1a;用于精确目标检测与语义分割的丰富特征层次结构 版本&#xff1a;第5版技…

极简以太彩光网络解决方案4.0正式发布,“彩光”重构园区网络极简之道

5月28日下午,锐捷网络在京举办以“光,本该如此‘简单’”为主题的发布会,正式发布极简以太彩光网络解决方案4.0。作为“彩光”方案的全新进化版本,极简以太彩光4.0从用户需求出发,聚焦场景洞察,开启了一场从底层基因出发的极简革命,通过架构、部署、运维等多维度的创新升级,以强…

国芯思辰| 霍尔电流传感器AH811为蓄电池负载检测系统安全护航

在电动车、储能电站、不间断电源&#xff08;UPS&#xff09;等设备中&#xff0c;蓄电池作为关键的储能单元&#xff0c;其运行状态直接关系到设备的稳定性和使用寿命。而准确监测蓄电池的负载情况&#xff0c;是保障其安全、高效运行的关键。霍尔电流传感器 AH811凭借独特的技…

TortoiseSVN账号切换

SVN登录配置及账号切换 本文主要为了解答svn客户端如何进行账号登录及切换不同权限账号的方式。 一、环境准备与客户端安装 安装TortoiseSVN客户端 ​​下载地址​​&#xff1a;TortoiseSVN官网 ​​安装步骤​​&#xff1a; 双击安装包&#xff0c;按向导完成安装后&#x…

2025年05月28日Github流行趋势

项目名称&#xff1a;agenticSeek 项目地址url&#xff1a;https://github.com/Fosowl/agenticSeek项目语言&#xff1a;Python历史star数&#xff1a;10352今日star数&#xff1a;2444项目维护者&#xff1a;Fosowl, steveh8758, klimentij, ganeshnikhil, apps/copilot-pull-…

篇章五 数据结构——链表(一)

目录 1.ArrayList的缺陷 2. 链表 2.1 链表的概念及结构 2.2 链表结构 1. 单向或者双向 2.带头或者不带头 3.循环或者非循环 2.3 链表的实现 1.完整代码 2.图解 3.显示方法 4.链表大小 5. 链表是否存在 key 值 6.头插法 7.尾插法 8.中间插入 9.删除key值节点 10.…

一文清晰理解目标检测指标计算

一、核心概念 1.交并比IoU 预测边界框与真实边界框区域的重叠比&#xff0c;取值范围为[0,1] 设预测边界框为&#xff0c;真实边界框为 公式&#xff1a; IoU计算为两个边界框交集面积与并集面积之比&#xff0c;图示如下 IoU值越高&#xff0c;表示预测边界框与真实边界框的对…

Artificial Analysis2025年Q1人工智能发展六大趋势总结

2025年第一季度人工智能发展六大趋势总结 ——基于《Artificial Analysis 2025年Q1人工智能报告》 趋势一&#xff1a;AI持续进步&#xff0c;竞争格局白热化 前沿模型竞争加剧&#xff1a;OpenAI凭借“o4-mini&#xff08;高智能版&#xff09;”保持领先&#xff0c;但谷歌&…

高效管理 Python 项目的 UV 工具指南

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 持续学习&#xff0c;不断…

初识vue3(vue简介,环境配置,setup语法糖)

一&#xff0c;前言 今天学习vue3 二&#xff0c;vue简介及如何创建vue工程 Vue 3 简介 Vue.js&#xff08;读音 /vjuː/&#xff0c;类似 “view”&#xff09;是一款流行的渐进式 JavaScript 框架&#xff0c;用于构建用户界面。Vue 3 是其第三代主要版本&#xff0c;于 …

LeetCode-链表操作题目

虚拟头指针&#xff0c;在当前head的前面建立一个虚拟头指针&#xff0c;然后哪怕当前的head的val等于提供的val也能进行统一操作 203移除链表元素简单题 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(…

【ARM】MDK浏览信息的生成对于构建时间的影响

1、 文档目标 用于了解MDK的代码浏览信息的生成对于工程的构建是否会产生影响。 2、 问题场景 客户在MDK中使用Compiler 5对于工程进行构建过程中发现&#xff0c;对于是否产生浏览信息会对于构建时间产生一定的影响。在Options中Output栏中勾选了Browse Information后&#…

py爬虫的话,selenium是不是能完全取代requests?

selenium适合动态网页抓取&#xff0c;因为它可以控制浏览器去点击、加载网页&#xff0c;requests则比较适合静态网页采集&#xff0c;它非常轻量化速度快&#xff0c;没有浏览器开销&#xff0c;占用资源少。当然如果不考虑资源占用和速度&#xff0c;selenium是可以替代requ…

docker B站学习

镜像是一个只读的模板&#xff0c;用来创建容器 容器是docker的运行实例&#xff0c;提供了独立可移植的环境 https://www.bilibili.com/video/BV11L411g7U1?spm_id_from333.788.videopod.episodes&vd_sourcee60c804914459274157197c4388a4d2f&p3 目录挂载 尚硅谷doc…

SpringBoot高校宿舍信息管理系统小程序

概述 基于SpringBoot的高校宿舍信息管理系统小程序项目&#xff0c;这是一款非常适合高校使用的信息化管理工具。该系统包含了完整的宿舍管理功能模块&#xff0c;采用主流技术栈开发&#xff0c;代码结构清晰&#xff0c;非常适合学习和二次开发。 主要内容 这个宿舍管理系…

ICASSP2025丨融合语音停顿信息与语言模型的阿尔兹海默病检测

阿尔兹海默病&#xff08;Alzheimers Disease, AD&#xff09;是一种以认知能力下降和记忆丧失为特征的渐进性神经退行性疾病&#xff0c;及早发现对于其干预和治疗至关重要。近期&#xff0c;清华大学语音与音频技术实验室&#xff08;SATLab&#xff09;提出了一种将停顿信息…

LabVIEW杂草识别与精准喷洒

基于LabVIEW构建了一套集成机器视觉、智能决策与精准控制的农业杂草识别系统。通过高分辨率视觉传感器采集作物图像&#xff0c;利用 LabVIEW 的 NI Vision 模块实现图像颜色匹配与特征分析&#xff0c;结合 Arduino 兼容的工业级控制硬件&#xff0c;实现杂草定位与除草剂精准…

学习日记-day20-6.1

完成目标&#xff1a; 知识点&#xff1a; 1.集合_Collections集合工具类 方法:static <T> boolean addAll(Collection<? super T> c, T... elements)->批量添加元素 static void shuffle(List<?> list) ->将集合中的元素顺序打乱static <T>…

【音视频】 FFmpeg 解码H265

一、概述 实现了使用FFmpeg读取对应H265文件&#xff0c;并且保存为对应的yuv文件 二、实现流程 读取文件 将H265/H264文件放在build路径下&#xff0c;然后指定输出为yuv格式 在main函数中读取外部参数 if (argc < 2){fprintf(stderr, "Usage: %s <input file&…