今天有一台mysql服务器突然连接数暴增,并且等待进程全部被锁...因为问题解决不当,
总结:以后要快速定位错误,布置解决方案

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

或者用

Mysql代码
  1. show full processlist   


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

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

Mysql代码
  1. mysql -e 'show full processlist;' > 111  


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

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

编辑MySQL(和PHP搭配之最佳组合)配置文件 

my.cnf 或者是 my.ini

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

Apache代码
  1. max_connections = 1000  


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

然后用命令:

MySQL(和PHP搭配之最佳组合)admin -uroot -p variables

输入root数据库账号的密码后可看到

Linux代码
  1. | max_connections | 1000 |