• ADADADADAD

    Mysql错误:Too many connections的解决方法[ mysql数据库 ]

    mysql数据库 时间:2024-12-03 10:29:01

    作者:文/会员上传

    简介:

    MySQL数据库 Too many connections出现这种错误明显就是 mysql_connect 之后忘记 mysql_close;当大量的connect之后,就会出现Too many connections的错误,mysql默认的连接为100

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    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 = 3306socket = /tmp/mysql.sockskip-lockingkey_buffer = 160Mmax_allowed_packet = 1Mtable_cache = 64sort_buffer_size = 512Knet_buffer_length = 8Kread_buffer_size = 256Kread_rnd_buffer_size = 512Kmyisam_sort_buffer_size = 8Mmax_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 = 600interactive_timeout = 600

    再次重启mysql即可

    原理解答

    mysql 默认100 连接数,超过则连不上,实际工作的连接数远远没有100,大部分在sleep

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

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。

    Mysql错误:Too many connections的解决方法.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: toomanyconnections