mysql Expression ‘too many connections’

本文介绍了在物联网短连接项目中遇到的'Too many connections'问题及其解决方案。通过检查并修改MySQL的最大连接数、等待超时时间和空闲超时时间,以及批量清理闲置连接来临时解决。此外,还提供了永久修改配置的方法,包括编辑配置文件和调整系统限制,确保即使设备重启也不会丢失设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景: 最近的一个物联网短连接的项目,用的是twisted+pymysql写的,在程序运行的过程中会出现如题错误:too many connections
方法一:
  1. 登录数据库
 	mysql -u root -p 
	回车输入密码进入mysql 
  1. 查看当前连接数
	show processlist; 
	查看连接数,可以发现有很多连接处于sleep状态
	这些其实是暂时没有用的,所以可以kill
  1. 查看最大连接数
	show variables like "max_connections";
	查看最大连接数
	应该是与上面查询到的连接数相同
	才会出现too many connections的情况
  1. .修改最大连接数目
	set GLOBAL max_connections=1000;
	修改最大连接数,
	但是这不是一劳永逸的方法,
	应该要让它自动杀死那些sleep的进程。
  1. 修改空闲超时时间
	show global variables like 'wait_timeout'
	这个数值指的是mysql
	在关闭一个非交互的连接之前要等待的秒数,
	默认是28800s
  1. 修改等待超时时间
	set global wait_timeout=300;
	修改这个数值
	这里可以随意
	最好控制在几分钟内
  1. 修改连接持续时间
	set global interactive_timeout=500;
	修改这个数值
	表示mysql在关闭一个连接之前要等待的秒数
	至此可以让mysql自动关闭那些没用的连接
	但要注意的是
	正在使用的连接到了时间也会被关闭
	因此这个时间值要合适
  1. 批量kill之前没用的sleep连接,在网上搜索的方法对我都不奏效,因此只好使用最笨的办法,一个一个kill
	1.select concat('KILL ',id,';') from information_schema.processlist where user='root'; 先把要kill的连接id都查询出来
	2.复制中间的kill id;内容到word文档
	3.替换掉符号“|”和回车符(在word中查询^p即可查询到回车符)
	4.把修改过的内容复制回终端,最后按回车执行!

方法二:

以上办法,虽然可以解决问题,但是设备重启之后,原来设置的内容也会丢失。下面介绍一个永久更改设置的办法

1、进入目录 /etc/mysql/mysql.conf.d,找到配置文件 mysqld.cnf;

2、sudo vim mysqld.cnf,在 [mysqld] 中修改 max_connections 为5000;

3、重启服务器 sudo service mysql restart;

但是这样修改后默认最大是214,所以还要继续修改。

4、进入目录 /etc/systemd/system/multi-user.target.wants,找到文件mysql.service;

5、sudo vim mysql.service,在 [Service] 最后加入:

LimitNOFILE=65535

LimitNPROC=65535

6、执行下面命令使修改生效:

systemctl daemon-reload

systemctl restart mysql.service

7、登录mysql,使用 show variables like "%max_connections%"; 查看最大连接数,这时发现已经改成5000。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值