javascript - 为什么我无法捕获 node-postgres 引发的错误?
问题描述
我在捕获 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.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
池实例,该实例将尝试连接并获取客户端。在此连接回调中,实际查询被分派到客户端模块,如果查询为 nil,它将抛出上述类型错误。
此错误是同步抛出的(即错误未传递给callback
参数,例如),并且由于池的连接回调中callback(new TypeError("...")
没有try/catch
围绕调用,因此您的.client.query
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 上创建一个问题并等待错误修复或分叉 repo 并使用上述解决方法。
推荐阅读
- alexa - 如何询问 Alexa 技能的语音评级?
- c# - 在 DataTable Delete 操作中多次发送 Ajax 请求 - ASP.NET、JQuery、Ajax
- powershell - 将查询对象格式化为数组
- javascript - 为什么严格模式不会在重复的属性名称上引发语法错误?
- python - 如果在“-”和“-”之间,则打印字符串
- android - 如何在android模拟器上以编程方式设置虚拟场景图像
- javascript - 如何在具有“contenteditable”属性的元素上触发功能?
- c - 如何指示 MSVC 编译器使用 64 位/32 位除法而不是较慢的 128 位/64 位除法?
- css - 如何修复:Gatsby 构建导致 css 文件被合并,这会破坏特定 Gatsby 页面上的本地样式
- visual-studio-code - 是否可以在 VS Code 中快速交换行?