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

相关推荐
C澒13 小时前
前端技术核心领域与实践方向
前端·系统架构
写代码的【黑咖啡】14 小时前
Python 中的自然语言处理利器:NLTK
前端·javascript·easyui
Swift社区14 小时前
Nginx 反向代理配置 React 前端与 Python 后端
前端·nginx·react.js
可问春风_ren14 小时前
Vue3 入门详解:从基础到实战
开发语言·前端·javascript·vue.js·前端框架·ecmascript·edge浏览器
一起养小猫14 小时前
Flutter for OpenHarmony 实战:从零开发一款五子棋游戏
android·前端·javascript·flutter·游戏·harmonyos
晚霞的不甘14 小时前
Flutter for OpenHarmony全面升级「今日运势」 应用的视觉与交互革新
前端·学习·flutter·前端框架·交互
学嵌入式的小杨同学14 小时前
【Linux 封神之路】文件操作 + 时间编程实战:从缓冲区到时间格式化全解析
linux·c语言·开发语言·前端·数据库·算法·ux
RFCEO14 小时前
学习前端编程:精准选中 HTML 元素的技巧与方法
前端·学习·css类选择器·兄弟元素选中·父子选中·关系选中·选择器选中
想睡好14 小时前
ref和reactive
前端·javascript·vue.js
霁月的小屋14 小时前
React 闭包陷阱深度解析
前端·javascript·react.js