在Go中,当使用SQL数据库时,是否需要db.Close在关闭应用程序之前关闭DB()?数据库是否会自动检测到连接已终止?
db.Close
DB将尽其所能进行检测,但是如果没有运气,它可能无法检测到。最好尽快发布所获得的东西。
send() 系统调用将等待TCP连接发送数据,但客户端不会收到任何信息。
send()
发生电源故障,网络问题或裸机退出而没有正确释放资源。TCP keepalive机制将启动,并尝试检测连接已死。
客户端已暂停,并且未收到任何数据,在这种情况下,send()它将被阻止。
结果,它可能会阻止
auto vacuum
服务器keepalive配置可以缩短以更早地检测到它。(例如,~2h 12m根据工作量,postgresql中的默认值将很长)。
~2h 12m
最大打开连接数可能会有硬性限制,直到检测到之前,有些连接会变成僵尸(存在,无法使用,但会降低限制)。