溫馨提示×

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

小樊
47
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)或類似工具,實現日志的集中存儲、分析和可視化。

存儲路徑參考

  • PM2管理:~/.pm2/logs/
  • 自定義路徑:通過代碼或庫配置(如logs/目錄)
  • 系統日志:/var/log/(需手動配置)

根據項目規模和需求選擇合適方案,生產環境建議結合日志庫+輪轉+集中管理。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女