INNODB I/O相关配置
记录日志为顺序I/O,刷新日志到数据文件为随机操作。顺序操作性能快于随机IO.
innodb_log_file_size
innodb_log_files_in_group
事务日志总大小:
innodb_log_files_in_group * innodb_log_file_size ,日志为循环写入。
innodb_log_buffer_size :日志不是直接刷新到日志文件,而是先写入log_buffer 内存中。一秒钟刷新一次。一般为 32-128M.
INNODB_FLUSH_LOG_AT_TRX_COMMIT:
0:每秒进行一次log写入操作系统cache,并flush log到磁盘。
1(默认):在每次事务提交时提交执行log写入cache,并flush log到磁盘。
2(建议):每次事务提交,执行log数据写入到cache,每秒执行一次flush log到磁盘。
0和2的区别:
如果mysql进程崩溃了,设置为2是不会丢任何事务。只有在整个服务器宕机时,才会丢失一秒钟的事务。
其他参数
innodb_flush_method=O_DIRECT
INNODB_FILE_PER_TABLE=1
INNODB_DOUBLEWRITE= 1
MYISAM IO配置
delay_key_write :
off:每次写操作后刷新键缓冲中的脏块到磁盘。性能差
on:只对在建表是指定了 delay_key_write 选项的表使用延迟刷新。
all: 对所有的myisam表都是用延迟键写入。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人