阅读量:2
在Ubuntu中进行Node.js日志管理,可采用以下方式:
- 内置模块:使用
console.log()/console.error()输出日志到控制台,适合开发调试。 - 第三方日志库:
- Winston:支持文件、控制台、HTTP等传输,可配置日志级别、格式化(如JSON)及轮转。
- 安装:
npm install winston - 配置示例:
const winston = require('winston'); const DailyRotateFile = require('winston-daily-rotate-file'); const logger = winston.createLogger({ transports: [ new DailyRotateFile({ filename: 'logs/app-%DATE%.log', datePattern: 'YYYY-MM-DD', maxSize: '20m', maxFiles: '14d', zippedArchive: true }) ] });
- 安装:
- Pino:高性能,支持结构化JSON日志,适合生产环境。
- Winston:支持文件、控制台、HTTP等传输,可配置日志级别、格式化(如JSON)及轮转。
- 日志轮转:
- 工具轮转:使用系统
logrotate工具管理日志文件,配置路径为/etc/logrotate.d/nodejs,设置按天轮转、保留天数、压缩等。 - 库内置轮转:如Winston的
winston-daily-rotate-file插件,直接在代码中配置轮转策略。
- 工具轮转:使用系统
- 进程管理器集成:
- 使用PM2管理应用时,日志默认存储在
~/.pm2/logs/目录,支持自动轮转及远程日志查看。- 启动应用:
pm2 start app.js --name my-app - 查看日志:
pm2 logs my-app
- 启动应用:
- 使用PM2管理应用时,日志默认存储在
- 集中式日志管理:
- 集成ELK Stack(Elasticsearch+Logstash+Kibana)或类似工具,实现日志的集中存储、分析和可视化。
存储路径参考:
- PM2管理:
~/.pm2/logs/ - 自定义路径:通过代码或库配置(如
logs/目录) - 系统日志:
/var/log/(需手动配置)
根据项目规模和需求选择合适方案,生产环境建议结合日志库+轮转+集中管理。
以上就是关于“Ubuntu中Node.js如何进行日志管理”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm