2

我想知道为使用分片的 Web 应用程序实现数据库连接池的最佳技术是什么。据我所知,大多数(全部?)开源实现仅支持单个数据库。至少,我还没有找到支持分片的。

此外,即使我使用分片,并非所有数据库都将具有与其他数据库相同的架构。我不确定这是否重要。

到目前为止,我能想到的唯一解决方案是编写一个位于多个不同池之上的层。每个不同的池可以是任何可用的单一数据库实现。

是否已经有解决方案?否则最好的技术是什么?

提前致谢,

斯蒂芬。

4

3 回答 3

4

我认为没有支持分片的开源实现。也许没有真正的需要,因为在多个数据库池之上创建一个层并不太难。它只需要一个分片映射函数(例如哈希函数)和一个管理器类来跟踪多个池。

如果您担心并非所有数据库都具有相同的模式,您可以将额外的模式跟踪配置放入您的管理器类,以便它知道哪些分片可以为模式提供服务。也就是说,除了数据库池之外,您还需要跟踪架构以分片信息。这并不是真正的额外工作,因为无论如何您都需要分片配置来确定如何从池中提取正确的分片(例如,用户 id mod 10 = 1 应该从分片 1 中提取)

祝你好运

于 2009-09-22T16:36:59.247 回答
1

您目前使用的技术堆栈是什么?我知道 Hibernate 有一个 sharding 项目,但我没有使用它,只是听了一些关于它的播客。

关于它的更多信息可以在这里找到。此外,可以在此处找到前面提到的播客。

播客解释了一般分片的一些问题,Hibernate 插件处理的一些问题,然后解释了他们预期的前进道路。希望能有所帮助!

于 2009-09-22T16:56:06.393 回答
1

您可以查看hibernate shards 项目。

于 2009-09-22T18:18:41.903 回答