如何轻松解决MYSQL数据库连接过多的错误

如何轻松解决MYSQL数据库连接过多的错误,第1张

1、MySQL数据库系统允许的最大可连接数max_connections。这个参数是可以设置的。如果不设置,默认是100。最大是16384。

2、数据库当前的连接线程数threads_connected。这是动态变化的。

查看max_connections、max_connections的办法见后。

如果

threads_connected

==

max_connections

时,数据库系统就不能提供更多的连接数了,这时,如果程序还想新建连接线程,数据库系统就会拒绝,如果程序没做太多的错误处理,就会出现类似强坛的报错信息。

因为创建和销毁数据库的连接,都会消耗系统的资源。而且为了避免在同一时间同时打开过多的连接线程,现在编程一般都使用所谓数据库连接池技术。

但数据库连接池技术,并不能避免程序错误导致连接资源消耗殆尽。

这种情况通常发生在程序未能及时释放数据库连接资源或其他原因造成数据库连接资源不能释放,但强坛系统估计不会发生这种低级的编程错误。

该错误的简便的检查办法是,在刷新强坛页面时,不断监视threads_connected的变化。如果max_connections足够大,而

threads_connected值不断增加以至达到max_connections,那么,就应该检查程序了。当然,如果采用数据库连接池技术,

threads_connected增长到数据库连接池的最大连接线程数时,就不再增长了。

从强坛出错的情况看,更大的可能性是数据库系统没能进行适当地配置。下面提出一点建议。供参考

让你们的工程师把MySQL的最大允许连接数从默认的100调成32000。这就不会老出现连接过多的问题了。

查看max_connections

进入MySQL,用命令:

show

variables

查看数据库最大可连接数的变量值:

max_connections

查看threads_connected

进入MySQL,用命令:

show

status

查看当前活动的连接线程变量值:

threads_connected

设置max_connections

设置办法是在my.cnf文件中,添加下面的最后红色的一行:

[mysqld]

port=3306

#socket=MySQL

skip-l

如何实时查看mysql当前连接数?

1、查看当前所有连接的详细资料:

./mysqladmin -uadmin -p -h10.140.1.1 processlist

2、只查看当前连接数(Threads就是连接数.):

./mysqladmin -uadmin -p -h10.140.1.1 status

、查看当前所有连接的详细资料:

mysqladmin -uroot -proot processlist

D:\MySQL\bin>mysqladmin -uroot -proot processlist

+-----+------+----------------+---------+---------+------+-------+------------------+

| Id | User | Host | db | Command | Time | State | Info |

+-----+------+----------------+---------+---------+------+-------+------------------+

| 591 | root | localhost:3544 | bbs | Sleep | 25 | | |

| 701 | root | localhost:3761 | | uery | 0 | | show processlist |

+-----+------+----------------+---------+---------+------+-------+------------------+

2、只查看当前连接数(Threads就是连接数.):

mysqladmin -uroot -proot status

D:\MySQL\bin>mysqladmin -uroot -proot status

Uptime: 2102 Threads: 3 Questions: 15531 Slow queries: 0 Opens: 0 Flush tab

les: 1 Open tables: 61 Queries per second avg: 7.389

3、修改mysql最大连接数:

打开my.ini,修改max_connections=100(默认为100)。

今天有一台mysql服务器突然连接数暴增,并且等待进程全部被锁...因为问题解决不当,导致被骂...OTL

总结:以后要快速定位错误,布置解决方案

登录到mysql客户端后,使用status命令也能获得thread连接数以及当前连接的id

或者用

show full processlist

看一下所有连接进程,注意查看进程等待时间以及所处状态 是否locked

如果进程过多,就把进程打印下来,然后查看

mysql -e 'show full processlist' >111

查找非locked的进程,一般就是当前执行中卡死,导致后面的进程排队的原因。

另外,修改mysql最大连接数的方法:

编辑MySQL(和PHP搭配之最佳组合)配置文件 

my.cnf 或者是 my.ini

在[MySQL(和PHP搭配之最佳组合)d]配置段添加:

max_connections = 1000

保存,重启MySQL(和PHP搭配之最佳组合)服务。

然后用命令:

MySQL(和PHP搭配之最佳组合)admin -uroot -p variables

输入root数据库账号的密码后可看到

| max_connections | 1000 |

查看MySQL连接数和当前用户Mysql连接数

先用管理员身份进入mysql提示符。

#mysql -uroot -pxxxx

mysql>show processlist可以显示前100条连接信息 show full processlist可以显示全部。随便说下,如果用普通账号登录,就只显示这用户的。注意命令后有分号。

如果我们想查看这台服务器设置。 #vi /etc/my.cnf

set-variable=max_user_connections=30 这个就是单用户的连接数

set-variable=max_connections=800 这个是全局的限制连接数


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7837807.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-10
下一篇 2023-04-10

发表评论

登录后才能评论

评论列表(0条)

保存