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

mysql太多连接问题及解决方案,第1张

概述不管是JavaEE开发还是其他,只要是Linux系统下安装的mysql,通常默认最大连接为270。 如果你的客户端连接超过这个数,通常要么是配置文件修改,或者是命令行修改,配置文件修改和命令行修改的区

不管是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方面。

 

总结

以上是内存溢出为你收集整理的mysql太多连接问题及解决方案全部内容,希望文章能够帮你解决mysql太多连接问题及解决方案所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1016194.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存