MySQL 的 max_connections 参数用来设置最大连接数。每个连接 MYSQL 的客户端均算作一个连接。当连接请求大于默认连接数后,就会出现无法连接数据库的错误,因此我们需要把它适当调大一些。在使用 MySQL 数据库的时候,经常会遇到一个问题,就是“Can not connect to MySQL server. Too many connections” 错误,这是因为访问MySQL且还未释放的连接数已经达到 MySQL 的上限。
MySQL 会保留一个用于管理员(SUPER)登陆的连接,用于管理员连接数据库进行维护操作,即使当前连接数已经达到了max_connections。因此MySQL的实际最大可连接数为max_connections+1;
增加max_connections参数的值,不会占用太多系统资源。系统资源(CPU、内存)的占用主要取决于查询的密度、效率等;
mysql> show variables like "%max_connections%";
±----------------±------+
| Variable_name | Value|
±----------------±------+
| max_connections| 151 |
±----------------±------+
mysql> show global status like 'Max_used_connections';
+----------------------+-------+
| Variable_name | Value |
+----------------------+-------+
| Max_used_connections | 80 |
+----------------------+-------+
可以看到服务器响应的最大连接数为 80,远远低于MySQL服务器允许的最大连接数值。对于MySQL服务器最大连接数值的设置范围比较理想的是:服务器响应的最大连接数值占服务器上限连接数值的比例值在10%以上,如果在10%以下,说明MySQL服务器最大连接上限值设置过高。
常用的修改最大连接数的两种方式如下:
第一种:命令行修改最大连接数(max_connections),设置最大连接数为1000。
mysql> set global max_connections = 1000;
这种方式有个问题,就是设置的最大连接数只在 MySQL 当前服务进程有效,一旦MySQL重启,又会恢复到初始状态。因为MySQL启动后的初始化工作是从其配置文件中读取数据的,而这种方式没有对其配置文件做更改。
第二种 :通过修改配置文件来修改MySQL最大连接数(max_connections)。
打开MySQL配置文件 my.ini 或 my.cnf 查找 max_connections 并修改为max_connections=1000,重启MySQL服务即可。