我想知道为使用分片的 Web 应用程序实现数据库连接池的最佳技术是什么。据我所知,大多数(全部?)开源实现仅支持单个数据库。至少,我还没有找到支持分片的。
此外,即使我使用分片,并非所有数据库都将具有与其他数据库相同的架构。我不确定这是否重要。
到目前为止,我能想到的唯一解决方案是编写一个位于多个不同池之上的层。每个不同的池可以是任何可用的单一数据库实现。
是否已经有解决方案?否则最好的技术是什么?
提前致谢,
斯蒂芬。
我想知道为使用分片的 Web 应用程序实现数据库连接池的最佳技术是什么。据我所知,大多数(全部?)开源实现仅支持单个数据库。至少,我还没有找到支持分片的。
此外,即使我使用分片,并非所有数据库都将具有与其他数据库相同的架构。我不确定这是否重要。
到目前为止,我能想到的唯一解决方案是编写一个位于多个不同池之上的层。每个不同的池可以是任何可用的单一数据库实现。
是否已经有解决方案?否则最好的技术是什么?
提前致谢,
斯蒂芬。
我认为没有支持分片的开源实现。也许没有真正的需要,因为在多个数据库池之上创建一个层并不太难。它只需要一个分片映射函数(例如哈希函数)和一个管理器类来跟踪多个池。
如果您担心并非所有数据库都具有相同的模式,您可以将额外的模式跟踪配置放入您的管理器类,以便它知道哪些分片可以为模式提供服务。也就是说,除了数据库池之外,您还需要跟踪架构以分片信息。这并不是真正的额外工作,因为无论如何您都需要分片配置来确定如何从池中提取正确的分片(例如,用户 id mod 10 = 1 应该从分片 1 中提取)
祝你好运
您可以查看hibernate shards 项目。