首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Winston没有将日志写入文件

Winston没有将日志写入文件
EN

Stack Overflow用户
提问于 2017-10-10 11:06:54
回答 2查看 10.2K关注 0票数 4

我在Winston中为错误和警告做了两次传输,据说是写入文件。控制台日志记录的现有传输运行良好,我确实检查了pm2 logs并查看了日志,但文件传输没有保存任何内容。

代码语言:javascript
复制
'use strict';

const winston = require('winston');
const m = require('moment-timezone');
let logger = null;
/**
 * Initializes the logger
 * @param {object} configLogging
 */
module.exports.initialize = function initialize(configLogging) {
  const dateFormat = 'dddd, MMMM Do YYYY, h:mm:ss a';

  logger = new winston.Logger({
    transports: [
      new (winston.transports.Console)({
        name: 'info-console',
        level: configLogging.level,
        colorize: true,
        timestamp: function() { return m.utc().format(dateFormat); }
      }),
      new (winston.transports.File)({
        name: 'warning-file',
        filename: 'warning-file.log',
        level: 'warning'
      }),
      new (winston.transports.File)({
        name: 'error-file',
        filename: 'error-file.log',
        level: 'error'
      })
    ]
  });

  logger.info('Starting logging service');
};

/**
 * Gets the logger instance
 * @returns {LoggerInstance} winLogger
 */
module.exports.get = function get() {
  return logger;
};
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-10-10 12:27:43

请创建一个log.js文件并编写所有代码

代码语言:javascript
复制
var winston = require('winston');
const env = process.env.NODE_ENV;
const logDir = 'logs';
const fs = require('fs');

if (!fs.existsSync(logDir)) {
  fs.mkdirSync(logDir);
 }

const now = new Date();
var logger = new(winston.Logger)({
transports: [

    new winston.transports.File({
        name: 'error-file',
        filename: './logs/exceptions.log',
        level: 'error',
        json: false
    }),

    new(require('winston-daily-rotate-file'))({
        filename: `${logDir}/-apimodules.log`,
        timestamp: now,
        datePattern: 'dd-MM-yyyy',
        prepend: true,
        json: false,
        level: env === 'development' ? 'verbose' : 'info'
    })
],
exitOnError: false
});

module.exports = logger;
module.exports.stream = {
  write: function(message, encoding) {
    logger.info(message);
    console.log('message=', message);
  }
};

对于add log,在需要使用以下代码进行日志记录的任何地方都可以使用此文件

代码语言:javascript
复制
var logger = require('./path of/log.js');
logger.info('*** Requested for First log... ***');
票数 5
EN

Stack Overflow用户

发布于 2020-05-10 00:05:54

对于现代化,这里是上述答案的工作代码,因为上述答案不适用于最新版本的winston 3.2.1。这是文件log.js的工作代码

代码语言:javascript
复制
const fs = require('fs');

var winston = require('winston');

const env = process.env.NODE_ENV;
const logDir = 'logs';

if (!fs.existsSync(logDir)) {
  fs.mkdirSync(logDir);
}

const now = new Date();
var logger = winston.createLogger({
  transports: [
    new winston.transports.File({
      name: 'error-file',
      filename: './logs/exceptions.log',
      level: 'error',
      json: false,
    }),

    new (require('winston-daily-rotate-file'))({
      filename: `${logDir}/-apimodules.log`,
      timestamp: now,
      datePattern: 'dd-MM-yyyy',
      prepend: true,
      json: false,
      level: env === 'development' ? 'verbose' : 'info',
    }),
  ],
  exitOnError: false,
});

module.exports = logger;

module.exports.stream = {
  write: function (message) {
    logger.info(message);
    console.log('message = ', message);
  },
};

请注意,这会将数据输出到名为logs的根文件夹中。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46658040

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档