服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - 超出MySQL最大连接数问题及解决

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

2023-05-16 15:46来齐 Mysql

这篇文章主要介绍了超出MySQL最大连接数问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

超出MySQL最大连接数问题

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

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

查看最大连接数

?
1
show variables like '%max_connections%';

修改最大连接数

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

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

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

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

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

?
1
MySQL> set global max_connections=200

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

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

MySQL最大连接数,TimeOut配置

MySQL连接数配置

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

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

?
1
show variables like "max_connections";

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

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

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

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

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

设置调整最大连接数

?
1
set global max_connections = 1000;

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

Mysql的连接线程池

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

?
1
show full processlist;

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

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

Mysql TimeOut配置

查看Mysql的TimeOut配置

?
1
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线程的时间,以免线程池被消耗太多

执行修改脚本

?
1
2
set global interactive_timeout=100;
set global wait_timeout=30;

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

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

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

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

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

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

?
1
2
3
max_connections=200
wait_timeout=30
interactive_timeout=100

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

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/m0_46528706/article/details/118578529

延伸 · 阅读

精彩推荐
  • MysqlMysql中tinyint(1)和tinyint(4)的区别详析

    Mysql中tinyint(1)和tinyint(4)的区别详析

    这篇文章主要给大家介绍了关于Mysql中tinyint(1)和tinyint(4)区别的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值...

    IT盛夏的果实8032022-09-26
  • MysqlMysql启动与数据库的创建方法[图文]

    Mysql启动与数据库的创建方法[图文]

    Mysql启动与数据库的创建方法,mysql数据库入门 ...

    MYSQL教程网2272019-11-29
  • MysqlMySQL超详细实现用户管理实例

    MySQL超详细实现用户管理实例

    MySQL 是一个多用户数据库,具有功能强大的访问控制系统,可以为不同用户指定不同权限。在前面的章节中我们使用的是 root 用户,该用户是超级管理员,...

    一念去殇8512022-11-07
  • Mysqlmysql 索引分类以及用途分析

    mysql 索引分类以及用途分析

    MySQL索引分为普通索引、唯一性索引、全文索引、单列索引、多列索引等等。这里将为大家介绍着几种索引各自的用途。 ...

    MYSQL教程网6242019-11-22
  • Mysqlphp mysql连接数据库实例

    php mysql连接数据库实例

    这篇文章主要介绍了php mysql连接数据库实例,需要的朋友可以参考下...

    jianqingwang3532020-06-26
  • MysqlMySQL基础教程之DML语句详解

    MySQL基础教程之DML语句详解

    DML 语句是指对数据库中表的记录进行的操作,下面这篇文章主要给大家介绍了关于MySQL基础教程之DML语句的相关资料,文中通过实例代码介绍的非常详细,需要...

    持行非就10032022-02-10
  • Mysqlmysql 8.0.15 winx64解压版图文安装教程

    mysql 8.0.15 winx64解压版图文安装教程

    这篇文章主要为大家详细介绍了mysql 8.0.15 winx64解压版图文安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    WistWillLee5392020-09-28
  • MysqlMysql中的Btree与Hash索引比较

    Mysql中的Btree与Hash索引比较

    这篇文章主要介绍了Mysql中的Btree与Hash索引比较,本文起讲解了B-Tree 索引特征、Hash 索引特征等内容,需要的朋友可以参考下 ...

    MYSQL教程网2362020-04-30