登录
首页 >  Golang >  Go问答

在 Golang 中如何管理和重用 Postgres/MySQL 数据库连接?

来源:stackoverflow

时间:2024-03-11 10:54:27 251浏览 收藏

大家好,我们又见面了啊~本文《在 Golang 中如何管理和重用 Postgres/MySQL 数据库连接?》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~

问题内容

我有一个应用程序,不同的用户可以连接到不同的数据库(这些数据库可以是 MySQL 或 Postgres),跨不同数据库缓存这些连接的最佳方法是什么?我看到了一些连接池,但似乎它们更适合一个数据库多个连接,而不是多个数据库多个连接。

PS: 为了添加更多上下文,我正在设计一种多租户架构,其中每个租户连接到一个或多个数据库,我可以选择使用 map[string]*sql.DB,其中键是数据库的 url,但它可以是当我们拥有大量数据库时很难扩展。或者我们应该为每个传入请求按连接 URL 分片建立一个分片层,以便每台机器都包含适量的数据库连接,格式为 map[string]*sql.DB

我想要构建的软件的一个示例是 https://www.sigmacomputing.com/,用户可以在其中连接到多个数据库以处理不同的表。


解决方案


MySQL 和 Postgres 都不允许多个数据库用户之间的连接共享,连接凭据中指定了单个数据库用户。如果您的意思是不同的用户拥有自己的数据库凭据,则无法在他们之间共享连接。

如果“不同用户”指的是您的应用程序用户,并且他们共享单个数据库用户来访问应用程序中更深层的数据库,那么您不需要对“缓存”连接执行任何特定操作。 sql.DB 默认保留并重用其池中的打开连接。

Go 自动打开、关闭和重用与 *database/sql.DB 的数据库连接。默认情况下,它最多保持 2 个连接打开(空闲),并在所有打开的连接都已繁忙时在并发下打开无限数量的新连接。

如果您需要对池效率与数据库负载进行一些微调,您可能需要使用 .Set* 方法更改 sql.DB 配置,例如 SetMaxOpenConns

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

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