mysql连接数过多 解决方案

原文链接         https://www.cnblogs.com/lazytomato/p/7428100.html

1、 查看当前连接数

./mysqladmin -uroot -p1234.com status

Uptime: 1370150 Threads: 1 (当前连接数) Questions: 79 Slow queries: 0 Opens: 33 Flush tables: 1 Open tables: 26 Queries per second avg: 0.000

./mysql -uroot -p1234.com -e 'show status' | grep -i  Threads 
Delayed_insert_threads    0
Slow_launch_threads    0
Threads_cached    1
Threads_connected    1
Threads_created    2
Threads_running    1 ##(当前连接数)

mysql> show status like 'Threads%';
+-------------------+-------+
| Variable_name    | Value |
+-------------------+-------+
| Threads_cached    | 1    |
| Threads_connected | 1    |
| Threads_created  | 2    |
| Threads_running  | 1    |   ###当前连接数
+-------------------+-------+
rows in set (0.00 sec)

2、 查看最大连接数

[root@xxx bin]# ./mysql -uroot -p1234.com -e 'show variables' | grep max_connections max_connections 500

mysql> show global variables like 'max_conn%';
+--------------------+-------+
| Variable_name      | Value |
+--------------------+-------+
| max_connect_errors | 10    |
| max_connections    | 500  |## 最大连接数
+--------------------+-------+
rows in set (0.00 sec)

解决方法

方法1:

使用gdb工具 不用进入数据库,不用重启数据库 方法如下:

[root@xxx bin]# gdb -p $(cat /data/mydata/xxx.pid) -ex "set max_connections=500" -batch  
[New LWP 7667]
[New LWP 4816]
[New LWP 341]
[New LWP 338]
[New LWP 337]
[New LWP 336]
[New LWP 335]
[New LWP 331]
[New LWP 330]
[New LWP 329]
[New LWP 328]
[New LWP 327]
[New LWP 326]
[New LWP 325]
[New LWP 324]
[New LWP 323]
[New LWP 322]
[Thread debugging using libthread_db enabled]
0x00000035654df1b3 in poll () from /lib64/libc.so.6

查看mysql pid位置的方法

 

在配置文件 my.cnf里查找

用 ps -ef | grep mysql 查找

mysql> show variables like '%pid%';
+---------------+----------------------+
| Variable_name | Value                |
+---------------+----------------------+
| pid_file      | /data/mydata/xxx.pid |
+---------------+----------------------+
row in set (0.00 sec)

修改完毕后 ,尝试重新进入数据库,并查看链接数

这种方法设置后,只是暂时的,数据库重启后,会变为原来的数值,要想永久,设置完后修改配置文件my.cnf

方法2

 

前提是还可以进入数据库

进入数据库

设置新的最大连接数为200:mysql> set GLOBAL max_connections=200

显示当前运行的Query:mysql> show processlist

显示当前状态:mysql> show status

退出客户端:mysql> exit

这种方法设置后,只是暂时的,数据库重启后,会变为原来的数值,要想永久,设置完后修改配置文件my.cnf

方法3:

 

需要重启数据库

修改 my.conf 

max_connection = 1000;

模拟mysql连接数过多

#!/bin/bash
set j=2
while true 
do
        let "j=j+1"
/usr/local/mysql/bin/mysqlslap -a -c 500 -i 10 -uroot -p1234.com
done

运行此脚本  ,然后导致mysql连接数过多无法连接,多试几次确定无法连接  再用gdb工具测试

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL连接数过多的情况有多种可能性。常见的情况包括没有正确关闭连接,导致连接数不断增,当连接数达到最大限制时,会出现"Too many connections"错误。另外,在某些情况下,MySQL的默认最大连接数可能会被占用,导致无法通过登录MySQL来调整参数来处理这个错误。 要解决此问题,可以采取以下方法: 1. 检查代码中的mysql_connectmysql_close函数是否正确使用。确保在每次使用完数据库连接后都调用了mysql_close来关闭连接,释放资源。 2. 使用命令行工具或者通过查询系统变量的方式,确认当前MySQL的最大连接数设置。可以通过以下命令登录MySQL查询最大连接数: ``` sudo mysql -uroot -p ``` 然后输入密码,如果出现"ERROR 1040 (00000): Too many connections"错误,说明当前连接数已经达到了最大限制。 3. 查看当前MySQL连接情况。可以通过以下方式查看当前连接数和已经建立的连接数: ``` SHOW STATUS LIKE 'Threads_connected'; ``` 这将显示当前连接数。如果连接数过多,可以通过以下命令查看当前所有的连接: ``` SHOW PROCESSLIST; ``` 这将显示当前所有的连接和相关信息,包括连接的状态、用户和主机等。 4. 根据现有的连接数情况,评估是否需要增最大连接数限制。如果连接数经常达到最大限制,可以考虑增最大连接数。可以通过修改MySQL的配置文件my.cnf来设置最大连接数参数max_connections。找到该配置文件并添或修改以下行: ``` max_connections = 200 ``` 然后重新启动MySQL服务。 需要注意的是,增最大连接数可能会对服务器资源造成负担,因此在增前需要评估服务器的性能和资源使用情况。 综上所述,解决MySQL连接数过多的问题,一方面需要检查代码中是否正确关闭连接,另一方面可以通过查询当前连接状态和最大连接数设置来评估并调整最大连接数限制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值