0

我一直在使用 In Dyno Heroku PostgreSQL 一段时间,但由于某种原因,它在一周前停止响应。我没有改变任何东西,即使运行旧的提交它仍然没有响应。不响应是指当我尝试将客户端连接到数据库时,什么也没有发生。没有错误消息,没有超时,什么都没有。结果,我无法在 Heroku CI 中运行任何测试。我正在使用 pg-node 连接到数据库。这是我在 app.json 中的代码:

{
  "buildpacks": [
    { "url": "heroku/nodejs" }
  ],
  "environments": {
    "test": {
      "env": {  "POSTGRESQL_VERSION": "12" },
      "addons": ["heroku-postgresql:in-dyno", "heroku-redis:hobby-dev"]
    }
  }
}

这就是我连接到数据库的方式:

client = new Client({
  connectionString: process.env.DATABASE_URL
})
client.connect()
.then(ob => {...}
.catch(err => {...}

它从不进入thenor catch。它只是被永远卡住了。知道为什么它突然停止工作了吗?

4

2 回答 2

0

有时会发生什么情况,Postgres 中的一个进程会锁定并阻止您的应用程序运行。您首先需要检查是否有任何进程阻止您的应用程序运行?

  • 对于这个运行命令heroku pg:ps

  • 您将看到进程的日志输出。

  • 从日志输出中识别卡住的进程

  • 在使用heroku pg:kill 1234 -a example_app_namewhere 1234is the process id 确定终止该进程后。

  • 如果您无法识别粘贴的进程 ID,则使用 heroku pg:killall -a example_app_name.

  • 在此之后,您应该重新启动您的应用程序以删除任何以前的不良连接: heroku restart -a example_app_name

于 2021-02-10T04:39:56.910 回答
0

出于某种原因,更新pg包有所帮助。

于 2021-02-11T18:50:37.793 回答