xxx*_*222 8 sql postgresql caching relational-database go
我有一个应用程序,其中不同的用户可以连接到不同的数据库(可以是 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 个连接打开(空闲),并在所有打开的连接都已繁忙时在并发下打开无限数量的新连接。
如果您需要对池效率与数据库负载进行一些微调,您可能需要sql.DB使用方法更改配置.Set*,例如SetMaxOpenConns。
| 归档时间: |
|
| 查看次数: |
587 次 |
| 最近记录: |