ubuntu

Ubuntu中Node.js如何进行日志管理

小樊
48
2025-08-19 20:06:20
栏目: 编程语言

在Ubuntu中进行Node.js日志管理,可采用以下方式:

  1. 内置模块:使用console.log()/console.error()输出日志到控制台,适合开发调试。
  2. 第三方日志库
    • 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日志,适合生产环境。
  3. 日志轮转
    • 工具轮转:使用系统logrotate工具管理日志文件,配置路径为/etc/logrotate.d/nodejs,设置按天轮转、保留天数、压缩等。
    • 库内置轮转:如Winston的winston-daily-rotate-file插件,直接在代码中配置轮转策略。
  4. 进程管理器集成
    • 使用PM2管理应用时,日志默认存储在~/.pm2/logs/目录,支持自动轮转及远程日志查看。
      • 启动应用:pm2 start app.js --name my-app
      • 查看日志:pm2 logs my-app
  5. 集中式日志管理
    • 集成ELK Stack(Elasticsearch+Logstash+Kibana)或类似工具,实现日志的集中存储、分析和可视化。

存储路径参考

根据项目规模和需求选择合适方案,生产环境建议结合日志库+轮转+集中管理。

0
看了该问题的人还看了