温馨提示×

如何监控Ubuntu Node.js实时日志

小樊
69
2025-03-07 22:22:29
栏目: 编程语言

要监控Ubuntu上的Node.js实时日志,您可以使用多种工具和方法。以下是一些推荐的解决方案:

使用Log4js进行日志记录

  • 安装Log4js:首先,您需要安装Log4js库。可以通过npm进行安装:

    npm install log4js
    
  • 配置Log4js:接下来,配置Log4js以指定日志的输出位置和格式。例如,将日志输出到文件:

    const log4js = require('log4js');
    log4js.configure({
      appenders: { file: { type: 'file', filename: 'app.log' } },
      categories: { default: { appenders: ['file'], level: 'info' } }
    });
    const logger = log4js.getLogger();
    logger.info('This is an info message');
    

使用PM2进行日志监控

  • 安装PM2:PM2是一个进程管理器,可以提供进程监控、日志记录和自动重启等功能。安装PM2:

    npm install pm2 -g
    
  • 使用PM2查看日志:使用以下命令来查看Node.js应用程序的实时日志:

    pm2 logs
    

使用Winston进行日志记录

  • 安装Winston:Winston是一个流行的Node.js日志库,支持多种传输方式。安装Winston:

    npm install winston
    
  • 配置Winston:配置Winston以将日志输出到控制台和文件:

    const winston = require('winston');
    const logger = winston.createLogger({
      level: 'info',
      format: winston.format.json(),
      transports: [
        new winston.transports.Console(),
        new winston.transports.File({ filename: 'combined.log' })
      ]
    });
    logger.info('Hello World!');
    

使用Elasticsearch和Kibana进行集中式日志管理

  • 安装Elasticsearch和Kibana:这些工具可以帮助您集中存储、搜索和分析日志数据。安装Elasticsearch和Kibana:

    sudo aptget install elasticsearch kibana
    
  • 配置Winston发送日志到Elasticsearch:使用winston-elasticsearch库将Winston的日志发送到Elasticsearch:

    const { ElasticsearchTransport } = require('winston-elasticsearch');
    const elasticsearchTransport = new ElasticsearchTransport({
      clientOpts: { node: 'http://localhost:9200' }
    });
    const logger = winston.createLogger({
      transports: [
        new winston.transports.File({ filename: 'error.log', level: 'error' }),
        new winston.transports.File({ filename: 'combined.log' }),
        elasticsearchTransport
      ]
    });
    

通过上述方法,您可以有效地监控Ubuntu上的Node.js应用程序日志,确保应用程序的稳定运行和问题的快速排查。

0