zoukankan      html  css  js  c++  java
  • 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方面。

  • 相关阅读:
    LOJ #6008. 「网络流 24 题」餐巾计划
    P2144 [FJOI2007]轮状病毒
    随记
    1010: [HNOI2008]玩具装箱toy(斜率优化)
    HDU 3507 Print Article(斜率优化)
    4819: [Sdoi2017]新生舞会(分数规划)
    POJ 2976 Dropping tests(01分数规划)
    spoj 104 Highways(Matrix-tree定理)
    dp专练
    4152: [AMPPZ2014]The Captain
  • 原文地址:https://www.cnblogs.com/youcong/p/9367878.html
Copyright © 2011-2022 走看看