Node Cpu 100% 问题分析解决

使用prof分析解决问题

准备

进入系统或者容器,关闭原有的服务,用node启动新的服务

遇到的其他问题自行搜索解决(端口重复、pm2退出)

启动项目

启动项目,生成一个刻度文件,isolate-0xnnnnnnnnnnnn-v8.log(其中n是数字)。

sql 复制代码
NODE_ENV=production  node --prof /data/srv/dist/main.js

processed.txt文件生成

通过对刻度文件isolate-0xnnnnnnnnnnnn-v8.log执行命令--prof-process生成 processed.txt

sql 复制代码
node --prof-process isolate-0x62b3c60-762-v8.log > processed.txt

processed.txt文件分析

分析修复processed.txt解决问题(看不懂查资料或者用 ai kimi、通义等进行分析)

比如这里,ticks total 最大的方法,问题就在这里,name 里面有方法名称和路径行数(注意是编译后的文件行数)

在Node.js 中,每次事件循环执行一次完整的过程,我们称之为tick

sql 复制代码
 [JavaScript]:
   ticks  total  nonlib   name
  151918   89.2%   99.9%  LazyCompile: *phpStrtr /data/srv/dist/common/utils/strUtil.js:41:18
     32    0.0%    0.0%  LazyCompile: *resolve node:path:1091:10

其他

结合代码位置,系统日志进行分析解决

sql 复制代码
export function errorCode(str: string, replacementsList: {replaceWord: string, replaceTo: string}[]) {
    const replacements: {[key: string]: string} = {};
    replacementsList.forEach((item) => {
    // 这里没有空判断,导致死循环
        if (item.replaceWord !== '') {
            replacements[item.replaceWord] = item.replaceTo;
        }
    });

    // 继续处理逻辑
}

资料

国行的这叫基础教程页面好看,内容简单,对新手有好

Node.js 简介

了解 process.nextTick()

Node.js --- Profiling Node.js Applications

Node.js --- Flame Graphs

相关推荐
Jonathan Star6 小时前
沉浸式雨天海岸:用A-Frame打造WebXR互动场景
前端·javascript
工业甲酰苯胺6 小时前
实现 json path 来评估函数式解析器的损耗
java·前端·json
老前端的功夫6 小时前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
LilySesy7 小时前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
Wang's Blog8 小时前
前端FAQ: Vue 3 与 Vue 2 相⽐有哪些重要的改进?
前端·javascript·vue.js
再希8 小时前
React+Tailwind CSS+Shadcn UI
前端·react.js·ui
用户47949283569158 小时前
JavaScript 的 NaN !== NaN 之谜:从 CPU 指令到 IEEE 754 标准的完整解密
前端·javascript
群联云防护小杜8 小时前
国产化环境下 Web 应用如何满足等保 2.0?从 Nginx 配置到 AI 防护实战
运维·前端·nginx
醉方休9 小时前
Web3.js 全面解析
前端·javascript·electron
前端开发爱好者9 小时前
前端新玩具:Vike 发布!
前端·javascript