注意:这主要是关于pg
或 Node-PostgreSQL 模块的问题。它包含来自 Gatsby 和 Postgraphile 的详细信息,但我不需要这三个方面的专业知识,只需pg
.
我有一个数据库,可以很好地与使用 PostGraphile 的 Express 服务器配合使用。我也可以通过node
命令行访问它...
const { Pool } = require("pg");
const pool = new Pool({ connectionString: myDbUrl });
pool.connect().then(() => console.log('connected'));
// logs 'connected' immediately
完全相同的数据库以前gatsby-source-pg
也可以通过插件与 Gatsby/PostGraphile 配合使用......但最近我更改了开发机器,当我尝试构建或运行开发服务器时,Gatsby 挂在“源和转换节点”步骤. 当我调试它时,它挂在对pool.connect()
.
所以我实际上有两个代码库都使用 PostGraphile,都具有相同的配置,一个有效,另一个无效。更奇怪的是,如果我编辑 Gatsby 插件的源代码,node_modules
使其使用完全相同的代码(我可以在命令行成功运行)......它仍然挂起。
我唯一能想到的是其他一些 Gatsby 插件正在使用所有连接并且没有释放它们,但据我所知(例如通过 grep-ing node_modules
)没有其他插件甚至使用pg
.
所以我真的有两个问题:
A) 谁能帮我理解为什么connect
会挂起?如果您能帮助我理解为什么它会使用已知良好的配置并且仅在 Gatsby 内部(在某些环境因素发生变化之后)这样做,那么奖励积分?
B)任何人都可以帮我解决它吗?如果可能是某种“以前的代码忘记释放连接”问题,有什么方法可以测试吗?如果我能以某种方式登录new Pool().areYouBroken()
,那将非常有用。