您的位置:首页 >如何通过Ubuntu JS日志排查性能问题
发布于2026-05-02 阅读(0)
扫一扫,手机访问

排查性能问题,第一步不是盲目猜测,而是建立清晰的观测体系。这就像医生看病,先得有检查报告。对于运行在Ubuntu上的Ja vaScript应用,日志就是最核心的“体检报告”。
console.log。在Node.js中,使用Winston、Bunyan或Log4js这类库输出JSON格式的日志,并区分info、warn、error等级别。关键在于,为每条日志注入关键维度信息,比如:请求路由(route)、HTTP方法(method)、状态码(statusCode)、耗时(durationMs)、用户ID(userId)以及链路追踪ID(traceId)。这能让后续分析事半功倍。
console.time/console.timeEnd或更精确的process.hrtime来记录关键业务路径的耗时。process.memoryUsage()的内存数据,以及下文会提到的事件循环延迟(event loop lag),从资源视角补充信息。journalctl -u your-service-name来跟踪你的服务进程日志。必要时,查看/var/log/syslog和dmesg,这里可能藏着内核或系统级别的异常线索。pm2 monit命令可以同时看到实时日志和CPU/内存消耗,非常方便。对于更复杂的生产环境,可以考虑接入New Relic、Datadog,或者自建ELK、Graylog栈,实现日志的聚合、检索和智能告警。有了高质量的日志,接下来就是“破案”时间。我们需要从海量日志中,快速定位出性能的“病灶”。
tail -f app.log | grep ‘durationMs’ | awk ‘{sum+=$NF; n++;} END {print “a vg=” sum/n}’… | sort -kNFnr | headtraceId还原完整的调用链,看看是不是某个下游服务故障,引发了连锁反应。upstream_response_time、db_query_time、cache_hit这样的字段,能快速定位是数据库查询慢、缓存未命中,还是第三方API响应延迟。rss(常驻内存集)和heapUsed(堆使用量)随时间的增长趋势。如果发现它们只增不减,即使在请求低谷期也不回落,那就要高度警惕内存泄漏了。优先排查全局变量、未清理的闭包引用、或者忘记清除的定时器。netstat、ss或lsof命令,检查是否存在大量的TIME_WAIT或CLOSE_WAIT连接堆积。对于前端或网络侧问题,使用curl、wget或浏览器DevTools的Network面板,查看TTFB(首字节时间)、传输大小和请求失败率。日志提供了线索,但要确诊,还需要借助更专业的“仪器”进行深度检查。
top、htop、atop实时观察CPU和内存使用情况。用iostat、vmstat、free来排查I/O和内存压力。如果问题极其棘手,perf和strace这样的系统级剖析工具可以帮助定位到具体的系统调用和热点代码路径。node --inspect或--inspect-brk启动应用,然后通过Chrome DevTools连接,进行CPU和内存采样,生成火焰图,直观看到时间都花在了哪里。node --prof生成V8性能分析日志,再用node --prof-process处理,可以识别出热点函数和脚本。EXPLAIN命令分析其执行计划,看是否缺少索引、进行了全表扫描,然后针对性添加索引或优化查询语句。理论讲完,是时候上“干货”了。这里提供一套可以直接复制使用的方案和命令。
npm i winstonconst winston = require(‘winston’);
const { createHash } = require(‘crypto’);
const logger = winston.createLogger({
level: ‘info’,
format: winston.format.combine(
winston.format.timestamp(),
winston.format.json()
),
transports: [new winston.transports.File({ filename: ‘combined.log’ })]
});
function withTiming(fn, label) {
return async (…args) => {
const start = process.hrtime.bigint();
const result = await fn(…args);
const end = process.hrtime.bigint();
const durationMs = Number(end - start) / 1e6;
logger.info({ event: ‘timing’, label, durationMs });
return result;
};
}
// 事件循环延迟(粗略)
let last = Date.now();
setInterval(() => {
const lag = Date.now() - last - 1000;
if (lag > 50) logger.warn({ event: ‘event_loop_lag’, lagMs: lag });
last = Date.now();
}, 1000).unref();
tail -f app.log | grep --color ‘durationMs|statusCode’… | sort -kNFnr | head… | awk ‘$NF ~ /5[0-9]{2}/ {err++; total++} END {print “errRate=” err/total}’ss -tan | awk ‘{print $1}’ | sort | uniq -ctop/htop;iostat -x 1;vmstat 1;free -mnode --inspect app.js 与 chrome://inspect;node --prof app.js && node --prof-process isolate-*.log/var/log/myapp/*.log {
daily;
rotate 7;
missingok;
notifempty;
compress;
delaycompress;
sharedscripts;
postrotate
killall -USR1 node || true;
endscript
}
winston-daily-rotate-file这类传输器,实现按天自动切分日志文件。最后,为了方便快速对照排查,将常见问题整理成下表,你可以按图索骥:
durationMs数值高,特定路由日志集中。netstat检查连接状态正常。event_loop_lag持续偏大。top命令显示单核CPU打满;浏览器DevTools发现长任务。heapUsed/rss指标单调递增,GC后不回落。heapdump生成堆快照,在Chrome DevTools的Memory面板中对比分析,观察特定对象数量是否持续增长。db_query_time字段数值高。EXPLAIN分析SQL,结果显示全表扫描。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9