express中间件--Morgan 日志记录

Morgan是一个node.js关于http请求的日志中间件

安装模块

npm install morgan --save #保存到package.json的依赖列表
1
使用方法

在终端打印日志
...
var logger = require('morgan');
...
app.use(logger('dev'));
...
1
2
3
4
5
每次http请求,express实例都会输出日志,并且使用一致的格式

GET / 200 338.136 ms - 170
POST / 404 60.506 ms - 1225
GET /users 200 2.432 ms - 23
POST /users 404 43.958 ms - 1225
1
2
3
4
将日志写入文件
var express = require('express');
var logger = require('morgan');//日志模块
var fs = require('fs');//文件模块

var app = express();
var accessLogStream = fs.createWriteStream(__dirname+'/access.log',{flags:'a'});//创建一个写入流
app.use(logger('combined',{stream:accessLogStream}));//将日志写入文件
app.get('/',function(req,res){
res.send('hello world');
})


app.listen(3000);
1
2
3
4
5
6
7
8
9
10
11
12
13
一天一个日志文件
var express=require('express');
var logger=require('morgan');
var fs=require('fs');
var FileStreamRotator = require('file-stream-rotator');

var app=new express();

//设置日志文件目录
var logDirectory=__dirname+'/logs';
//确保日志文件目录存在 没有则创建
fs.existsSync(logDirectory)||fs.mkdirSync(logDirectory);

//创建一个写路由
var accessLogStream=FileStreamRotator.getStream({
filename:logDirectory+'/accss-%DATE%.log',
frequency:'daily',
verbose:false
})

app.use(logger('combined',{stream:accessLogStream}));//写入日志文件

app.get('/',function(req,res){
res.send('hello world');
});

app.listen(3000);
---------------------
作者:no-96
来源:CSDN
原文:https://blog.csdn.net/qq_14998713/article/details/62416901
版权声明:本文为博主原创文章,转载请附上博文链接!

posted @   孙首富  阅读(3817)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示