mysql太多连接问题及解决方案

前端之家收集整理的这篇文章主要介绍了mysql太多连接问题及解决方案前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

不管是JavaEE开发还是其他,只要是Linux系统下安装的MysqL,通常默认最大连接为270。

如果你的客户端连接超过这个数,通常要么是配置文件修改,或者是命令行修改配置文件修改和命令行修改的区别是,配置文件,既然是文件通常持久化到硬盘,保存最长,如果是命令行的话,仅仅只能保持在MysqL运行状态,如果一旦MysqL因为某种原因宕机或者关闭了,命令行的方式就失效了。

 

比如我之前一个项目,使用的是SSM框架,在使用过程中最初出现了一个异常:

异常信息为:Too Many Connection

这是关键信息,通常就是MysqL连接数达到最大了。

解决办法一:

执行如下命令:

show variables like '%max_connections%';//查看当前最大连接数是多少,通常默认为270左右


set global max_connections=1000;//设置MysqL最大连接数为1000
show processlist;// 该命令可以查看当前连接MysqL的客户进程 

show gobal status like 'Thread%';// 可以查看当前MysqL线程(其中可获得客户进程信息)

解决办法发弊端:如果一旦MysqL重启,将会导致失效。

 

解决办法二:

进入MysqL安装目录 打开MysqL配置文件 my.ini 或 my.cnf,找到 max_connections=270

将其修改为 max_connections=1000 

然后重启MysqL后,执行:

show variable like '%max_connection%';

如果显示最大连接数为1000,表示修改成功,如果不是就表示修改失效,我之前通过这种方式修改,但是没有成功,最后只得通过命令行的形式修改,也就是第一种解决方案。

 

这两种是比较常用的、通用的解决方案。如果你的服务器是centos或者ubuntu关于MysqL的相关的设置可以自行博客搜索

不过,通常的话,没有这个必要。因为MysqL的连接数你可以设置很大很大,但是不一定有用,就好比生态系统一样,每个生态系统的构成都不一样,小的大的,生态系统的自我调节能力或者自我恢复能力、抗击外来风险能力都不一样。而MysqL也同理,就好比生态系统,不能让某一类植物或者动物疯狂生长,这回导致生态失衡,而MysqL里面的很多参数设置也不能随便乱调,必须考虑服务器和业务,如果业务过于庞大复杂,就不是一台服务器或者一台MysqL优化就能搞定的事情。MysqL主要的两大瓶颈就是cpu和I/O方面。

 

猜你在找的Linux相关文章