MYSQL经常使用缓存

全局共享内存主要是 MySQL Instance(mysqld进程)以及底层存储引擎用来暂存各类全局运算及可共享的暂存信息,如存储查询缓存的 Query Cache,缓存链接线程的 Thread Cache,缓存表文件句柄信息的 Table Cache,缓存二进制日志的 BinLog Buffer, 缓存 MyISAM 存储引擎索引键的 Key Buffer以及存储 InnoDB 数据和索引的 InnoDB Buffer Pool 等等。下面针对 MySQL 主要的共享内存进行一个简单的分析。mysql

查询缓存(Query Cache):查询缓存是 MySQL 比较独特的一个缓存区域,用来缓存特定 Query 的结果集(Result Set)信息,且共享给全部客户端。经过对 Query 语句进行特定的 Hash 计算以后与结果集对应存放在 Query Cache 中,以提升彻底相同的 Query 语句的相应速度。当咱们打开 MySQL 的 Query Cache 以后,MySQL 接收到每个 SELECT 类型的 Query 以后都会首先经过固定的 Hash 算法获得该 Query 的 Hash 值,而后到 Query Cache 中查找是否有对应的 Query Cache。若是有,则直接将 Cache 的结果集返回给客户端。若是没有,再进行后续操做,获得对应的结果集以后将该结果集缓存到 Query Cache 中,再返回给客户端。当任何一个表的数据发生任何变化以后,与该表相关的全部 Query Cache 所有会失效,因此 Query Cache 对变动比较频繁的表并非很是适用,但对那些变动较少的表是很是合适的,能够极大程度的提升查询效率,如那些静态资源表,配置表等等。为了尽量高效的利用 Query Cache,MySQL 针对 Query Cache 设计了多个 query_cache_type 值和两个 Query Hint:SQL_CACHE 和 SQL_NO_CACHE。当 query_cache_type 设置为0(或者 OFF)的时候不使用 Query Cache,当设置为1(或者 ON)的时候,当且仅当 Query 中使用了 SQL_NO_CACHE 的时候 MySQL 会忽略 Query Cache,当 query_cache_type 设置为2(或者DEMAND)的时候,当且仅当Query 中使用了 SQL_CACHE 提示以后,MySQL 才会针对该 Query 使用 Query Cache。能够经过 query_cache_size 来设置可使用的最大内存空间。算法

链接线程缓存(Thread Cache):链接线程是 MySQL 为了提升建立链接线程的效率,将部分空闲的链接线程保持在一个缓存区以备新进链接请求的时候使用,这尤为对那些使用短链接的应用程序来讲能够极大的提升建立链接的效率。当咱们经过 thread_cache_size 设置了链接线程缓存池能够缓存的链接线程的大小以后,能够经过(Connections - Threads_created) / Connections * 100% 计算出链接线程缓存的命中率。注意,这里设置的是能够缓存的链接线程的数目,而不是内存空间的大小。sql

表缓存(Table Cache):表缓存区主要用来缓存表文件的文件句柄信息,在 MySQL5.1.3以前的版本经过 table_cache 参数设置,但从MySQL5.1.3开始改成 table_open_cache 来设置其大小。当咱们的客户端程序提交 Query 给 MySQL 的时候,MySQL 须要对 Query 所涉及到的每个表都取得一个表文件句柄信息,若是没有 Table Cache,那么 MySQL 就不得不频繁的进行打开关闭文件操做,无疑会对系统性能产生必定的影响,Table Cache 正是为了解决这一问题而产生的。在有了 Table Cache 以后,MySQL 每次须要获取某个表文件的句柄信息的时候,首先会到 Table Cache 中查找是否存在空闲状态的表文件句柄。若是有,则取出直接使用,没有的话就只能进行打开文件操做得到文件句柄信息。在使用完以后,MySQL 会将该文件句柄信息再放回 Table Cache 池中,以供其余线程使用。注意,这里设置的是能够缓存的表文件句柄信息的数目,而不是内存空间的大小。缓存

表定义信息缓存(Table definition Cache):表定义信息缓存是从 MySQL5.1.3 版本才开始引入的一个新的缓存区,用来存放表定义信息。当咱们的 MySQL 中使用了较多的表的时候,此缓存无疑会提升对表定义信息的访问效率。MySQL 提供了 table_definition_cache 参数给咱们设置能够缓存的表的数量。在 MySQL5.1.25 以前的版本中,默认值为128,从 MySQL5.1.25 版本开始,则将默认值调整为 256 了,最大设置值为524288。注意,这里设置的是能够缓存的表定义信息的数目,而不是内存空间的大小。数据结构

二进制日志缓冲区(Binlog Buffer):二进制日志缓冲区主要用来缓存因为各类数据变动操作所产生的 Binary Log 信息。为了提升系统的性能,MySQL 并非每次都是将二进制日志直接写入 Log File,而是先将信息写入 Binlog Buffer 中,当知足某些特定的条件(如 sync_binlog参数设置)以后再一次写入 Log File 中。咱们能够经过 binlog_cache_size 来设置其可使用的内存大小,同时经过 max_binlog_cache_size 限制其最大大小(当单个事务过大的时候 MySQL 会申请更多的内存)。当所需内存大于 max_binlog_cache_size 参数设置的时候,MySQL 会报错:“Multi-statement transaction required more than ‘max_binlog_cache_size’ bytes of storage”。ide

MyISAM索引缓存(Key Buffer):MyISAM 索引缓存将 MyISAM 表的索引信息缓存在内存中,以提升其访问性能。这个缓存能够说是影响 MyISAM 存储引擎性能的最重要因素之一了,经过 key_buffere_size 设置可使用的最大内存空间。

InnoDB 日志缓冲区(InnoDB Log Buffer):这是 InnoDB 存储引擎的事务日志所使用的缓冲区。相似于 Binlog Buffer,InnoDB 在写事务日志的时候,为了提升性能,也是先将信息写入 Innofb Log Buffer 中,当知足 innodb_flush_log_trx_commit 参数所设置的相应条件(或者日志缓冲区写满)以后,才会将日志写到文件(或者同步到磁盘)中。能够经过 innodb_log_buffer_size 参数设置其可使用的最大内存空间。
注:innodb_flush_log_trx_commit 参数对 InnoDB Log 的写入性能有很是关键的影响。该参数能够设置为0,1,2,解释以下:性能

0:log buffer中的数据将以每秒一次的频率写入到log file中,且同时会进行文件系统到磁盘的同步操做,可是每一个事务的commit并不会触发任何log buffer 到log file的刷新或者文件系统到磁盘的刷新操做。ui

1:在每次事务提交的时候将log buffer 中的数据都会写入到log file,同时也会触发文件系统到磁盘的同步;spa

2:事务提交会触发log buffer 到log file的刷新,但并不会触发磁盘文件系统到磁盘的同步。此外,每秒会有一次文件系统到磁盘同步操做。线程

此外,MySQL文档中还提到,这几种设置中的每秒同步一次的机制,可能并不会彻底确保很是准确的每秒就必定会发生同步,还取决于进程调度的问题。实际上,InnoDB 可否真正知足此参数所设置值表明的意义正常 Recovery 仍是受到了不一样 OS 下文件系统以及磁盘自己的限制,可能有些时候在并无真正完成磁盘同步的状况下也会告诉 mysqld 已经完成了磁盘同步。

InnoDB 数据和索引缓存(InnoDB Buffer Pool):InnoDB Buffer Pool 对 InnoDB 存储引擎的做用相似于 Key Buffer Cache 对 MyISAM 存储引擎的影响,主要的不一样在于 InnoDB Buffer Pool 不只仅缓存索引数据,还会缓存表的数据,并且彻底按照数据文件中的数据快结构信息来缓存,这一点和 Oracle SGA 中的 database buffer cache 很是相似。因此,InnoDB Buffer Pool 对 InnoDB 存储引擎的性能影响之大就可想而知了。能够经过 (Innodb_buffer_pool_read_requests - Innodb_buffer_pool_reads) / Innodb_buffer_pool_read_requests * 100% 计算获得 InnoDB Buffer Pool 的命中率。

InnoDB 字典信息缓存(InnoDB Additional Memory Pool):InnoDB 字典信息缓存主要用来存放 InnoDB 存储引擎的字典信息以及一些 internal 的共享数据结构信息。因此其大小也与系统中所使用的 InnoDB 存储引擎表的数量有较大关系。不过,若是咱们经过 innodb_additional_mem_pool_size 参数所设置的内存大小不够,InnoDB 会自动申请更多的内存,并在 MySQL 的 Error Log 中记录警告信息。

这里所列举的各类共享内存,是我我的认为对 MySQL 性能有较大影响的集中主要的共享内存。实际上,除了这些共享内存以外,MySQL 还存在不少其余的共享内存信息,如当同时请求链接过多的时候用来存放链接请求信息的back_log队列等。

相关文章
相关标签/搜索