Node.js 模块之 morgan中间件记录日志

NodeJs中Express框架使用morgan中间件记录日志

Express中的app.js文件已经默认引入了该中间件var logger = require(‘morgan‘);

使用app.use(logger(‘dev‘));可以将请求信息打印在控制台,便于开发调试,但实际生产环境中,需要将日志记录在log文件里,可以使用如下代码

    var express = require(‘express‘);
    var fs = require(‘fs‘);
    var logger = require(‘morgan‘);  

    var app = express();  

    var accessLog = fs.createWriteStream(‘../access.log‘, {flags : ‘a‘});
    var errorLog = fs.createWriteStream(‘../error.log‘, {flags : ‘a‘});  

    app.use(logger(‘dev‘));     //打印到控制台
    app.use(logger(‘combined‘, {stream : accessLog}));      //打印到log日志  

这样便可以将请求信息打印在根目录下的access.log文件中(注意文件路径别填错,并不会自动创建该文件)

示例:

express/connect

Simple app that will log all request in the Apache combined format to STDOUTq

Log出所有Apache请求(结合STTDOUT格式)

var express = require(‘express‘)
var morgan = require(‘morgan‘)

var app = express()

app.use(morgan(‘combined‘))

app.get(‘/‘, function (req, res) {
  res.send(‘hello, world!‘)
})

vanilla http server

Simple app that will log all request in the Apache combined format to STDOUT

var finalhandler = require(‘finalhandler‘)
var http = require(‘http‘)
var morgan = require(‘morgan‘)

// create "middleware"
var logger = morgan(‘combined‘)

http.createServer(function (req, res) {
  var done = finalhandler(req, res)
  logger(req, res, function (err) {
    if (err) return done(err)

    // respond to request
    res.setHeader(‘content-type‘, ‘text/plain‘)
    res.end(‘hello, world!‘)
  })
})

write logs to a file

single file

Simple app that will log all requests in the Apache combined format to the file access.log.

Log列出所有Apache请求到access.log中

var express = require(‘express‘)
var fs = require(‘fs‘)
var morgan = require(‘morgan‘)
var path = require(‘path‘)

var app = express()

// create a write stream (in append mode)
var accessLogStream = fs.createWriteStream(path.join(__dirname, ‘access.log‘), {flags: ‘a‘})

// setup the logger
app.use(morgan(‘combined‘, {stream: accessLogStream}))

app.get(‘/‘, function (req, res) {
  res.send(‘hello, world!‘)
})

log file rotation

Simple app that will log all requests in the Apache combined format to one log file per day in the log/ directory using the rotating-file-stream module.

每天将所有Apache请求记录到log中

var express = require(‘express‘)
var fs = require(‘fs‘)
var morgan = require(‘morgan‘)
var path = require(‘path‘)
var rfs = require(‘rotating-file-stream‘)

var app = express()
var logDirectory = path.join(__dirname, ‘log‘)

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

// create a rotating write stream
var accessLogStream = rfs(‘access.log‘, {
  interval: ‘1d‘, // rotate daily
  path: logDirectory
})

// setup the logger
app.use(morgan(‘combined‘, {stream: accessLogStream}))

app.get(‘/‘, function (req, res) {
  res.send(‘hello, world!‘)
})

split / dual logging

The morgan middleware can be used as many times as needed, enabling combinations like:

  • Log entry on request and one on response
  • Log all requests to file, but errors to console
  • ... and more!

Sample app that will log all requests to a file using Apache format, but error responses are logged to the console:

Log所有Apache请求,错误Log到console中

var express = require(‘express‘)
var fs = require(‘fs‘)
var morgan = require(‘morgan‘)
var path = require(‘path‘)

var app = express()

// log only 4xx and 5xx responses to console
app.use(morgan(‘dev‘, {
  skip: function (req, res) { return res.statusCode < 400 }
}))

// log all requests to access.log
app.use(morgan(‘common‘, {
  stream: fs.createWriteStream(path.join(__dirname, ‘access.log‘), {flags: ‘a‘})
}))

app.get(‘/‘, function (req, res) {
  res.send(‘hello, world!‘)
})

use custom token formats

Sample app that will use custom token formats. This adds an ID to all requests and displays it using the :id token.

ID Token格式

var express = require(‘express‘)
var morgan = require(‘morgan‘)
var uuid = require(‘node-uuid‘)

morgan.token(‘id‘, function getId (req) {
  return req.id
})

var app = express()

app.use(assignId)
app.use(morgan(‘:id :method :url :response-time‘))

app.get(‘/‘, function (req, res) {
  res.send(‘hello, world!‘)
})

function assignId (req, res, next) {
  req.id = uuid.v4()
  next()
}
时间: 2024-10-14 04:37:02

Node.js 模块之 morgan中间件记录日志的相关文章

Node.js模块封装及使用

Node.js中也有一些功能的封装,类似C#的类库,封装成模块这样方便使用,安装之后用require()就能引入调用. 一.Node.js模块封装 1.创建一个名为censorify的文件夹 2.在censorify下创建3个文件censortext.js.package.json.README.md文件 1).在censortext.js下输入一个过滤特定单词并用星号代替的函数. var censoredWorlds=["sad","bad","mad&

Node.js 模块和 NPM

1.模块概念 原生模块:Node.js API 提供的原生模块,原生模块在启动时已经被加载. 文件模块:动态加载模块,由原生模块 module 来实现和完成. 文件模块需要通过调用 require 方法来实现加载. Node.js 对两种模块都有缓存,不会重复开销去加载模块,只读取相应数据. 原生模块的调用 Node.js 的 API require 加载相应的 Node.js 模块,加载成功后返回一个 Node.js 模块对象. 该对象拥有该模块的所有方法和属性. var httpModule

如何发布一个自定义Node.js模块到NPM(详细步骤)

咱们闲话不多说,直接开始! 由于我从没有使用过MAC,所以我不保证本文中介绍的操作与MAC一致. 文章开始我先假定各位已经在window全局安装了Node.js,下面开始进行详细步骤介绍: 本文本着,以极少的文字说明以及极少的代码书写为原则来给大家演示! 文章中上传的模块不具备任何意义! 一.封装node.js模块时的必须项 1.创建package.json 每一个完整封装的node模块,必须含有一个参数明确的package.json文件! 以下为package.json的最精简配置: { "n

node js 模块系统

Node.js模块系统 为了让Node.js的文件可以相互调用,Node.js提供了一个简单的模块系统. 模块是Node.js 应用程序的基本组成部分,文件和模块是一一对应的.换言之,一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码.JSON 或者编译过的C/C++ 扩展. 创建模块 在 Node.js 中,创建一个模块非常简单,如下我们创建一个 'hello.js' 文件,代码如下: var hello = require('./hello'); hello.w

3:Node.js模块系统

原文出自:http://www.w3cschool.cc/nodejs/nodejs-module-system.html Node.js模块系统 为了让Node.js的文件可以相互调用,Node.js提供了一个简单的模块系统. 模块是Node.js 应用程序的基本组成部分,文件和模块是一一对应的.换言之,一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码.JSON 或者编译过的C/C++ 扩展. 创建模块 在 Node.js 中,创建一个模块非常简单,如下我们创建

Developer - 如何自我保证Node.js模块质量

组里正在做SaaS产品,其中一些模块(Module)是Node.js实现,这里我们主要使用Node.js实现Web Server来提供服务. 在做SaaS项目之前,组里的开发模式是传统的Deverloper + QA的模式,这是传统的协作模式,Developer负责写代码开发,当然也会有基本的自测,QA负责测试,遇到问题,提Bug给Developer去修复,Developer修复Bug后,由QA来验证并记录Bug.但这样的协作模式已不适合SaaS产品的开发,SaaS产品更新迭代快,模块众多,这就

本地安装node.js模块

一.需求 单位电脑不让上网,但是需要用到一个node.js模块,elasticdump. 二.解决 1.自己电脑上下载模块: npm install elasticdump -g 注意:必须要加 -g,因为需要全局使用.非全局的模块复制到电脑上,还没找的方法运行模块. 2.复制拷贝 a.复制 操作1步骤会默认下载到C:\Users\T470s\AppData\Roaming\npm\node_modules\elasticdump ,复制elasticdump文件夹到U盘, 再到C:\Users

Node.js 模块机制及常见面试问题解答

Node.js 模块机制采用了 Commonjs 规范,弥补了当前 JavaScript 开发大型应用没有标准的缺陷,类似于 Java 中的类文件,Python 中的 import 机制,Node.js 中可以通过 module.exports.require 来导出和引入一个模块. 在模块加载机制中,Node.js 采用了延迟加载的策略,只有在用到的情况下,系统模块才会被加载,加载完成后会放到 binding_cache 中. 面试指南 require的加载机制?,参考:模块加载机制 modu

node.js模块之fs文件系统

fs 模块是文件操作的封装,它提供了文件的读取.写入.更名.删除.遍历目录.链接等 POSIX 文件系统操作.与其他模块不同的是,fs 模块中所有的操作都提供了异步的和同步的两个版本, 例如读取文件内容的函数有异步的 fs.readFile() 和同步的fs.readFileSync().我们以几个函数为代表,介绍 fs 常用的功能,并列出 fs 所有函数的定义和功能. fs.readFile(filename,[encoding],[callback(err,data)])是最简单的读取文件的