gpt4 book ai didi

java - 为什么数据库连接对象或连接池需要做成单例?

转载 作者:行者123 更新时间:2023-12-02 07:26:27 25 4
gpt4 key购买 nike

我已经阅读了几篇关于单例示例的文章。我可以看到开发人员有时将数据库连接对象或连接管理器作为单例实现。在一些帖子中甚至建议使用数据库连接池。那么 Singleton 意味着创建单个实例,所以基本上我们限制访问。例如打印机或硬件访问、记录器访问,其中我们尝试使用单例将用户的访问限制为一次一个。但是,在数据库连接对象中使用单例的目的是什么?如果我能正确理解将数据库连接创建为单例意味着应用程序服务器将只有一个实例。这是否意味着只有一个用户可以访问数据库连接,而下一个用户必须等到连接关闭?请指教。

最佳答案

我认为您正确理解了使连接本身成为单例的含义。一般来说,这不是一个好主意(尽管在某些非常特殊的情况下它可能是有意义的)。

使连接管理器或连接池成为单例是完全不同的。池本身将处理连接的集合,并且可以根据需要创建新的连接(最多达到限制)或重新使用已使用和丢弃的连接。

同时拥有多个连接池就会失去池的优势:

  • 控制打开的连接总数会更困难
  • 一个池可能正在创建连接,而其他池可能有可用连接

希望这有助于澄清这个主题。您可能想了解有关连接池的更多信息。

关于java - 为什么数据库连接对象或连接池需要做成单例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13521660/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com