溫馨提示×

Node.js日志中請求處理時間

小樊
46
2025-06-18 19:16:26
欄目: 編程語言

在Node.js中,你可以使用中間件來記錄每個請求的處理時間。這里以Express框架為例,展示如何創建一個中間件來記錄請求處理時間:

首先,確保你已經安裝了Express:

npm install express

然后,創建一個名為app.js的文件,并添加以下代碼:

const express = require('express');
const app = express();

// 自定義中間件,用于記錄請求處理時間
app.use((req, res, next) => {
  const start = Date.now(); // 記錄請求開始時間

  // 監聽響應結束事件
  res.on('finish', () => {
    const duration = Date.now() - start; // 計算處理時間
    console.log(`${req.method} ${req.url} - ${duration}ms`); // 輸出請求方法、URL和處理時間
  });

  next(); // 繼續執行下一個中間件或路由處理程序
});

// 示例路由
app.get('/', (req, res) => {
  res.send('Hello World!');
});

// 啟動服務器
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
  console.log(`Server is running on port ${PORT}`);
});

現在運行app.js文件:

node app.js

當你訪問http://localhost:3000時,控制臺將顯示類似以下內容的輸出:

GET / - 12ms

這表示請求的處理時間為12毫秒。你可以根據需要修改中間件,以便將日志記錄到文件或其他存儲系統中。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女