小编典典

在Go中关闭应用程序之前是否需要关闭数据库连接?

sql

在Go中,当使用SQL数据库时,是否需要db.Close在关闭应用程序之前关闭DB()?数据库是否会自动检测到连接已终止?


阅读 185

收藏
2021-04-22

共1个答案

小编典典

DB将尽其所能进行检测,但是如果没有运气,它可能无法检测到。最好尽快发布所获得的东西。

send() 系统调用将等待TCP连接发送数据,但客户端不会收到任何信息。

  1. 发生电源故障,网络问题或裸机退出而没有正确释放资源。TCP keepalive机制将启动,并尝试检测连接已死。

  2. 客户端已暂停,并且未收到任何数据,在这种情况下,send()它将被阻止。

结果,它可能会阻止

  1. 正常关闭集群。
  2. 如果事件持有事务处理中的排他锁(例如auto vacuum在postgresql中),则提高事件范围。

服务器keepalive配置可以缩短以更早地检测到它。(例如,~2h 12m根据工作量,postgresql中的默认值将很长)。

最大打开连接数可能会有硬性限制,直到检测到之前,有些连接会变成僵尸(存在,无法使用,但会降低限制)。

2021-04-22