mysql 报错 ‘too many connections’
2018-09-12 本文已影响25人
遗步看风景
最近的一个物联网短连接的项目,用的是twisted+pymysql写的,在程序运行的过程中会出现如题错误:too many connections
为此各种百度找到的解决办法,并且摘录下来以防丢失。转自:https://blog.csdn.net/qq_31454017/article/details/71108278
1.登录数据库
mysql -u root -p
回车输入密码进入mysql
2.查看当前连接数
show processlist;
查看连接数,可以发现有很多连接处于sleep状态
这些其实是暂时没有用的,所以可以kill掉
3.查看最大连接数
show variables like "max_connections";
查看最大连接数
应该是与上面查询到的连接数相同
才会出现too many connections的情况
4.修改最大连接数目
set GLOBAL max_connections=1000;
修改最大连接数,
但是这不是一劳永逸的方法,
应该要让它自动杀死那些sleep的进程。
5.修改空闲超时时间
show global variables like 'wait_timeout'
这个数值指的是mysql
在关闭一个非交互的连接之前要等待的秒数,
默认是28800s
6.修改等待超时时间
set global wait_timeout=300;
修改这个数值
这里可以随意
最好控制在几分钟内
7.修改连接持续时间
set global interactive_timeout=500;
修改这个数值
表示mysql在关闭一个连接之前要等待的秒数
至此可以让mysql自动关闭那些没用的连接
但要注意的是
正在使用的连接到了时间也会被关闭
因此这个时间值要合适
8.批量kill之前没用的sleep连接,在网上搜索的方法对我都不奏效,因此只好使用最笨的办法,一个一个kill
1.select concat('KILL ',id,';') from information_schema.processlist where user='root'; 先把要kill的连接id都查询出来
2.复制中间的kill id;内容到word文档
3.替换掉符号“|”和回车符(在word中查询^p即可查询到回车符)
4.把修改过的内容复制回终端,最后按回车执行!
9.以上办法,虽然可以解决问题,但是设备重启之后,原来设置的内容也会丢失。下面介绍一个永久更改设置的办法。
1、进入目录 /etc/mysql/mysql.conf.d,找到配置文件 mysqld.cnf;
2、sudo vim mysqld.cnf,在 [mysqld] 中修改 max_connections 为5000;
3、重启服务器 sudo service mysql restart;
但是这样修改后默认最大是214,所以还要继续修改。
4、进入目录 /etc/systemd/system/multi-user.target.wants,找到文件mysql.service;
5、sudo vim mysql.service,在 [Service] 最后加入:
LimitNOFILE=65535
LimitNPROC=65535
6、执行下面命令使修改生效:
systemctl daemon-reload
systemctl restart mysql.service
7、登录mysql,使用 show variables like "%max_connections%"; 查看最大连接数,这时发现已经改成5000。