MySQL 连接数相关参数设置

时间:2023-06-15 19:11:50

当我们的数据库服务器遇到如下的错误:ERROR: Too many connections

一种可能性就是我们的压力确实很大,需要增加服务器硬件资源或者增加数据库服务器。但是大多数情况下是我们的连接数配置不合理造成的。

在MySQL中,有如下几个参数是和连接数配置相关的:

Max_connections

Max_used_connections

Connections

Max_user_connections

Back_log

Max_connect_errors

接下来我们逐一来分析这些参数的意义:

Max_connections:

是指整个数据库服务器所允许的最大连接数,可使用以下命令进行查询:

Show variables like ‘max_connections’;

MySQL 连接数相关参数设置

在Windows平台该数值一般默认为151,如果超过该数值,由于限制那么系统就会产生等待的情况,从而影响系统的并发量和吞吐量。

通常情况下,我们会根据服务器的性能适当的调整一个合适的值,比如500-800,但是要注意该数值的最大值为16384,请不要超过这个值。

由于数据库会为每个连接,分配一定内存资源和缓冲区,通常为每个连接分配256KB资源,所以设置要慎重一些,建议不要超过实际用户的1.5倍。

在我们评估最大连接数数值的时候,我们可以使用以下的一些命令,来查看一下历史数据,提供参考数据:

Show global status like ‘max_used_connection’;

MySQL 连接数相关参数设置

这个命令用于查询,服务器自启动以来运行期间的最大连接数。

show global status like 'Connections';

MySQL 连接数相关参数设置

这个命令可以查询服务器自启动以来的连接数的总数,这是一个累计值,可以查看数据库连接的频率。

通过检测这些数据,我们就能得到是否需要增加Max_connections的证据。

如果max_used_connections 已经等于或者接近Max_connections,那么我们就需要增加数据库的最大值。

按照通用的20/80法则,我们建议留有20%的连接数用于系统备用,即Max_used_connections/Max_connections *100% < 80%。

按照经验,我们会留比较大的连接数,比如留50%的连接数用于备用。

Max_user_connections

是指对每个用户允许的最大连接数。

一般情况下我们都会让其保持默认值,除非有特定的需要或者临时性的用户,我们才做出限制。

该参数会限制单个用户的最大连接值,通常是对单用户并发用户进行限制。

Back_log

show variables like 'back_log';

MySQL 连接数相关参数设置

该参数是用来缓存用户连接的,相当于一个排队的连接池。

在数据库达到最大连接数的时候,新的连接请求会被存放在堆栈中,并等待其他连接释放资源。

如果等待的连接数超过这个值,那么新的连接将不会被接受。

这个数值不能超过系统的TCP/IP连接的监听队列数,否则无效。

Linux系统我们推荐设置为小于512的整数。

注意每个队列会消耗256kb的内存资源。

Max_connect_errors

show variables like 'max_connect_errors';

MySQL 连接数相关参数设置

该参数是指,当连接的错误数达到这个阈值的时候,系统会终止用户的连接服务。

需要使用flush hosts来清除错误,否则就会报错:

Host *** is blocked because of many connection errors.Unblock with ‘mysqladmin flush-hosts’.

当数据库达到这个阈值的时候,数据库认定系统出现了一个错误,并且会阻止该用户后续的请求操作,除非使用命令刷新系统。

如果是内网环境,建议可以将数值设置的高一点,并使用任务机制定期刷新hosts。

Connect_timeout

show variables like '%connect_timeout%';

MySQL 连接数相关参数设置

指定MySQL服务等待应答的时间,如果超时那么客户端会返回一个错误,bad handshake。

在Windows环境下默认值为10秒。

如果是局域网或者高并发的环境下,可以适当提高该数值,比如15-20 秒,以避免出现连接错误。

建议该数值要结合thread_cache_size建议适当提高该数值,以便提高更多的连接数。

Skip_name_resolve

show variables like '%skip_name_resolve%';

MySQL 连接数相关参数设置

该设置是用于提高数据库服务器的连接速度。

MySQL在获得连接请求的时候,会根据请求中的IP地址,来反向查询服务器的主机名,然后再次获取该服务器的IP地址。

如果两次获取的IP地址一致,那么才会建立连接。

按照这种设计,一次连接会耗费较长的时间,主要是一种安全上的验证。

但是我们不推荐在广域网环境下,打开这个设置,以防止黑客的攻击。