如何解决在 Dyno Heroku 中,PostgreSQL 没有响应
我一直在使用 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 => {...}
它从不输入 then
或 catch
。它只是被永远卡住了。
知道为什么它突然停止工作了吗?
解决方法
有时会发生什么,Postgres 中的一个进程锁定并阻止您的应用程序运行。 您首先需要检查是否有任何进程阻止您的应用运行?
-
对于此运行命令
heroku pg:ps
。 -
您将看到进程的日志输出。
-
从日志输出中识别卡住的进程
-
使用
heroku pg:kill 1234 -a example_app_name
确定终止该进程后,其中1234
是进程 ID。 -
如果您无法识别粘贴的进程 ID,请使用以下命令杀死所有进程
heroku pg:killall -a example_app_name
。 -
在此之后,您应该重新启动您的应用程序以删除任何以前的错误连接:
heroku restart -a example_app_name
出于某种原因,更新 pg
软件包有所帮助。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。