草庐IT

php - MySQL(i) "Too many connections"怎么办?

coder 2023-10-06 原文

我正在编写一个 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/

有关php - MySQL(i) "Too many connections"怎么办?的更多相关文章

  1. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是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

  2. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从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""-

  3. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  4. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循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

  5. ruby-on-rails - 相关表上的范围为 "WHERE ... LIKE" - 2

    我正在尝试从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

  6. 使用 ACL 调用 upload_file 时出现 Ruby S3 "Access Denied"错误 - 2

    我正在尝试编写一个将文件上传到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

  7. ruby - 安装 Ruby 时遇到问题(无法下载资源 "readline--patch") - 2

    当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub

  8. ruby - Ruby 中的隐式返回值是怎么回事? - 2

    所以我开始关注ruby​​,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出

  9. ruby - 怎么来的(a_method || :other) returns :other only when assigning to a var called a_method? - 2

    给定以下方法:defsome_method:valueend以下语句按我的预期工作:some_method||:other#=>:valuex=some_method||:other#=>:value但是下面语句的行为让我感到困惑:some_method=some_method||:other#=>:other它按预期创建了一个名为some_method的局部变量,随后对some_method的调用返回该局部变量的值。但为什么它分配:other而不是:value呢?我知道这可能不是一件明智的事情,并且可以看出它可能有多么模棱两可,但我认为应该在考虑作业之前评估作业的右侧...我已经在R

  10. ruby-on-rails - 我该怎么办 :remote location validation with CarrierWave? - 2

    我在我的Rails3示例应用程序上使用CarrierWave。我想验证远程位置上传,因此当用户提交无效URL(空白或非图像)时,我不会收到标准错误异常:CarrierWave::DownloadErrorinImageController#createtryingtodownloadafilewhichisnotservedoverHTTP这是我的模型:classPaintingtrue,:length=>{:minimum=>5,:maximum=>100}validates:image,:presence=>trueend这是我的Controller:classPaintingsC

随机推荐