PHP連接遠端mysql server最終造成ERROR 1040 (HY000): Too many connections
最近遇到一個很詭異的問題,原本的PHP系統要擴增AP Server並把MySQL移到一台獨立的Server上運作,原本認為這個task幾乎是沒有風險的,沒想到一接上線,大量的Client端的請求不僅無法消化,MySQL這邊的Connection數目竟然會很快地暴增,進而讓MySQL不斷吐Too many connections的錯誤的訊息。
但是如果去google "ERROR 1040 (HY000): Too many connections" 的話,許多文章會要你修改max_connections的數目或connection expire(逾期)的時間(例如這篇,下面的指令內容也都引用自此篇文章)。
- 提高max_connection的數值
- 查詢現在的max connections設定,以在任何可以query的地方執行下面的指令
- select VARIABLE_VALUE from information_schema.GLOBAL_VARIABLES where VARIABLE_NAME=’MAX_CONNECTIONS’;
- 查詢現在已經使用的connections數目
- select count(*) from information_schema.PROCESSLIST;
- 服務執行中動態更改max connections,可以在任何可以query的地方執行下面的指令 (下面的xxxx是數字,即允許的最大的connection數目),不過這種設定方式,mysql服務重啟就會失效。
- set global max_connections =xxxx;
- 透過修改設定檔增加max_connections (my.cnf 或是 my.ini),在 [mysqld] 的下面修改 max_connections的數值 (如果沒有的話要自己加進去,預設值是100),修改後需要重啟mysql服務才會生效
- 修改connection的逾期時間(expire time),讓connection不會佔用過久的時間interactive_timeout(單位是秒),下面這個是動態修改的方法。靜態修改也是直接在mysqld裡面加入或修改interactive_timeout的參數就可以了。
- set global interactive_timeout = 3600;
不過在這個case裡面去修改max_connections的參數是沒有用的,因為connection增加的速度太快,最終會灌爆MySQL的 max_connection (我曾有把max_connections改到九十萬,不過connection炸到3萬左右正個系統就癱瘓了)。
因為原本的系統不會有這樣的問題,所以開始換OS、Switch Hub怪罪所有修改過的東西,後來trial and error卻發現,如果AP改用SSH Tunnel來連MySQL就不會有相同的問題,這十分怪異。後來百思不得其解的時候突然在某篇討論串中有人提到可能的原因之一是MySQL試著去反解AP的主機名稱,而DNS又沒有設定AP
Server的反解的record才會出現這個問題。所以,解決的方法如下:
- 去DNS把每台要連的主機名稱設反解
- 設定MySQL Server的/etc/hosts (各系統hosts放置位置請參考這一篇),把要連的AP主機的主機名稱與IP設定上去。
(例如:下面這樣)
- 修改MySQL的設定檔my.cnf (在windows上是my.ini),在[mysqld]下面多加一行skip-name-resolve讓mysql不要在去反解主機名稱
修改了主機名稱反解的問題後,connections就不再暴增了,提供上面幾個解決方法,請參考嚕,希望有幫助。
分享到:
相关推荐
从官方文档知道linux上面编译安装的mysql默认的连接为100个,这样对于网站的需求来说是远远不够的。 mysql官方告诉我们需要修改max_connections的值,那么我们怎么去修改呢?有两种方法 1、修改配置文件文件 修改/etc...
主要给大家介绍了关于Mysql错误Too many connections的解决方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
连接数过多,其实际上并不是,原因是我挪动了一下php的sock文件位置导致,因这几个socket修改没有修改完全,于是出现了too many connections ,从mysql里show processlist并没有发现真的有连接,其实用tshark抓下包...
38 案例实战:数据库无法连接故障的定位,Too many connections.pdf
ERROR 1040 (08004): Too many connections 解决办法,这也是centos7下修改mysql连接数的做法: 1)临时修改 MariaDB [(none)]> show variables like “max_connections”; +—————–+——-+ | Variable_name ...
关于mysql 提示too many connections问题解决办法mysql 提示too many connections是由于当前服务器上的mysql连接过多,一方面清当前已有连接,另一方面是改 max_connections (最大连接量)(就是开源节流思想),我...
39 案例实战:如何解决经典的Too many connections故障?背后原理是什么.pdf
主要介绍了mysql too many open connections问题解决方法,其实是max_connections配置问题导致,它必须在[mysqld]下面才会生效,需要的朋友可以参考下
主要介绍了Mysql 错误too many connections解决方案的相关资料,这里提供了如何解决此问题,需要的朋友可以参考下
解决方法是修改/etc/mysql/my.cnf,添加... 以下是mysql.com网站的相关说明: If you get a Too many connections error when you try to connect to the mysqld server, this means that all available connections are
行业-38 案例实战:数据库无法连接故障的定位,Too many connections.rar
行业-39 案例实战:如何解决经典的Too many connections故障?背后原理是什么.rar
经常会遇见”mysql: error 1040: too many connections”的情况,一种是访问量确实很高,mysql服务器抗不住,这个时候要考虑增加从服务器分散读压力,另外一种情况是mysql配置文件中max_connections值过小: ...
很多开发人员都会遇见”MySQL: ERROR 1040: Too many connections”的异常情况,造成这种情况的一种原因是访问量过高,MySQL服务器抗不住,这个时候就要考虑增加从服务器分散读压力;另一种原因就是MySQL配置文件中...
MySQLNonTransientConnectionException Too many connections mysql的最大连接数默认是100, 最大可以达到16384