登录
首页 >  Golang >  Go问答

SetMaxOpenConns 和 SetMaxIdleConns

来源:Golang技术栈

时间:2023-04-11 10:06:01 102浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《SetMaxOpenConns 和 SetMaxIdleConns》,介绍一下golang,希望对大家的知识积累有所帮助,助力实战开发!

问题内容

为什么有SetMaxOpenConnsSetMaxIdleConns。在文档中

SetMaxIdleConns

SetMaxIdleConns 设置空闲连接池的最大连接数。

如果 MaxOpenConns 大于 0 但小于新的 MaxIdleConns,则新的 MaxIdleConns 将减少以匹配 MaxOpenConns 限制

如果 n

SetMaxOpenConns

SetMaxOpenConns 设置与数据库的最大打开连接数。

如果 MaxIdleConns 大于 0 并且新的 MaxOpenConns 小于 MaxIdleConns,则 MaxIdleConns 将减少以匹配新的 MaxOpenConns 限制

如果 n

为什么同时具有这两个功能但没有一个功能来调整空闲和打开的连接MaxConns,例如MaxIdleConns + MaxOpenConns. 为什么开发人员必须安排可以有多少打开和空闲的 conn,而不是定义总池?

正确答案

数据库池可能包含 0 个或多个与数据库的空闲连接。这些是建立、使用而不是关闭的连接,保留以供将来使用。我们可以保留的数量是MaxIdleConns

当您请求其中一个空闲连接时,它会变成一个开放连接,可供您使用。您可以使用的数量是MaxOpenConns

现在,没有任何比允许的最大打开连接数更多的空闲连接,因为如果您 可以 立即获取所有允许的打开连接,则剩余的空闲连接将始终保持空闲状态。这就像一座有四车道的桥,但一次只允许三辆车通过。

因此,我们希望确保

MaxIdleConns 

MaxIdleConns编写函数是为了通过在超过 时通过减少来保留此不变量MaxOpenConns。请注意,文档说, onlyMaxIdleConns永远减少为 match MaxOpenConns,后者永远不会正确。

要回答为什么开发人员可能要单独调整这些问题的问题:考虑一个通常很安静但偶尔需要打开大量连接的应用程序的情况。您可能希望指定一个很大MaxOpenConns但很小的MaxIdleConns,以确保您的应用程序可以在需要时打开尽可能多的连接,但会快速释放这些资源,从而为自身 数据库释放内存。保持空闲连接不是免费的,通常这样做是因为您想尽快将其变为可用连接。

所以这里有两个数字的原因是这两个参数你可能有充分的理由单独改变。当然,API 的语义意味着如果你不关心设置这两个值,你可以只设置你关心的一个,这可能是MaxOpenConns

理论要掌握,实操不能落!以上关于《SetMaxOpenConns 和 SetMaxIdleConns》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>