我已经阅读了几篇关于单例示例的文章。而且我可以看到开发人员有时将数据库连接对象或连接管理器作为单例实现。在一些帖子中甚至建议使用数据库连接池。那么Singleton的意思就是创建一个单一的实例,所以基本上我们限制访问。例如打印机或硬件访问,记录器访问,我们尝试使用单例将用户的访问限制为一次一个。但是,在 DB 连接对象中使用单例的目的是什么?如果我能正确理解将数据库连接创建为单例,则意味着应用服务器将只有一个实例。这是否意味着只有一个用户可以访问数据库连接,而下一个用户必须等到连接关闭?请指教。
问问题
2056 次
2 回答
2
我认为您正确理解了将连接本身设为单例的含义。通常这不是一个好主意(尽管在某些非常特殊的情况下它可能有意义)。
使连接管理器或连接池成为单例是完全不同的。池本身将处理一组连接,它可以根据需要创建新的连接(达到限制)或重新使用已经使用和丢弃的连接。
同时拥有多个连接池会失去连接池的优势:
- 控制打开的连接总数会更难
- 一个池可能正在创建连接,而另一个池可能有可用的连接
希望这有助于澄清主题。您可能想阅读有关连接池的更多信息。
于 2012-11-23T01:01:03.180 回答
0
问:“但是,在 DB 连接对象中使用单例的目的是什么?”
答:(几乎总是)没有。所以你的想法是正确的。
问:“这是否意味着只有一个用户可以访问数据库连接,而下一个用户必须等到连接关闭?”
答:取决于(第一部分)和否(“和”之后的第二部分)。
在单线程应用程序中,一次只有一个用户会使用数据库,而另一个用户会等待,直到第一个用户的分派结束,但连接关闭时不会。连接关闭后,您需要创建另一个连接以使用数据库。
在多线程应用程序中,许多线程可能使用相同的连接实例,结果实际上取决于供应商的实现:可能会阻塞调度(有效地将您的应用程序转换为单线程应用程序)或抛出异常甚至是不同的东西。然而,
于 2012-11-23T09:24:18.497 回答