【发布时间】:2020-02-24 02:46:07
【问题描述】:
嘿,我收到一条错误消息:来自 pgx 的 conn busy
我不知道如何解决这个问题。这是我的功能:
func (r *proverbRepo) SelectPendingProverbs(table string) (proverbs []domain.Proverb, err error) {
query := fmt.Sprintf("SELECT id, proverb literal FROM %s", table)
rows, err := r.Db.Query(context.Background(), query)
defer rows.Close()
if err != nil {
return
}
for rows.Next() {
var prov domain.Proverb
if err = rows.Scan(&prov.ID, &prov.Literal); err != nil {
return
}
proverbs = append(proverbs, prov)
}
return
}
r.Db 是pgx.Connect(context.Background(), os.Getenv("PSQL_URL"))
我在很短的时间间隔内从两个单独的前端请求中获取两个不同的表。
第一个请求通过,另一个返回conn busy错误信息。
我真的不知道要找什么,有人可以帮我吗?
【问题讨论】:
-
建议:在错误检查之前不要延迟,如果 err 不是 nil 行 将 为 nil,并且由于您在错误检查之前延迟,因此将触发延迟从错误检查返回并 Close 将在
nil行实例上调用。不好的做法。 -
谢谢,没有解决问题,但我已经更新了我的功能。
-
conn busy 表示您在某处错过了 Close call,可能在共享数据库实例的程序的其他部分。
-
好的,那与请求的同时性无关?我会再检查一次接近的电话。
-
也可能与上下文有关。还在寻找。