InnoDB缓冲池是一个内存区域,用于保存InnoDB表、索引和其他辅助缓冲区的缓存数据 。为了提高大容量读取操作的效率,缓冲池被划分为 可能包含多行的页面。为了缓存管理的效率,缓冲池被实现为页链表;使用LRU算法的变体,很少使用的数据会从缓存中老化 。
缓冲池的大小对系统性能很重要:
系统 innodb_buffer_pool_size 变量定义缓冲池大小。通常,推荐 innodb_buffer_pool_size 值为系统内存的 50% 到 75%。
innodb_buffer_pool_size 可以在服务器运行时动态配置。
在具有大量内存的系统上,您可以通过将缓冲池划分为多个 缓冲池实例来提高并发性。系统变量定义缓冲池实例的 innodb_buffer_pool_instances 数量。
太小的缓冲池可能会导致过度搅动,因为页面从缓冲池中刷新,只是在短时间内再次需要。
过大的缓冲池可能会因为内存竞争而导致交换。
所有线程共享MyISAM 密钥缓冲区。key_buffer_size系统变量决定了它的大小 。
对于服务器打开的每个MyISAM表,索引文件打开一次;对于访问该表的每个并发运行的线程,数据文件打开一次。对于每个并发线程,分配一个表结构、每列的列结构和一个大小的缓冲区 (其中是最大行长度,不包括 列)。一 列需要五到八个字节加上 数据的长度。存储引擎维护一个额外的行缓冲区供内部使用 。
如果内部内存临时表变得太大(由 tmp_table_size和 max_heap_table_size 系统变量确定),MySQL 会自动将表从内存转换为磁盘格式。磁盘临时表使用 internal_tmp_disk_storage_engine 系统变量定义的存储引擎。
对于使用MEMORY显式创建的表CREATE