mysql:解决too many connections 连接数过多问题

在这里插入图片描述
今天做并发测试,导致数据库连接数过多,无法正常使用!

解决办法:
1.查询连接(可能查询不了,要先关闭几张表或者关掉一些进程)
– 当前连接进程数
show full processlist ;

2.把要关闭的连接写入一个文件kill_6.txt,注意路径必须是指定的目录;

select concat(‘KILL ‘,id,’;’) from information_schema.processlist where user=‘root’ into outfile ‘/var/lib/mysql-files/kill_6.txt’;

补充:执行show variables like ‘%secure%’;若secure_file_priv =null 则无法写入,secure_file_priv 有一个路径,则可将文件写入。
在这里插入图片描述
3.登陆mysql命令行,执行:source /var/lib/mysql-files/kill_6.txt;(需要确保此路径下面存在文件kill_6.txt);
在这里插入图片描述

其它方法:
1.设置最大连接数(max_connections ),默认是100;
2.设置连接数过期时间(wait_timeout ),不能太短,也不能过长;
3.程序里及时关闭连接;

my.cnf文件修改字段,如下:
#MySQL 服务所允许的同时会话数的上限,其中一个连接将被SUPER权限保留作为管理员登录。 即便已经达到了连接数的上限.
max_connections = 200

#指定一个请求的最大连接时间。
wait_timeout = 30

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章