too many connections 解决方法
最近写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 解决方法相关推荐
- Too many connections解决方法
Too many connections解决方法 参考文章: (1)Too many connections解决方法 (2)https://www.cnblogs.com/gomysql/p/3834 ...
- Mysql Too many connections解决方法
检查 # 查看当前所有连接 mysql> show full processlist; # 查看MySQL连接设置 mysql> show variables like '%connect ...
- mysql too many connections_mysql too many connections 解决方法
1.mysql -u root -p 回车输入密码进入mysql 2.show processlist; 查看连接数,可以发现有很多连接处于sleep状态,这些其实是暂时没有用的,所以可以kill掉 ...
- MySQL too many connections 解决方法
mysql出现Too many connections提示一般原因就是你网站连接数超过了你msyql配置的连接数据了,解决办法就是修改一下mysql配置文件中的max_connections参数或修改 ...
- 解决Mysql错误Too many connections的方法
解决Mysql错误Too many connections的方法 参考文章: (1)解决Mysql错误Too many connections的方法 (2)https://www.cnblogs.co ...
- Nginx中worker connections问题的解决方法
这篇文章主要介绍了Nginx中worker connections问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 查看日志,有一个[warn]: 3660#0: 20000 work ...
- 解决mysql 1040错误Too many connections的方法
2019独角兽企业重金招聘Python工程师标准>>> 解决mysql 1040错误Too many connections的方法 1.可能是mysql的max connection ...
- 启动tomcat出现too many connections的原因及解决方法
感谢分享,原文地址:http://blog.sina.com.cn/s/blog_e7e07ec30102vsba.html 一.原因 产生too many connections 的直接原因是因为 ...
- mysql1040_解决mysql 1040错误Too many connections的方法
从官方文档知道linux上面编译安装的mysql默认的连接为100个,这样对于网站的需求来说是远远不够的. mysql官方告诉我们需要修改max_connections的值,那么我们怎么去修改呢?有两 ...
最新文章
- 基于人工智能方法的手写数字图像识别_【工程分析】基于ResNet的手写数字识别...
- selenium打开chrome浏览器代码
- SQL Server 2017 2019 Linux(Centos、Unbuntu16.04、Unbuntu18.04、Unbuntu20.04)安装过程详解
- wegame地下城不显示服务器,在电脑端wegame看不到旭旭宝宝?来吧我教你! - 地下城与勇士掌游宝...
- 学python的注意点_python学习入门细节知识点
- js选中文字兼容性解决
- URTracker 试用不过期修改方法
- 创业公司研发团队面临的项目管理难题探讨
- 5万字、97 张图总结操作系统核心知识点
- PXE网络安装Linux操作系统原理与详细过程
- 遭遇应用程序正常初始化失败
- Linux基础操作命令
- html标签-meta
- BAT公司 or 创业公司,选择哪个更好?
- 关于电话电子邮件诈骗的骨感
- 【分布式】分布式系统概述
- 算法竞赛进阶指南---0x05(排序)七夕祭
- 《Unity 3D脚本编程:使用C#语言开发跨平台游戏》序言
- Summers Crafts Broad Role in Reshaping Economy
- ibm dsa生成html,IBMxSerial服务器故障诊断工具DSA
热门文章
- Android双屏异显的实现
- 【密码学】一万字带您走进密码学的世界(上)
- 图灵奖得主Sivio Micali的Algorand区块链协议简介
- mathematica 可编辑pdf_Mathematica学习笔记[1]
- python os 常用方法_python中os常用方法详解
- 安卓 camera 调用流程_[Camera]Camera1 open、preview、take picture流程分析(3)
- LOJ #2731 [JOI2016春季合宿]Solitaire (DP、组合计数)
- xp改mac地址linux,局域网络必备-mac地址修改
- mysql语句表_mysql表级sql语句
- php tsrmg,php garbage collect