」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > Node.js 應用程式中的錯誤處理和日誌記錄

Node.js 應用程式中的錯誤處理和日誌記錄

發佈於2024-11-09
瀏覽:921

Error Handling and Logging in Node.js Applications

介绍

在后端开发领域,可靠的错误处理和结构化日志记录对于构建有弹性和可维护的应用程序至关重要。 Node.js 中有效的错误处理不仅可以改善用户体验,还可以简化调试并增强应用程序监控。结合适当的日志记录,开发人员可以更快地跟踪问题并实时监控系统运行状况。在本文中,我们将深入探讨 Node.js 中的错误处理和日志记录策略,这些策略可以使应用程序更加健壮并可用于生产。

1.了解 Node.js 中的错误处理

Node.js 中的错误处理有其独特的挑战,主要是由于其异步、事件驱动的架构。让我们探讨 Node.js 中有效错误处理的一些关键区别和原则:

  • 同步与异步错误:同步错误立即发生,可以使用传统的 try-catch 块捕获,而异步错误稍后发生,需要不同的处理,例如回调、承诺或异步/等待模式。
  • 统一错误处理策略:通过大量的异步操作,维护统一的方法有助于更有效地管理整个应用程序中的错误。一致的错误处理简化了调试并确保统一传播和记录错误。

2.基本错误处理技术

Node.js 提供了多种管理错误的机制,特别是在异步工作流程中:

  • Try-Catch 块:这些对于处理同步代码中的错误很有用,但不会捕获异步代码中的错误。例如:
  try {
    const data = JSON.parse(jsonString);
  } catch (error) {
    console.error("JSON parsing error:", error);
  }
  • 错误对象:Node.js 中的错误对象携带堆栈跟踪等重要信息,可以帮助开发人员调试问题。自定义错误消息应该清晰且可操作。

  • Promises 和 Async/Await 中的错误处理:

    • Promises:使用 .catch() 处理 Promise 拒绝。
    fetchData()
      .then(data => console.log(data))
      .catch(error => console.error("Error fetching data:", error));
    
    • Async/Await:将await 调用包装在try-catch 块内以进行异步错误处理。
    async function fetchData() {
      try {
        const data = await someAsyncFunction();
        console.log(data);
      } catch (error) {
        console.error("Error:", error);
      }
    }
    
  • 全局错误处理

    • 未捕获的异常:使用process.on('uncaughtException',callback)捕获未捕获的异常。
    • 未处理的拒绝:使用 process.on('unhandledRejection',callback) 处理未处理的 Promise 拒绝。这提供了生产中的最后一道防线,尽管通常建议在错误发生的地方进行处理。

3.高级错误处理模式

为了实现更具可扩展性和可维护性的错误处理,这些先进技术至关重要:

  • Express 中的中间件错误处理: Express 提供了内置的错误处理机制,可以捕获错误并将其传递给自定义中间件。
  app.use((err, req, res, next) => {
    console.error("Error:", err);
    res.status(500).send("Something went wrong!");
  });
  • 集中错误管理: 可以创建集中式错误处理模块来定义自定义错误响应和消息,从而提供处理错误的标准化方法。
  class AppError extends Error {
    constructor(message, statusCode) {
      super(message);
      this.statusCode = statusCode;
      Error.captureStackTrace(this, this.constructor);
    }
  }
  • 错误代码及分类: 使用 HTTP 状态代码对错误进行分类(4xx 表示客户端错误,5xx 表示服务器错误),并添加自定义代码以进行更详细的日志记录和错误跟踪。

4.在 Node.js 中实现日志记录

日志记录可以深入了解应用程序中发生的情况,对于跟踪错误非常有价值。以下是如何在 Node.js 中实现有效的日志记录:

  • 基本控制台日志记录:
    控制台对象(console.log、console.error 等)很方便,但在生产中受到限制。对于结构化、基于级别的日志记录,最好使用专用的日志记录库。

  • 使用 Winston 进行日志记录:
    Winston 是一个功能强大的日志记录库,提供结构化日志记录,包括信息、警告、错误和调试等级别。

  const winston = require("winston");

  const logger = winston.createLogger({
    level: "info",
    format: winston.format.json(),
    transports: [
      new winston.transports.File({ filename: "error.log", level: "error" }),
      new winston.transports.Console({ format: winston.format.simple() })
    ]
  });
  • 日志级别:

    • info:有关应用程序行为的一般信息。
    • warn:警告,通常是非破坏性但值得注意的事件。
    • 错误:需要立即关注的关键问题。
    • debug:对调试有用的详细信息。
  • 旋转日志:

    日志轮换限制日志文件大小并确保高效存储。 Winston 的 winston-daily-rotate-file 传输可以帮助管理每天的日志。

5.生产中的错误和日志管理

管理生产中的错误和日志需要额外考虑以维护性能和数据安全。

  • 使用日志服务:
    集成 LogglyPapertrailELK Stack(Elasticsearch、Logstash、Kibana)等服务以进行集中式日志管理。这些工具提供强大的搜索和过滤选项,可以快速解决生产问题。

  • 性能注意事项:
    日志记录会影响性能,因此请避免过多的日志记录,尤其是在高流量应用程序中。考虑为开发(调试)和生产(信息或错误)设置不同的日志级别。

  • 保护日志:
    为防止敏感信息泄露,请避免记录敏感数据,或使用脱敏技术对用户信息进行匿名化。

6。现实世界的例子

  • 电子商务应用程序:对于电子商务应用程序,记录用户操作并监控结帐过程中的错误可以深入了解用户行为和阻碍转化的问题。
  • 具有结构化日志记录的 REST API:使用结构化日志记录的 REST API 可以跟踪请求详细信息、错误和用户访问,从而帮助维护系统可靠性。

结论

总之,Node.js 中设计良好的错误处理和日志记录策略对于构建有弹性且可维护的应用程序至关重要。有效的错误处理和结构化日志记录使开发人员能够监视、排除故障和优化应用程序,确保他们准备好妥善处理错误并跟踪应用程序的运行状况。通过将这些技术与持续监控相结合,您将拥有一个更可靠的系统可供生产。

版本聲明 本文轉載於:https://dev.to/divine_nnanna2/error-handling-and-logging-in-nodejs-applications-1k2a?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何使用Python理解有效地創建字典?
    如何使用Python理解有效地創建字典?
    python dictionary consection 在python中,詞典綜合提供了一種生成新詞典的簡潔方法。儘管它們與列表綜合相似,但存在一些顯著差異。 與問題所暗示的不同,您無法為鑰匙創建字典理解。您必須明確指定鍵和值。 For example:d = {n: n**2 for n in...
    程式設計 發佈於2025-04-19
  • Python元類工作原理及類創建與定制
    Python元類工作原理及類創建與定制
    python中的metaclasses是什麼? Metaclasses負責在Python中創建類對象。就像類創建實例一樣,元類也創建類。他們提供了對類創建過程的控制層,允許自定義類行為和屬性。 在Python中理解類作為對象的概念,類是描述用於創建新實例或對象的藍圖的對象。這意味著類本身是使用...
    程式設計 發佈於2025-04-19
  • 如何在其容器中為DIV創建平滑的左右CSS動畫?
    如何在其容器中為DIV創建平滑的左右CSS動畫?
    通用CSS動畫,用於左右運動 ,我們將探索創建一個通用的CSS動畫,以向左和右移動DIV,從而到達其容器的邊緣。該動畫可以應用於具有絕對定位的任何div,無論其未知長度如何。 問題:使用左直接導致瞬時消失 更加流暢的解決方案:混合轉換和左 [並實現平穩的,線性的運動,我們介紹了線性的轉換。...
    程式設計 發佈於2025-04-19
  • C++中如何將獨占指針作為函數或構造函數參數傳遞?
    C++中如何將獨占指針作為函數或構造函數參數傳遞?
    在構造函數和函數中將唯一的指數管理為參數 unique pointers( unique_ptr [2啟示。通過值: base(std :: simelor_ptr n) :next(std :: move(n)){} 此方法將唯一指針的所有權轉移到函數/對象。指針的內容被移至功能中,在操作...
    程式設計 發佈於2025-04-19
  • 如何解決AppEngine中“無法猜測文件類型,使用application/octet-stream...”錯誤?
    如何解決AppEngine中“無法猜測文件類型,使用application/octet-stream...”錯誤?
    appEngine靜態文件mime type override ,靜態文件處理程序有時可以覆蓋正確的mime類型,在錯誤消息中導致錯誤消息:“無法猜測mimeType for for file for file for [File]。 application/application/octet...
    程式設計 發佈於2025-04-19
  • Python高效去除文本中HTML標籤方法
    Python高效去除文本中HTML標籤方法
    在Python中剝離HTML標籤,以獲取原始的文本表示 僅通過Python的MlStripper 來簡化剝離過程,Python Standard庫提供了一個專門的功能,MLSTREPERE,MLSTREPERIPLE,MLSTREPERE,MLSTREPERIPE,MLSTREPERCE,MLST...
    程式設計 發佈於2025-04-19
  • CSS強類型語言解析
    CSS強類型語言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    程式設計 發佈於2025-04-19
  • 如何在Java字符串中有效替換多個子字符串?
    如何在Java字符串中有效替換多個子字符串?
    在java 中有效地替換多個substring,需要在需要替換一個字符串中的多個substring的情況下,很容易求助於重複應用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    程式設計 發佈於2025-04-19
  • 如何在Java的全屏獨家模式下處理用戶輸入?
    如何在Java的全屏獨家模式下處理用戶輸入?
    Handling User Input in Full Screen Exclusive Mode in JavaIntroductionWhen running a Java application in full screen exclusive mode, the usual event ha...
    程式設計 發佈於2025-04-19
  • 查找當前執行JavaScript的腳本元素方法
    查找當前執行JavaScript的腳本元素方法
    如何引用當前執行腳本的腳本元素在某些方案中理解問題在某些方案中,開發人員可能需要將其他腳本動態加載其他腳本。但是,如果Head Element尚未完全渲染,則使用document.getElementsbytagname('head')[0] .appendChild(v)的常規方...
    程式設計 發佈於2025-04-19
  • 如何使用FormData()處理多個文件上傳?
    如何使用FormData()處理多個文件上傳?
    )處理多個文件輸入時,通常需要處理多個文件上傳時,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    程式設計 發佈於2025-04-19
  • CSP是什麼以及它如何工作?
    CSP是什麼以及它如何工作?
    How CSP WorksCSP is implemented through a meta-tag in the HTML header of a web page.該元標記的內容包含定義加載資源的允許來源的指令。這些指令通常指定以下內容:源來源:可以加載資源的域或主機。 使用content-...
    程式設計 發佈於2025-04-19
  • 切換到MySQLi後CodeIgniter連接MySQL數據庫失敗原因
    切換到MySQLi後CodeIgniter連接MySQL數據庫失敗原因
    Unable to Connect to MySQL Database: Troubleshooting Error MessageWhen attempting to switch from the MySQL driver to the MySQLi driver in CodeIgniter,...
    程式設計 發佈於2025-04-19
  • 在Python中如何創建動態變量?
    在Python中如何創建動態變量?
    在Python 中,動態創建變量的功能可以是一種強大的工具,尤其是在使用複雜的數據結構或算法時,Dynamic Variable Creation的動態變量創建。 Python提供了幾種創造性的方法來實現這一目標。 利用dictionaries 一種有效的方法是利用字典。字典允許您動態創建密鑰並...
    程式設計 發佈於2025-04-19
  • 使用jQuery如何有效修改":after"偽元素的CSS屬性?
    使用jQuery如何有效修改":after"偽元素的CSS屬性?
    在jquery中了解偽元素的限制:訪問“ selector 嘗試修改“:”選擇器的CSS屬性時,您可能會遇到困難。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    程式設計 發佈於2025-04-19

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3