Suggestions on RDS for MySQL Parameter Tuning
Parameters are key configuration items in a database system. Improper parameter settings may adversely affect database performance. This section describes some important parameters for your reference. For details, visit the MySQL official website.
For details on how to modify RDS for MySQL parameters on the console, see Modifying Parameters of an RDS for MySQL Instance.
Sensitive Parameters
The following parameters can result in system security and stability issues if set improperly:
- innodb_flush_log_at_trx_commit
Default value: 1
Function: Controls the balance between strict ACID compliance for commit operations and higher performance. The default setting of 1 is required for full ACID compliance. Logs are written and flushed to disks at each transaction commit. If the value is set to 0, logs are written and flushed to disks once per second. If the value is set to 2, logs are written at each transaction commit and flushed to disks every two seconds.
Impact: If this parameter is not set to 1, data security is not guaranteed. If the system fails, data may be lost.
- sync_binlog
Default value: 1
Function: Controls how often the RDS for MySQL server synchronizes binary logs to the disk. The default setting of 1 requires synchronization of the binary log to the disk at each transaction commit. If the value is set to 0, synchronization of the binary log to the disk is not controlled by the RDS for MySQL server but relies on the OS to flush the binary log to the disk. This setting provides the best performance. However, if a power failure occurs or the OS crashes, all binary log information in binlog_cache will be lost.
Impact: If this parameter is not set to 1, data security is not guaranteed. If the system fails, binary logs may be lost.
- innodb_large_prefix
Default value: OFF
Function: Specifies the maximum length of a single-column index in an InnoDB table.
This parameter is available only for RDS for MySQL 5.6.
Impact: Changing this parameter value during DDL execution may cause primary/standby replication exceptions. Exercise caution when performing this operation.
- If you want to change this parameter value from OFF to ON, change it on read replicas first and then on the primary DB instance.
- If you want to change this parameter value from ON to OFF, change it on the primary DB instance first and then on read replicas.
Performance Parameters
The following parameters can affect database performance:
- The values of innodb_spin_wait_delay and query_alloc_block_size are determined by the DB instance specifications. If you increase their values, database performance may be affected.
- If max_connections is set to a small value, database access will be affected.
- The default values of the following parameters are determined by the DB instance specifications: innodb_buffer_pool_size, max_connections, and back_log. These parameter values are default before being specified.
- The values of innodb_io_capacity_max and innodb_io_capacity are determined by the storage type. These parameter values are default before being specified.
Constraints on Parameter Modification
- When the innodb_adaptive_hash_index and innodb_buffer_pool_size parameters are modified at the same time, the value of innodb_adaptive_hash_index will fail to be changed from OFF to ON.
- The value of innodb_buffer_pool_size must be an integer multiple of the product of innodb_buffer_pool_instances and innodb_buffer_pool_chunk_size.
- If innodb_buffer_pool_instances is set to 2, the value of innodb_buffer_pool_size must be greater than or equal to 1 (unit: GB).
- For MySQL 8.0, if the kernel version is earlier than 8.0.18, the value of max_prepared_stmt_count cannot exceed 1048576.
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.