文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

超出MySQL最大连接数问题及解决

2023-05-15 15:11

关注

超出MySQL最大连接数问题

如果遇到MySQ连接数超出最大限制了,不要慌,往下看:

通常,mysql的最大连接数默认是100, 最大可以达到16384。

查看最大连接数

show variables like '%max_connections%';

修改最大连接数

方法一:修改配置文件。推荐方法一

进入MySQL安装目录 打开MySQL配置文件 my.ini 或 my.cnf查找 max_connections=100 并将其修改为

max_connections=1000 然后再服务里重起MySQL服务即可.

方法二:命令行修改。不推荐方法二

命令行登录MySQL后。设置新的MySQL最大连接数为200:

MySQL> set global max_connections=200

如果已经连接不上了,先重启MySQL服务后再进行上述操作即可。

这种方式有个问题,就是设置的最大连接数只在mysql当前服务进程有效,一旦mysql重启,又会恢复到初始状态。因为mysql启动后的初始化工作是从其配置文件中读取数据的,而这种方式没有对其配置文件做更改。

MySQL最大连接数,TimeOut配置

MySQL连接数配置

1.MySQL的max_connections参数用来设置最大连接(用户)数。每个连接MySQL的用户均算作一个连接,max_connections的默认值为100左右

1.1查看数据库配置的最大连接数

show variables like "max_connections";

可以使用Navicat或者CMD进行命令查询

Navicat命令页面

CMD操作命令页面

1.2如果实际情况中的最大连接数超过,就会提示TimeOut超出最大请求数

这是我们需要进行配置项的修改

设置调整最大连接数

set global max_connections = 1000;

超出MySQL最大连接数问题及解决

Mysql的连接线程池

1.查看Mysql数据库当前的所有连接线程

show full processlist;

超出MySQL最大连接数问题及解决

图片中可以看到当前数据库的连接线程情况 。其中发现很多的线程都是Sleep状态,这个下面讲到的TimeOut配置会进行管理Sleep线程。

Mysql TimeOut配置

查看Mysql的TimeOut配置

show global variables like '%timeout%';

超出MySQL最大连接数问题及解决

参数名参数作用
delayed_insert_timeout在获取链接时,等待握手的超时时间,只在登录时有效,登录成功这个参数就不管事了。主要是为了防止网络不佳时应用重连导致连接数涨太快,一般默认即可
delayed_insert_timeout这是为MyISAM INSERT DELAY设计的超时参数,在INSERT DELAY中止前等待INSERT语句的时间
innodb_lock_wait_timeout事务遇到锁等待时的Query超时时间。跟死锁不一样,InnoDB一旦检测到死锁立刻就会回滚代价小的那个事务,锁等待是没有死锁的情况下一个事务持有另一个事务需要的锁资源,被回滚的肯定是请求锁的那个Query
innodb_rollback_on_timeout这个参数关闭或不存在的话遇到超时只回滚事务最后一个Query,打开的话事务遇到超时就回滚整个事务
interactive_timeout/wait_timeout一个持续SLEEP状态的线程多久被关闭。线程每次被使用都会被唤醒为activity状态,执行完Query后成为interactive状态,重新开始计时。wait_timeout不同在于只作用于TCP/IP和Socket链接的线程,意义是一样的
net_read_timeout / net_write_timeout这个参数只对TCP/IP链接有效,分别是数据库等待接收客户端发送网络包和发送网络包给客户端的超时时间,这是在Activity状态下的线程才有效的参数
slave_net_timeout这是Slave判断主机是否挂掉的超时设置,在设定时间内依然没有获取到Master的回应就人为Master挂掉了

这里我们设置下Sleep线程的时间,以免线程池被消耗太多

执行修改脚本

set global interactive_timeout=100;
set global wait_timeout=30;

超出MySQL最大连接数问题及解决

执行完成后可以发现全局变量已修改

超出MySQL最大连接数问题及解决

注意:在项目的连接字符中也需要确认是否进行了相关的配置,导致了Mysql连接失败问题

以上设置会马上生效,但是当mysql重启时这个设置会失效,更好的办法是

找到mysqld块,修改或者添加下面的设置:

max_connections=200
wait_timeout=30
interactive_timeout=100

这样修改之后,即便重启mysql也会默认载入这个配置了

关于my.ini文件的路径以及创建

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯