APP下载

解决Mysql错误Too many connections的方法

消息来源:baojiabao.com 作者: 发布时间:2026-05-23

报价宝综合消息解决Mysql错误Too many connections的方法

MySQL数据库 Too many connections

出现这种错误明显就是 mysql_connect 之后忘记 mysql_close;

当大量的connect之后,就会出现Too many connections的错误,mysql预设的连线为100个,而什么情况下会出现这种错误呢?

正常的mysql_connect 之后呼叫 mysql_close()关闭连线

但在连线错误时,会者mysql_real_query()出现错误退出时,可能忘记mysql_close();

所以在程式return 之前一定要判断是否close(),最稳妥的方法就是在写任何函式时都只有一个出口!

还有可以通过修改mysql配置档案来加大允许连线的数量!

有时你的服务器是经常出现这样的错误呢:

错误资讯如下:

Can not connect to MySQL server

Error: Too many connections

Errno.: 1040

Similar error report has beed dispatched to administrator before.

从官方文件知道Linux上面编译安装的mysql预设的连线为100个

文件:http://dev.mysql.com/doc/refman/5.0/en/too-many-connections.html

mysql官方告诉我们需要修改max_connections的值,那么我们怎么去修改呢?有两种方法

1、修改配置档案档案

修改/etc/my.cnf这个档案,在[mysqld] 中新增max_connections=N,如果你没有这个档案请从编译源代码中的support-files资料夹中复制你所需要的*.cnf档案为到 /etc/my.cnf。我使用的是my-medium.cnf,中型服务器配置。例如我的[mysqld]的内容如下

[mysqld]

port = 3306

socket = /tmp/mysql.sock

skip-locking

key_buffer = 160M

max_allowed_packet = 1M

table_cache = 64

sort_buffer_size = 512K

net_buffer_length = 8K

read_buffer_size = 256K

read_rnd_buffer_size = 512K

myisam_sort_buffer_size = 8M

max_connections=1000

由于对mysql还不是很熟悉,所以很多引数没有修改。哈哈。。

2、非使用mysqld指令码自动启动的使用者。

修改MYSQLHOME/bin/mysqldsafe档案例如:/usr/local/mysql/bin/mysqldsafe这个档案grep−n‘maxconnection′

MYSQLHOME/bin/mysqldsafe档案例如:/usr/local/mysql/bin/mysqldsafe这个档案grep−n‘maxconnection′MYSQL_HOME/bin/mysqld_safe

修改对应行号的max_connections引数值

3、服务器登入mysql : mysql -u root -p

百分之九十进不去,进不去的执行重启命令 :/etc/init.d/mysql restart(centos系统)

此时重启mysql就能连线mysql了,如果还有时间,可以继续下一步,治病要治本

开启配置档案 新增一下配置 vi /etc/my.cnf

wait_timeout = 600

interactive_timeout = 600

再次重启mysql即可

原理解答

mysql 预设100 连线数,超过则连不上,实际工作的连线数远远没有100,大部分在sleep

所以要么增大连线数,要么杀掉无用连线,推荐后者。

2019-12-15 02:51:00

相关文章