常用MySQL5.7配置参数
default_storage_engine:设置默认使用的存储引擎
- 默认值为 INNODB
max_allowed_packet:客户端和服务器之间发送的数据包的最大大小限制
- 默认值为 4M
- 推荐值为 64M - 1G,具体取决于服务器的可用内存和需要处理的数据大小。
join_buffer_size:连接操作缓存大小
- 默认值为 262144(即 256K)
- 推荐值为 128M - 512M,具体取决于系统的总内存量和查询表的大小。
tmp_table_size:临时表大小
- 默认值为 16777216(即 16M)
- 推荐值为 1G 或大于最大单个表所需的空间。
interactive_timeout:交互式会话超时时间,单位为秒
- 默认值为 28800(秒),推荐值根据应用程序的需求而定。
wait_timeout:非交互式会话超时时间,单位为秒
- 默认值为 28800(秒),推荐值根据应用程序的需求而定。
read_buffer_size:读取数据时缓存的大小
- 默认值为 131072(即 128K)
- 推荐值为 128K - 2M,具体取决于系统内存大小和 I/O 负载。
read_rnd_buffer_size:随机读取数据时缓存的大小
- 默认值为 262144(即 256K)
- 推荐值为 256K - 2M,具体取决于系统内存大小和 I/O 负载。
sort_buffer_size:排序操作缓存大小
- 默认值为 262144(即 256K)
- 推荐值为 1M - 256M,具体取决于系统内存大小和排序操作的复杂程度。
key_buffer_size:索引缓存大小
- 默认值为 8388608(即 8M)
- 推荐值为 64M - 1G,具体取决于系统内存和索引大小。
back_log:等待处理连接请求的队列大小
- 默认值为 -1(表示自动调整大小)
- 推荐值为 100 - 1000,具体取决于并发连接数和所需的响应时间。
flush_time:将更新写入磁盘的间隔时间,单位为秒
- 默认值为 0,推荐值根据应用程序的需求而定。
open_files_limit:同时打开的文件描述符数量
- 默认值为 5000,建议将其设置为操作系统允许的最大值。
table_definition_cache:表定义缓存大小
- 默认值为 -1(表示自动调整大小)
- 推荐值为 2000 - 4000,具体取决于表的数量和大小。
max_connections:最大连接数
- 默认值为 151
- 推荐值为 500 - 5000,具体取决于系统硬件和应用程序的分布式程度。
max_connect_errors:客户端连续错误次数达到此值后,会被禁止进一步连接
- 默认值为 100,更具安全要求设置次数。
thread_cache_size:线程缓存大小
- 默认值为 -1(表示自动调整大小)
- 推荐值为 100 - 1000,具体取决于系统中的并发连接数。
innodb_flush_log_at_trx_commit:InnoDB存储引擎日志写入磁盘的时机
- 默认值为 1
- 推荐值为 2 或 0,如果需要更好的性能,则可以将其设置为 2,而不是 1。
innodb_buffer_pool_size:InnoDB存储引擎缓冲池大小
- 默认值为 128M
- 推荐值为系统内存的 50% - 80%。
innodb_log_file_size:InnoDB存储引擎日志文件大小
- 默认值为 48M
- 推荐值为 256M - 2G,具体取决于系统 I/O 负载和事务吞吐量。
innodb_log_buffer_size:InnoDB存储引擎日志缓存大小
- 默认值为 16777216(即 16M)
- 建议将其设置为 innodb_log_file_size 的 25%。
innodb_thread_concurrency:InnoDB存储引擎线程并发度
- 默认值为 0
- 推荐值为 8 - 64,具体取决于应用程序的并发性质。
innodb_autoextend_increment:InnoDB存储引擎自动扩展增量
- 默认值为 64M
- 建议将其设置为 128M - 1G。
innodb_buffer_pool_instances:InnoDB存储引擎缓冲池实例数
- 默认值为 1
- 推荐值为 4 - 12,具体取决于系统内存的大小和 CPU 核心数量。
innodb_concurrency_tickets:InnoDB存储引擎并发票数
- 默认值为 5000
- 推荐值为 1000 - 10000,具体取决于应用程序的并发程度。
innodb_old_blocks_time:InnoDB存储引擎旧数据块保留时间,单位为毫秒
- 默认值为 1000,推荐值根据应用程序的需求而定。
innodb_open_files:InnoDB存储引擎打开文件数
- 默认值为 -1(表示自动调整大小)
- 推荐值取决于您的系统负载和可用内存大小。一般来说,建议将innodb_open_files设置为足够大的值,以便InnoDB存储引擎能够同时处理多个表和索引文件。
innodb_stats_on_metadata:InnoDB存储引擎在获取表元数据时是否收集统计信息
- 默认值为1(开启)
- 对于大型数据库,建议将该参数设置为0(关闭),以减少在执行DDL操作时的开销。
innodb_file_per_table:是否为每个InnoDB表创建单独的数据文件
- 推荐值为1
innodb_checksum_algorithm:InnoDB存储引擎数据校验算法
- 默认值crc32
innodb_lock_wait_timeout:当一个事务等待锁定资源的时间超过此值时,将回滚事务。
- 默认值为50秒
query_cache_size:查询缓存大小
- 默认值为 0
- 建议设置为0,MySQL缓存命中率不高,启用反而浪费时间
slow_query_log:是否记录慢查询日志
- 默认值为 0
- 建议将其设置为 1,以帮助诊断缓慢查询。
long_query_time:指定慢查询的时间阈值,单位为秒
- 默认值为 10(秒),推荐值根据应用程序的需求而定。
lower_case_table_names:处理表名和数据库名时是否区分大小写
- 默认值为 0
- 推荐值为 1,以避免表名大小写不敏感导致的冲突问题。
table_open_cache:可以同时打开多少个表
- 默认值为 2000
- 推荐值为 4000 - 8000,具体取决于表的数量和大小。
autocommit:是否自动提交事务
- 默认值为 1,推荐值根据应用程序的需求而定。
skip_name_resolve:是否对连接的客户端进行DNS解析
- 默认值为 0
- 推荐值为 1,以避免 DNS 查询的性能影响。
transaction_isolation:事务的隔离级别
- 默认值为 REPEATABLE-READ
- 推荐值为 READ-COMMITTED,以提高并发性能。
explicit_defaults_for_timestamp:如何处理TIMESTAMP列的默认值
- 默认值为 0
- 建议将其设置为 1,以防止时间戳列的插入错误。
symbolic-links:是否允许使用符号链接
- 默认值为 1
- 建议将其设置为 0,以提高安全性。