不管是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太多连接问题及解决方案所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)