我正在编写一个 hugh MySQLi/PHP 应用程序,我的数据库遇到问题,似乎在运行几个小时后打开的连接 (250) 太多。
我在我的网络中使用了一个非常快速的外部数据库服务器。我每秒处理大约 1000 个问题,但服务器似乎并没有给我留下深刻印象(负载接近于 0)。
在我的应用程序中,MySQLi 链接被数据库类的析构函数关闭(这似乎工作正常)。
我正在使用准备好的语句,还有几个运行着无限 while 循环的守护进程和其中的一些查询(循环被 usleep() 延迟以防止过度使用,我必须注意mysqli_connect() 仅在启动守护程序时调用)。
但似乎我从来没有用stmt->close() 关闭我准备好的语句。在我的数据库中的查询统计信息下,我可以看到 stmt->close() 问题的数量等于 stmt->execute() 的数量。那么这可能是问题吗?例如,我什么时候必须关闭我的 stmt?我不知道在哪里可以找到这个问题的解决方案。
软件版本
CentOS 6.5 下的 PHP 5.5 和 MySQL 5.6
最佳答案
这里有一些尝试:
首先:在你的无限循环守护进程中:在 sleep 前关闭你的连接并在醒来时再次打开它们。不要试图长时间保持数据库连接打开。客户端-服务器连接中有各种超时逻辑,它们可能会在您不希望它激活时激活,因此会给您带来不可预测的故障。打开连接,使用它们,然后关闭它们将避免这种情况。
第二:尝试使用所谓的持久连接。在 mysqli 中,您可以在主机名前添加 p: 来执行此操作。读这个:http://www.php.net/manual/en/mysqli.persistconns.php
第三:最好的做法是在你完成准备好的语句时显式地close(),如果你重用它们,则在使用之间reset()它们他们。 mysqli dtor 应该会自动执行此操作,但这仍然是一个很好的做法
第四:您可能希望配置 Apache 或 ngnix 服务器软件以产生更少的实例和线程。这些实例和/或线程是连续可重用的资源,Linux 的 TCP 堆栈在为它们排队连接请求方面做得很好。这应该会减少 MySQL 需要处理的连接数。
第五:您是否需要更改 MySQL 的配置以允许超过 250 个连接?如果您要将网络流量负载均衡到许多网络服务器,您可能需要这样做。
恭喜您获得大量流量!现在来点真正的乐趣。哇哈哈哈。
关于php - MySQL(i) "Too many connections"怎么办?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24654726/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
给定以下方法:defsome_method:valueend以下语句按我的预期工作:some_method||:other#=>:valuex=some_method||:other#=>:value但是下面语句的行为让我感到困惑:some_method=some_method||:other#=>:other它按预期创建了一个名为some_method的局部变量,随后对some_method的调用返回该局部变量的值。但为什么它分配:other而不是:value呢?我知道这可能不是一件明智的事情,并且可以看出它可能有多么模棱两可,但我认为应该在考虑作业之前评估作业的右侧...我已经在R
我在我的Rails3示例应用程序上使用CarrierWave。我想验证远程位置上传,因此当用户提交无效URL(空白或非图像)时,我不会收到标准错误异常:CarrierWave::DownloadErrorinImageController#createtryingtodownloadafilewhichisnotservedoverHTTP这是我的模型:classPaintingtrue,:length=>{:minimum=>5,:maximum=>100}validates:image,:presence=>trueend这是我的Controller:classPaintingsC