0

Morgan を使用して Express Nodejs アプリケーションで実稼働ログ環境をセットアップしようとしています。

このドキュメントhttps://github.com/expressjs/morgan#write-logs-to-a-fileを使用して実行しようとしました

ロギングに関する私のコードは次のようになります。

var express = require('express');
var path = require('path');
var logger = require('morgan');
var FileStreamRotator = require('file-stream-rotator');
var fs = require('fs');
var app = express();

// logging
if (app.get('env') !== 'development') {
  var logDirectory = path.join('/srv/iss', 'log');

  // ensure log directory exists
  fs.existsSync(logDirectory) || fs.mkdirSync(logDirectory);

  var accessLogStream = FileStreamRotator.getStream({
    date_format: 'YYYYMMDD',
    filename: path.join(logDirectory, 'access-%DATE%.log'),
    frequency: 'daily',
    verbose: false
  });

  // setup the logger
  app.use(logger('combined', {stream: accessLogStream}))
}
else {
  app.use(logger('dev'));
}

アプリケーションを開発モードで起動するとすべて正常に動作しますが、本番モードではアクセス ログ ファイルが作成されますが、ログ メッセージはファイルに送信されません。

4

1 に答える 1