`
kisseveryone
  • 浏览: 198016 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

【转】合理配置MySQL缓存 提高缓存命中率

 
阅读更多
众所周知,系统读取数据时,从内存中读取要比从硬盘上速度要快好几百倍。故现在绝大部分应用系统,都会最大程度的使用缓存(内存中的一个存储区域),来提高系统的运行效率。MySQL数据库也不例外。在这里,笔者将结合自己的工作经验,跟大家探讨一下,MySQL数据库中缓存的管理技巧:如何合理配置MySQL数据库缓存,提高缓存命中率。



一、什么时候应用系统会从缓存中获取数据?

  数据库从服务器上读取数据时,可以从硬盘的数据文件中获取数据,也可以从数据库缓存中读取数据。现在数据库管理员需要搞清楚的是,在什么样的情况下,系统是从缓存中读取数据,而不是从硬盘的数据文件中读取数据?

  简单的说,数据缓存就是内存中的一块存储区域,其存储了用户的SQL文本以及相关的查询结果。通常情况下,用户下次查询时,如果所使用的SQL文本是相同的,并且自从上次查询后,相关的纪录没有被更新过,此时数据库就直接采用缓存中的内容。从这个原则中,可以看到如果要直接使用缓存中的数据,至少要满足以下几个条件。

  一是所采用的SQL文本是相同的。当前后两次用户使用了相同的SQL语句(假设不考虑其他条件),则服务器会从缓存中读取结果,而不需要再去解析和执行SQL语句。这里需要注意的是,这里的SQL文本必须一次不差的完全相同。如果前后两次查询,使用了不同的查询条件。如第一次查询时没有输入Where条件语句。后来发现数据量过多,利用了Where条件了过滤查询的结果。此时即使最后的查询结果是相同的,系统仍然是从数据文件中获取数据,而不是从数据缓存中。再如,Select后面所使用的字段名称也必须是相同的。如果有一个字段名称不同或者前后两次查询所使用的字段数量不同,则系统都会认为是不同的SQL语句,而重新解析并查询。

  二是从数据缓存的角度考虑,大小写是不敏感的。如前后两次查询时,采用的字段名称可能只有大小写的差异。如第一次使用的是大小,第二次使用的是小写,这系统认为仍然是相同的SQL语句。或者说关键字大小写等等这都是不敏感的。

  三是要满足二次查询之间,数据记录包括表结构都没有被更改过。如果记录所在的标更改了,如增加了一个字段等等,此时使用这个表的所有缓冲数据系统将自动清空。这里需要注意,这里指的更改是一个广义的更改,包括表中任何数据或者结果的改变。举一个简单的例子,第一次查询时用户需要查询2010年的出货数据。查询后有用户在这个表中插入了一条2011年1月份的出货信息。然后又有用户需要查询2010年的出货信息。使用的SQL语句与第一次查询时完全相同。在这种情况下,数据库系统会使用缓存中的数据吗?答案是否定的。因为当中间用户插入一条记录时,系统会自动清空跟这个表相关的所有缓存记录。当第二次查询时,缓存中已经没有这张表对应的缓存信息。此时就需要重新解析并查询。

  四是需要注意,默认字符集对缓存命中率的影响。通常情况下,如果客户端与服务器之间所采用的默认字符集不同,则即使查询语句相同、在两次查询之间记录与表结构也没有被更改,系统仍然认为是不同的查询。对于这一点需要特别的注意,大家比较容易忽视。

  二、提高缓存命中率的建议。

  从上面的条件分析中可以看出,利用缓存中的数据具有比较严格的条件。其实这些条件也是合情合理的。主要是为了保障数据的一致性。对以上这些条件有深入的认识之后,现在数据库管理员需要考虑的是,如何来提高这个缓存的命中率?对此笔者有如下几个建议。

  一是在配置时,客户端与服务器端要使用相同的字符集。如果客户端(或者说第三方工具)与服务器端使用的字符集不同,那么任何情况下都不会使用缓存功能。特别在国内,需要用到中文的字符集。此时特别需要注意,客户端默认字符集要与服务器端的默认字符集相同。注意,这里是相同,而不是兼容。有时候即使采用了不同的字符集,客户端上仍然可以正常显示。这主要是因为有些字符集虽然不相同,但是是相互兼容的。在缓存管理上,需要相同,光兼容还不行。

  二是在客户端上,要固化查询的语句。如现在有财务人员和采购人员同时从系统中查询11月份的出货数据。显然他们岗位职责不同,所需要字段的内容是不同的。此时在客户端出,可以允许用户设置自己所需要的表单格式。但是笔者建议,后台所采用的SQL语句最好是相同的。这里数据会经过三个渠道:后台数据库、客户端、用户。笔者的意识时,后台数据库与客户端之间的交互采用相同的SQL语句。然后客户端与用户之间进行交互时,根据用户定义的格式(包括字段前后的排列、不包括查询条件语句的差异)向用户显示数据。此时由于采用了相同的SQL语句(只是用户对于显示格式的要求不同),从而可以提高应用系统的查询效率。

  三是提高内存中缓存的配置,来提高命中率。一般在服务器启动时,操作系统会跟数据库软件协商缓存空间的大小。当缓存工作不足时,缓存中最旧的缓存记录会被最新的消息所覆盖。可见,如果能够提高缓存空间,就可以提高命中率。这就好像打靶,目标多了,命中的几率也会高许多。不过用户的并发数越多,这个设置的效果会越不明显。

  四是通过分区表可以提高缓存的命中率。在上面的条件分析中,大家可以看到,只要所查询的表中插入了一条记录,系统就会清空缓存记录。现在以查询出货记录为例。出货记录表每天都在更新,而用户在年初时,会经常需要查询上一年的出货记录。此时由于这个表中的数据每个小时都在更新,那么缓存中的信息会不断的被情况。此时缓存的命中率显然不会很高。针对这种情况,笔者建议可以采用分区表。如可以通过系统设置,将2010年的出货记录单独存放在一个出货的分区表中。即每一个年度都使用一张单独的分区表。此时2011年的纪录,就不会影响到2010年的分区表。此时如果用户重复查询2010年的出货信息,只要其使用的SQL语句相同(没有采用不同的查询条件),那么就可以享受缓存机制所带来的效益,提高应用系统的查询效果。。

  三、多个应用对缓存的影响。

  通常情况下,MySQL数据库的缓存是根据服务器内存的大小自动分配的。如果一台服务器上只有一个MySQL应用,那么固然最好。不过在实际工作中,为了降低信息化投资的成本,往往会在同一台服务器上布置多个信息化应用。由于其他信息化应用也需要使用内存的空间作为缓存,那么MySQL数据库中缓存空间就可能变小。如果遇到这种情况下,数据库管理员需要跟系统工程师进行协商,为各种不同的应用根据性能要求的不同,手工设置不同的缓存空间。如此的话,就可以避免同一台服务器上不同信息化应用对缓存的冲突。
分享到:
评论

相关推荐

    MySQL缓存研究

    在研究报告中,会详细探讨不同缓存组件的运作机制,如查询缓存的缓存命中率、InnoDB缓冲池的脏页比例等,并结合实际案例分析缓存对性能的影响。此外,还会涉及如何通过调整MySQL的配置参数来优化缓存使用,例如`...

    释放MySQL潜能:深入配置缓存机制

    - **监控缓存命中率**:缓存命中率是衡量缓存效率的重要指标,可以通过以下命令监控:`SHOW STATUS LIKE 'Qcache_hits';` `SHOW STATUS LIKE 'Qcache_inserts';` - **调整缓存参数**:根据监控结果,适时调整缓存...

    mysql查询缓存

    MySQL的查询缓存并非缓存执行计划,而是查询及其结果集,这就意味着只有相同的查询操作才能命中缓存,因此MySQL的查询缓存命中率很低,另一方面,对于大结果集的查询,其查询结果可以从cache中直接读取,有效的提升...

    MySQL优化之缓存优化(续)

    MySQL缓存优化是数据库性能提升的关键一环,尤其在高并发和大数据量的场景下,合理利用缓存能显著减少磁盘I/O操作,提高查询速度。本文将深入探讨MySQL中的各种缓存机制及其优化策略。 首先,我们关注的是查询缓存...

    清空mysql 查询缓存的可行方法

    - 定期监控查询缓存的命中率(`SHOW STATUS LIKE 'Qcache%'`),如果命中率低,可能要考虑禁用查询缓存或调整缓存策略。 理解并有效地管理MySQL的查询缓存是数据库性能调优的重要环节。在进行SQL查询优化时,清空...

    MySQL 执行过程与查询缓存1

    **查询缓存**虽然在新版本中已不再使用,但在早期版本中,它可以提高查询速度,但需注意的是,任何对查询中涉及的表的修改都会使相关缓存失效,因此命中率不高。**分析器**用于解析SQL语句,检查语法和语义,确保...

    MYSQL查询缓存性能问题分析与优化案例(绝对精华)[参照].pdf

    3. **监控和性能分析**:通过MySQL的性能分析工具,如Performance Schema,监控查询缓存的命中率和内存使用情况,以便及时调整。 4. **合理配置**:设置适当的查询缓存大小至关重要。太小可能导致缓存效果不明显,...

    mysql配置文件的解释

    合理配置有助于提高缓存命中率,降低重复计算成本。 - **query_cache_size=n**:分配给查询缓存的空间总量。较大的缓存可以容纳更多的查询结果,但在高并发环境下也可能导致频繁的淘汰操作。 - **query_cache_type=0...

    supercache超级缓存

    同时,定期监控缓存命中率和内存使用情况,以确保缓存效果最佳。 6. **安全性与维护**: 由于缓存中存储的是热数据,因此确保其安全性至关重要。需要定期清理无效缓存,防止内存泄漏,并确保缓存系统免受攻击。...

    缓存技术浅谈PPT简介

    设计缓存方案时,需要考虑多个因素,如缓存命中率、数据更新策略(如LRU、LFU)、缓存失效策略、缓存一致性以及如何处理缓存穿透和缓存雪崩等问题。此外,缓存大小的设定、缓存的数据结构选择、并发控制等也是重要...

    集群的缓存技术

    - **一致性哈希**:相比轮询,一致性哈希算法能够提供更好的缓存命中率。但在某些情况下可能会导致单机热点问题。为了解决这个问题,可以采取以下措施: - 将热点数据直接推送到接入层Nginx缓存。 - 设置阈值,当...

    数据库缓存:释放性能瓶颈的金钥匙

    缓存预热有助于提高缓存的初始命中率,减少不必要的数据库查询。 ##### 5. 监控和调优 最后,监控缓存的命中率和性能,根据监控结果调整缓存策略也是非常重要的步骤: ```sql # MySQL 缓存监控示例 SHOW STATUS ...

    MySQL DBA教程:Mysql性能优化之缓存参数优化

    MySQL 数据库性能优化是DBA工作中的核心任务之一,尤其对于IO密集型的...在优化过程中,持续监控和分析各项指标(如缓存命中率、I/O负载等)也是必不可少的步骤,以确保优化措施真正带来性能提升,而不是引入新的问题。

    数据库与缓存深度学习完整版

    反之,对于偶尔查询且间隔时间较长的数据,或者数据量较大的结果集,不建议使用缓存,因为这可能导致内存资源浪费,甚至影响缓存命中率。 10.4. 涉及缓存的地方有哪些? 数据库缓存涉及以下几个层面: - 数据库本身...

    基于MySQL的高可靠性缓存DNS系统的设计与实现.pdf

    在压力测试中,将DNS缓存存储在MySQL数据库中相比传统方法,表现出更优秀的性能,包括更快的查询响应时间、更高的查询命中率以及更低的出口带宽占用。 此外,文章还提到了DNS日志的数据量问题。例如,山西农业大学...

    亿级流量电商缓存课程

    实时监控缓存的命中率、访问量、TPS(每秒事务处理量)等指标,根据实际情况调整缓存策略。 通过这20节课的学习,你将掌握电商环境下缓存的运用技巧,理解如何在亿级流量的压力下,构建高效、稳定、高可用的缓存...

    藏经阁-高性能Web架构之缓存体系.pdf

    - Cache命中率:衡量缓存效果的重要指标,高命中率意味着更多的请求被缓存服务,减少了底层系统负载。 以上内容是构建高性能Web架构的关键要素,通过合理运用缓存技术,可以显著提升Web服务的响应速度和用户体验,...

    web缓存技术精品课程

    而DataBuffer则是数据库数据在内存中的容器,其命中率直接影响数据库性能。MySQL中的InnoDB存储引擎通过innodb_buffer_pool_size参数来配置DataBuffer的大小,建议将buffer pool大小设置为服务器物理内存的60-80%。 ...

    mysql数据库配置模板

    2. **query_cache_size**: 如果查询缓存命中率较低,则考虑减小其大小或完全禁用,以节省内存资源。 3. **innodb_buffer_pool_size**: 对于InnoDB表,这是最重要的内存设置之一,应尽可能大但不超过系统总可用内存的...

Global site tag (gtag.js) - Google Analytics