日期:2014-05-16  浏览次数:20723 次

查看修改mysql连接数,打印进程

今天有一台mysql服务器突然连接数暴增,并且等待进程全部被锁...因为问题解决不当,导致被骂...OTL

总结:以后要快速定位错误,布置解决方案

登录到mysql客户端后,使用status命令也能获得thread连接数以及当前连接的id

或者用

show full processlist
?

看一下所有连接进程,注意查看进程等待时间以及所处状态 是否locked

如果进程过多,就把进程打印下来,然后查看

mysql -e 'show full processlist;' > 111
?

查找非locked的进程,一般就是当前执行中卡死,导致后面的进程排队的原因。

另外,修改mysql最大连接数的方法:

编辑MySQL(和PHP搭配之最佳组合)配置文件 
my.cnf 或者是 my.ini

在[MySQL(和PHP搭配之最佳组合)d]配置段添加:

max_connections = 1000
?

保存,重启MySQL(和PHP搭配之最佳组合)服务。

然后用命令:

MySQL(和PHP搭配之最佳组合)admin -uroot -p variables 
?
输入root数据库账号的密码后可看到
| max_connections | 1000 |
?