您的位置:首页 >如何通过Ubuntu日志排查Node.js错误
发布于2026-04-28 阅读(0)
扫一扫,手机访问

面对一个突然“罢工”的Node.js应用,一头扎进代码里debug往往事倍功半。更聪明的做法,是先去听听日志在“说”什么。一套清晰的排查思路,能帮你快速定位问题核心。
node命令运行的,还是由PM2管理的,又或是配置成了systemd服务?不同的运行方式,查看日志的命令也完全不同。知道了要看什么,接下来就是知道去哪看。日志通常藏在以下几个地方:
logs/文件夹,或者系统级的/var/log/yourapp/目录。文件名通常是app.log、error.log、combined.log这类。当然,如果代码或配置文件里显式指定了路径,那就要以配置为准。~/.pm2/logs/目录下。你会看到类似app-name-out.log和app-name-error.log的文件。直接用pm2 logs命令可以统一查看所有托管应用的日志流,非常方便。journalctl -u your-node-service来查看。如果配置了写入传统的syslog,则需要去查看/var/log/syslog文件。工具用得好,排查没烦恼。下面这些命令组合,能应对大多数日志查看场景:
tail -f logs/app.log 或 tail -f logs/error.log。这个“-f”参数是关键,它能让你像看直播一样盯着日志输出。grep -i “error” logs/error.log。用-i忽略大小写,快速揪出所有错误。结合正则表达式,还能进一步过滤出特定模块或特定模式的错误堆栈。sudo tail -f /var/log/syslog。如果是journald管理的服务,则用sudo journalctl -u your-node-service -f来跟踪特定服务。pm2 logs;只看某个应用:pm2 logs ;查看最近N行历史:pm2 logs --lines 1000。journalctl -u your-node-service --since “10 minutes ago”。这个命令在排查刚刚发生的问题时极其有用,能过滤掉无关的历史信息。有些错误像常客,总会时不时出现。记住它们的“样貌”和“解法”,能省下大量时间:
sudo lsof -i :端口号找到是哪个进程占用了端口,记下它的PID,然后用sudo kill -9 结束它。当然,更优雅的方式是确认该进程是否真的可以停止。npm install <模块名>来安装它。如果频繁出现,检查一下package.json和node_modules是否同步。.catch()处理,或者在async函数中使用try-catch。临时兜底的话,可以监听process.on(‘unhandledRejection’)事件,避免进程直接崩溃。myEmitter.setMaxListeners(20)临时提高限制,但根本解决之道还是记得用removeListener进行清理。node --max-old-space-size=4096 app.js。但这只是权宜之计。长期来看,必须使用像clinic、heapdump这样的工具分析内存泄漏点,优化数据结构和缓存策略才是根本。排查问题是被动反应,构建良好的可观测性则是主动防御。以下几个实践能让你的应用更“透明”:
console.log。推荐使用winston、log4js等专业库,并配置好按文件大小或时间进行滚动归档的策略,同时设定合理的日志保留天数。pm2 logs输出和日志文件双轨留存的方式,互为备份。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9