当前位置:首页 > 行业动态 > 正文

如何有效调优RDS for MySQL以提高性能?

RDS for MySQL参数调优建议包括调整缓冲池大小、查询缓存设置、连接数限制等,以优化性能和资源使用。

在RDS MySQL参数调优中,合理配置各项参数对于提升数据库性能至关重要,以下是一些关键参数的调优建议:

如何有效调优RDS for MySQL以提高性能?  第1张

1、back_log

作用:控制未完成连接队列的最大长度。

适用版本:8.0、5.7、5.6、5.5

修改后是否需要重启:是

现象:如果参数过小,应用可能会出现SQLSTATE[HY000] [2002] Connection timed out错误。

修改建议:提高此参数值的大小,建议设置为3000。

2、innodb_autoinc_lock_mode

作用:控制自增主键的锁机制。

适用版本:8.0、5.7、5.6、5.5

修改后是否需要重启:是

现象:在load data(包括INSERT … SELECT和REPLACE … SELECT)场景下若使用自增表锁,则可能导致应用在并发导入数据时出现死锁。

修改建议:建议将该参数值改为2,表示所有情况插入都使用轻量级别的mutex锁(只针对row模式),以避免auto_inc的死锁,同时在INSERT … SELECT的场景下会提升很大的性能。

3、query_cache_size

作用:控制MySQL query cache的内存大小。

适用版本:5.7、5.6、5.5

修改后是否需要重启:否

现象:数据库中有大量的连接状态为checking query cache for query、Waiting for query cache lock、storing result in query cache。

修改建议:RDS默认是关闭query cache功能的,如果您的实例打开了query cache,当出现上述情况后可以关闭query cache。

4、net_write_timeout

作用:等待将一个block发送给客户端的超时时间。

适用版本:8.0、5.7、5.6、5.5

修改后是否需要重启:否

现象:若参数设置过小,可能会导致客户端出现如下错误:the last packet successfully received from the server was milliseconds ago或the last packet sent successfully to the server was milliseconds ago。

修改建议:该参数在RDS中默认设置为60秒,一般在网络条件比较差时或者客户端处理每个block耗时较长时,由于net_write_timeout设置过小导致的连接中断很容易发生,建议增加该参数的大小。

5、tmp_table_size

作用:决定内部内存临时表的最大值,每个线程都要分配,实际起限制作用的是tmp_table_size和max_heap_table_size的最小值。

适用版本:8.0、5.7、5.6、5.5

修改后是否需要重启:否

现象:如果复杂的SQL语句中包含了GROUP BY、DISTINCT等不能通过索引进行优化而使用了临时表,则会导致SQL执行时间加长。

修改建议:如果应用中有很多GROUP BY、DISTINCT等语句,同时数据库有足够的内存,可以增大tmp_table_size(max_heap_table_size)的值提升查询性能。

6、loose_rds_max_tmp_disk_space

作用:用于控制MySQL能够使用的临时文件的大小。

适用版本:5.6、5.5

修改后是否需要重启:否

现象:如果临时文件超出loose_rds_max_tmp_disk_space的取值,则会导致应用出现如下错误:The table ‘/home/mysql/dataxxx/tmp/#sql_2db3_1’ is full。

修改建议:首先需要分析一下导致临时文件增加的SQL语句是否能够通过索引或者其它方式进行优化,如果确定实例的空间足够,则可以提升此参数的值,以保证SQL能够正常执行。

7、loose_tokudb_buffer_pool_ratio

作用:用于控制TokuDB引擎能够使用的buffer内存大小。

适用版本:5.6

修改后是否需要重启:是

现象:无特殊现象。

修改建议:用于控制TokuDB引擎能够使用的buffer内存大小,比如innodb_buffer_pool_size设置为1000MB,tokudb_buffer_pool_ratio设置为50(代表50%),那么TokuDB引擎的表能够使用的buffer内存就是500MB。

FAQs

1、问:用户收到参数主动运维通知的实例会对业务有什么影响?

:用户如果不在控制台中配置确认执行的时间,后台不会进行参数修改的任务下发,并且不会对实例的业务产生影响。

2、问:参数主动运维推荐的参数默认值是否一定会对数据库有优化效果?

:在参数调优建议中推荐的参数默认值,是根据阿里云RDS MySQL历史的经验沉淀出的建议值,每个实例可根据自己实际的业务特点是否采纳。

0