3

注意:这主要是关于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(),那将非常有用。

4

2 回答 2

5

尝试:

npm install pg@latest

这就是让我的池/连接按预期开始工作的原因。

于 2021-04-04T18:27:52.840 回答
1

烦人的答案:因为一个错误(谢谢@charmander)。有关详细信息,请参阅:https ://github.com/brianc/node-postgres/issues/2300

PS我从来没有找到任何new Pool().areYouBroken()功能。

于 2020-08-02T22:55:25.353 回答