javascript - 为什么我不能捕获从 node-postgres 抛出的错误?

标签 javascript node.js npm error-handling try-catch

我在捕获从 Node-Postgres NPM 包抛出的错误时遇到了问题。

这个问题表面上看起来很简单,但是我已经尝试了所有我能想到的。

我的代码如下:

import { Pool } from 'pg' // Import postgres connection pool
const pgPool = new Pool()

async function queryDatabase() {
  try {

    // Force TypeError by passing undefined
    let queryResult = await pgPool.query( undefined )

    if ( queryResult.rows.length > 0 ) {
      return queryResult.rows[0]
    }

    return false

  } catch( err ) {

    // Never Reached
    return new Error( 'Test error' )

  }
}
queryDatabase()

错误如下:

TypeError: Client was passed a null or undefined query
at Client.query (~/.../node_modules/pg/lib/client.js:479:11)

错误本身是不言自明的。我在这里强制错误,以便在 undefined 被错误传递的情况下尝试处理它。我意识到我可以简单地执行检查以确保输入永远不会为空或未定义,但这不是我主要关心的问题。

我担心的是,如果我不能捕捉到从这个包中抛出的这个错误,我还会遇到多少其他无法预见的情况,我根本无法捕捉和处理抛出的错误。

我尝试过许多不同的方法 - Async/Await Try/Catch 方法,如上所示 - 我尝试过 pgPool.query()。 then().catch() - 两者的组合。我什至尝试过对 Pool 实例本身运行 catch。无论我做什么,如果不使用 Node 的 process.on('unhandledRejection', ...) 就无法处理异常,这当然是个坏主意。

几个小时以来,我一直在绞尽脑汁。有什么方法可以捕获并处理这样的错误,这样就不会每次都让我的服务器崩溃?提前致谢!

最佳答案

我能够重现这个,它似乎是 pg-library 中的一个实际错误。

根据源代码,如果您在池实例上调用 .query,该实例将 attempt to connect and get a client .在此连接回调中,实际查询被分派(dispatch)到客户端模块,这将抛出上述类型错误 if the query is nil .

此错误是同步抛出的(即错误传递给callback参数,例如callback(new TypeError("...")) 并且由于池的连接回调中的 client.query 调用周围没有 try/catch,因此您的 try 不会捕获错误/ catch

一个潜在的修复方法是将 client.query 调用包装在一个 try catch 中:

 client.once('error', onError)
      this.log('dispatching query')
      try {
        client.query(text, values, (err, res) => {
          this.log('query dispatched')
          client.removeListener('error', onError)
          if (clientReleased) {
            return
          }
          clientReleased = true
          client.release(err)
          if (err) {
            return cb(err)
          } else {
            return cb(undefined, res)
          }
        })
      }catch(err) {
        return cb(err)
      }

所以目前,恐怕您应该在 github 上创建一个问题并等待错误修复或 fork 存储库并使用上述解决方法。

关于javascript - 为什么我不能捕获从 node-postgres 抛出的错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65222622/

相关文章:

javascript - Enquire.js 在页面加载时不起作用,仅在屏幕 <= 480px 时起作用

javascript - 当用户单击提交按钮时如何显示用户输入。当用户单击清除按钮时也会清除消息。 (Angularjs)

node.js - 对于 Node.js,将所有错误处理放入针对所有未捕获异常的机制中是否有意义?

javascript - 我如何在 NodeJS 中解决 "TypeError: Converting circular structure to JSON"

npm - 如何更改npm路径

javascript - 顺序运行 NPM 脚本

reactjs - sh : react-scripts: command not found

javascript - HTML range 元素控制音频元素的音量

javascript - .js 文件后的井号 (#) 是什么意思?

javascript - 未捕获的语法错误 : Unexpected token < when using bootstrap js