您的网站是否显示 MySQL max_connections 达到最大限制错误?
通常,当我们尝试连接到 MySQL 服务器时,MySQL max_connections 值不足会导致 “Too many connections” 错误。
今天,让我们看看我们的支持工程师如何为我们修复这个错误。
什么是 MySQL 最大连接数?
MySQL max_connections 是服务器可以接受的并发客户端连接数。
默认值为 151。但是,在 max_connections 限制之上还有一个额外的默认连接。
通常,这是为具有诊断连接问题的超级权限的数据库用户保留的。
值 151 并不意味着只允许 151 个连接数。
当 MySQL 请求突然激增时,通常是由于流量过大,服务器将无法处理它们。 结果,网站开始显示 MySQL max_connections 达到最大连接错误。
设置正确的 max_connections 值
现在让我们看看我们的 MySQL 工程师如何计算服务器上最大连接数的理想值。
通常,最大连接数取决于每个连接的可用 RAM 和内存使用情况。 并且,计算如下:
Available RAM = Global Buffers + (Thread Buffers x max_connections)
max_connections = (Available RAM - Global Buffers) / Thread Buffers
这里,Global Buffers 包括 key_buffer_size、innodb_buffer_pool_size、innodb_log_buffer_size、innodb_additional_mem_pool_size、net_buffer_size、query_cache_size。
并且,Thread Buffers 包括:sort_buffer_size、myisam_sort_buffer_size、read_buffer_size、join_buffer_size、read_rnd_buffer_size、thread_stack。
获取 buffer 列表及其值:
SHOW VARIABLES LIKE '%buffer%';
此外,我们的工程师在增加 max_connection 值得同时考虑了各种 MySQL 查询、应用程序类型等。
检查默认的最大连接数
登录 MySQL 命令行工具并运行以下命令以获取数据库服务器支持的当前默认最大连接数。
mysql> show variables like "max_connections";
您将看到以下输出。
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| max_connections | 151 |
+-----------------+-------+
增加最大连接数
有两种方法可以增加 MySQL 连接。 这是通过 MySQL 命令行工具将最大连接数更新为 200 的命令,无需重新启动。
mysql> set global max_connections = 200;
上面的命令将在不重启的情况下增加最大连接数,但一旦服务器重启,更改将消失。 此方法可用于增加生产系统(例如网站/应用程序)中的可用连接,而无需重新启动数据库服务器。
要永久增加最大连接数,请打开 my.cnf 文件,
$ sudo vi /etc/my.cnf
根据您的 Linux 发行版和安装类型,my.cnf 文件可能位于以下任何位置。
- /etc/my.cnf
- /etc/mysql/my.cnf
- $MYSQL_HOME/my.cnf
- ~/.my.cnf
在 [mysqld] 部分下添加以下行。
max_connections = 200
现在,如果您重新启动 MySQL 服务器,更改将持存在。