当前位置: 首页 > 面试题库 >

mysql_connect VS mysql_pconnect [关闭]

公宜春
2023-03-14
问题内容

关闭。 这个问题不能重现或由错别字引起。它当前不接受答案。

想改善这个问题吗? 更新问题,使其成为Stack Overflow
的主题。

4年前关闭。

我对此表示怀疑,我已经在网上搜索过,答案似乎多样化。通过PHP连接到数据库时,在mysql_connect上使用mysql_pconnect更好吗?我读到pconnect的扩展性要好得多,但另一方面,它是一个持久连接…同时拥有10000个连接(全部持久)对我而言似乎不可扩展。

提前致谢。


问题答案:

对于MySQL,持久连接应该是不必要的。在其他数据库(例如Oracle)中,建立连接既昂贵又费时,因此,如果您可以重用连接,那将是一个巨大的胜利。但是那些品牌的数据库提供了连接池,这可以更好地解决该问题。

与其他品牌的数据库相比,建立与MySQL数据库的连接要快得多,因此与其他品牌的数据库相比,使用持久连接给MySQL带来的收益成比例地减少。

持久连接也有不利之处。无论是否需要连接,数据库服务器都会为每个连接分配资源。因此,如果连接处于空闲状态,则会无目的地看到大量浪费的资源。我不知道您是否会达到10,000个空闲连接,但即使是数百个连接也很昂贵。

连接具有状态,对于PHP请求来说,从另一个PHP请求先前使用的会话中“继承”信息是不合适的。例如,临时表和用户html" target="_blank">变量通常在连接关闭时清除,但在使用持久性连接时不会清除。同样,基于会话的设置(例如字符集和排序规则)。另外,LAST_INSERT_ID()将报告会话期间最后生成的ID
,即使该ID在先前的PHP请求中也是如此。

至少对于MySQL而言,持久连接的弊端可能胜过它们的好处。还有其他更好的技术来实现高可伸缩性。

2014年3月更新:

与其他品牌的RDBMS相比,MySQL的连接速度始终很低,但它的速度甚至越来越好。

参见http://mysqlserverteam.com/improving-connectdisconnect-
performance/

在MySQL 5.6中,我们开始着手优化代码处理连接和断开连接。并且这项工作在MySQL
5.7中得到了加速。在这篇博客文章中,我将首先展示我们已经取得的成果,然后描述我们为获得这些成果所做的努力。

阅读博客以获取更多详细信息和速度比较。



 类似资料:
  • 当试图建立我的项目,我得到以下错误: 在我的build.gradle存储库中,我没有jCenter,所以我得到的这个错误来自仍然指向jCenter的依赖项。 Gradle离线模式不是我期望的解决方案。 我知道jCenter已经崩溃了,我们都应该搬到mavenCentral(我已经做到了) 有解决办法吗?

  • 嗨,我只知道这是一个古老的问题,但今天只是好奇。正如我们所知connection.close也会关闭preared语句(如果我错了请纠正我)。但是如果我关闭连接然后关闭preared语句会怎样 我会得到一个空指针异常吗? 有人说这取决于jvm的速度。有时,ps.close()会在conn.close完成其工作之前运行并首先关闭,因此您不会得到null指针。 为了测试它,我修改了代码 但是我没有得到

  • 问题内容: 我已经实现了 使用资源的自定义 java.util.Iterator ,该资源应在使用方法的最后释放。该资源可以是 java.sql.ResultSet , java.io.InputStream 等。 使用此迭代器的某些外部库可能不知道必须关闭它。例如: 在这种情况下,有没有办法关闭此迭代器? 更新: 非常感谢您提供当前的答案。我给每个人一个(+1)。当 hasNext() 返回fa

  • 问题内容: 今天,我第一次在本地计算机上启动Redis,然后在关闭Rails应用程序后关闭了所有终端窗口。一个小时后,我再次启动Rails应用程序,并执行以下操作来启动Redis服务器 但是,它告诉我 因此,即使关闭了Mac上的终端窗口,我也认为它仍在运行其较早的实例。 看着这个页面http://redis.io/commands/shutdown,我试图运行 在终端窗口中,但我收到此响应 因此,

  • 我对ExecutorService的javadoc#shutdown方法感到困惑。这些说法不矛盾吗? 启动有序关闭,其中执行以前提交的任务,但不接受新任务。此方法不会等待以前提交的任务完成执行。使用waitTersion执行此操作。 如果它能有序地关闭之前提交的任务,那么它怎么能等它们完成执行呢?

  • 我已经实现了HikariCP,它工作得很好,我现在计划优雅地关闭我的应用程序,我想让HikariCP正确地关闭数据库连接,而不仅仅是关闭java应用程序。我在谷歌上阅读,我可以看到HikariDataSource应该有一个封闭的方法。。。。但事实上,我看不到它的可用性: 在Eclipse中,如果我尝试ds。close()。。。Eclipse没有显示“close”作为HikariDataSource

  • 问题内容: 我试图将我的应用程序中较大且经常使用的部分重构为单独的方法,以使其易于维护。 其中一些方法要求用户输入并进行输入验证,因此我使用了Scanner和System.in,但是当我关闭Scanner时,我也关闭了System.in。 所以我的问题是,我只能通过用CloseShieldInputStream屏蔽System.in来防止System.in关闭,还是应该开始将Scanner传递给方

  • 想改进这个问题吗?更新问题,使其仅通过编辑这篇文章来关注一个问题。 刚开始学习java大约一个月,我对arraylist和oop有几个问题 这个arraylist允许我将字符串添加到列表中并存储它,但是如果我有一个类调用簿呢 这三者有什么区别?假设我有大量的输入,比如文件 我有一个班级运动 我该怎么做呢?所以我用许多参数来添加这些输入,因为如果我想添加,我通常会这样做 我也会去