最近写javaee项目的时候,mysql报了too many connections的错误,百度的内容有一些有问题,所以我重新写一下我的解决方法。

mysql -u root -p 回车输入密码进入mysql 

这里写图片描述

show processlist;

查看连接数,可以发现有很多连接处于sleep状态,这些其实是暂时没有用的,所以可以kill掉

show variables like "max_connections";

查看最大连接数,应该是与上面查询到的连接数相同,才会出现too many connections的情况

set GLOBAL max_connections=1000;

修改最大连接数,但是这不是一劳永逸的方法,应该要让它自动杀死那些sleep的进程。

show global variables like 'wait_timeout';

这个数值指的是mysql在关闭一个非交互的连接之前要等待的秒数,默认是28800s

set global wait_timeout=300;

修改这个数值,这里可以随意,最好控制在几分钟内

这里写图片描述

set global interactive_timeout=500;

修改这个数值,表示mysql在关闭一个连接之前要等待的秒数,至此可以让mysql自动关闭那些没用的连接,但要注意的是,正在使用的连接到了时间也会被关闭,因此这个时间值要合适

批量kill之前没用的sleep连接,在网上搜索的方法对我都不奏效,因此只好使用最笨的办法,一个一个kill

select concat('KILL ',id,';') from information_schema.processlist where user='root'; 先把要kill的连接id都查询出来

复制中间的kill id;内容到word文档
替换掉符号“|”和回车符(在word中查询^p即可查询到回车符)
把修改过的内容复制回终端,最后按回车执行!

ERROR 1040: Too many connections问题解决办法

出现此错误的原因,一种是访问量确实很高,MySQL服务器顶不住,这个时候就要考虑增加从服务器分散读压力,另外一种情况是MySQL配置文件中max_connections值过小。

分析原因

mysql的默认连接上只有100,也就是说连接数据超过100 就会有可能出现 Too Many Connections

修改my.cnf配置文件添加并需要重启:

[mysqld]wait_timeout = 600
interactive_timeout = 600

查询MySQL的最大连接数:

mysql> show variables like 'max_connections';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| max_connections | 100 |
+-----------------+-------+
1 row in set (0.00 sec)

查询MySQL响应的最大连接数:

mysql> show global status like 'max_used_connections';
+----------------------+-------+
| Variable_name | Value |
+----------------------+-------+
| Max_used_connections | 5 |
+----------------------+-------+
1 row in set (0.00 sec)

说明:本地环境没什么参考价值,但是就上面的数据而言,MySQL过去所响应的最大连接数小于其允许的最大连接数,所以不会出现1040错误。
MySQL比较理想的最大连接数计算方式为:

max_used_connections / max_connections * 100% ≈ 85%

即最大连接数占上限连接数的85%左右,如果发现比例在10%以下,MySQL服务器连接数上限设置的过高了。

问题找到解决办法

1、mysql -u root -p 进入不了,同样出现上述错误。

2、修改/etc/mysql/my.cnf(ubuntu系统,其他系统在/etc/my.cnf

[mysqld]
port=3306
#socket=MySQL
skip-locking
set-variable = key_buffer=16K
set-variable = max_allowed_packet=1M
set-variable = thread_stack=64K
set-variable = table_cache=4
set-variable = sort_buffer=64K
set-variable = net_buffer_length=2K
set-variable = max_connections=1000

3、重启

代码如下 复制代码

mysql /etc/init.d/mysql restart

搞定了。

总结

MySQL服务器所支持的最大连接数是有上限的,因为每个连接的建立都会消耗内存,因此客户端在连接到MySQL Server处理完相应的操作后,应该断开连接并释放占用的内存。

如果MySQL Server有大量的闲置连接,不仅会白白消耗内存,而且如果连接一直在累加而不断开,最终肯定会达到MySQL Server的连接上限数,这会报'too many connections'的错误。

对于wait_timeout的值设定,应该根据系统的运行情况来判断。在系统运行一段时间后,可以通过show processlist命令查看当前系统的连接状态,如果发现有大量的sleep状态的连接进程,则说明该参数设置的过大,可以进行适当的调整小些。

转载于:https://www.cnblogs.com/luoahong/articles/9003446.html

too many connections 解决方法相关推荐

  1. Too many connections解决方法

    Too many connections解决方法 参考文章: (1)Too many connections解决方法 (2)https://www.cnblogs.com/gomysql/p/3834 ...

  2. Mysql Too many connections解决方法

    检查 # 查看当前所有连接 mysql> show full processlist; # 查看MySQL连接设置 mysql> show variables like '%connect ...

  3. mysql too many connections_mysql too many connections 解决方法

    1.mysql -u root -p 回车输入密码进入mysql 2.show processlist; 查看连接数,可以发现有很多连接处于sleep状态,这些其实是暂时没有用的,所以可以kill掉 ...

  4. MySQL too many connections 解决方法

    mysql出现Too many connections提示一般原因就是你网站连接数超过了你msyql配置的连接数据了,解决办法就是修改一下mysql配置文件中的max_connections参数或修改 ...

  5. 解决Mysql错误Too many connections的方法

    解决Mysql错误Too many connections的方法 参考文章: (1)解决Mysql错误Too many connections的方法 (2)https://www.cnblogs.co ...

  6. Nginx中worker connections问题的解决方法

    这篇文章主要介绍了Nginx中worker connections问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 查看日志,有一个[warn]: 3660#0: 20000 work ...

  7. 解决mysql 1040错误Too many connections的方法

    2019独角兽企业重金招聘Python工程师标准>>> 解决mysql 1040错误Too many connections的方法 1.可能是mysql的max connection ...

  8. 启动tomcat出现too many connections的原因及解决方法

    感谢分享,原文地址:http://blog.sina.com.cn/s/blog_e7e07ec30102vsba.html 一.原因  产生too many connections 的直接原因是因为 ...

  9. mysql1040_解决mysql 1040错误Too many connections的方法

    从官方文档知道linux上面编译安装的mysql默认的连接为100个,这样对于网站的需求来说是远远不够的. mysql官方告诉我们需要修改max_connections的值,那么我们怎么去修改呢?有两 ...

最新文章

  1. 基于人工智能方法的手写数字图像识别_【工程分析】基于ResNet的手写数字识别...
  2. selenium打开chrome浏览器代码
  3. SQL Server 2017 2019 Linux(Centos、Unbuntu16.04、Unbuntu18.04、Unbuntu20.04)安装过程详解
  4. wegame地下城不显示服务器,在电脑端wegame看不到旭旭宝宝?来吧我教你! - 地下城与勇士掌游宝...
  5. 学python的注意点_python学习入门细节知识点
  6. js选中文字兼容性解决
  7. URTracker 试用不过期修改方法
  8. 创业公司研发团队面临的项目管理难题探讨
  9. 5万字、97 张图总结操作系统核心知识点
  10. PXE网络安装Linux操作系统原理与详细过程
  11. 遭遇应用程序正常初始化失败
  12. Linux基础操作命令
  13. html标签-meta
  14. BAT公司 or 创业公司,选择哪个更好?
  15. 关于电话电子邮件诈骗的骨感
  16. 【分布式】分布式系统概述
  17. 算法竞赛进阶指南---0x05(排序)七夕祭
  18. 《Unity 3D脚本编程:使用C#语言开发跨平台游戏》序言
  19. Summers Crafts Broad Role in Reshaping Economy
  20. ibm dsa生成html,IBMxSerial服务器故障诊断工具DSA

热门文章

  1. Android双屏异显的实现
  2. 【密码学】一万字带您走进密码学的世界(上)
  3. 图灵奖得主Sivio Micali的Algorand区块链协议简介
  4. mathematica 可编辑pdf_Mathematica学习笔记[1]
  5. python os 常用方法_python中os常用方法详解
  6. 安卓 camera 调用流程_[Camera]Camera1 open、preview、take picture流程分析(3)
  7. LOJ #2731 [JOI2016春季合宿]Solitaire (DP、组合计数)
  8. xp改mac地址linux,局域网络必备-mac地址修改
  9. mysql语句表_mysql表级sql语句
  10. php tsrmg,php garbage collect