小心对待query_cache_size
cache size Query 小心
2023-09-27 14:25:06 时间
作者:吴炳锡 来源:http://www.mysqlsupport.cn/ 联系方式: wubingxi#gmail.com 转载请注明作/译者和出处,并且不能用于商业用途,违者必究.
对于使用MySQL的用户,对于这个变量大家一定不会陌生。前几年的MyISAM引擎优化中,这个参数也是一个重要的优化参数。但随着发展,这个参数也爆露出来一些问题。
机器的内存越来越大,人们也都习惯性的把以前有用的参数分配的值越来越大。这个参数加大后也引发了一系列问题。我们首先分析一下query_cache_size的工作原理:
一个SELECT查询在DB中工作后,DB会把该语句缓存下来,当同样的一个SQL再次来到DB里调用时,DB在该表没发生变化的情况下把结果从缓存中返回给Client。
这里有一个关建点,就是DB在利用Query_cache工作时,要求该语句涉及的表在这段时间内没有发生变更。那如果该表在发生变更时,Query_cache里的数据又怎么处理呢?首先要把Query_cache和该表相关的语句全部置为失效,然后在写入更新。那么如果Query_cache非常大,该表的查询结构又比较多,查询语句失效也慢,一个更新或是Insert就会很慢,这样看到的就是Update或是Insert怎么这么慢了。
所以在数据库写入量或是更新量也比较大的系统,该参数不适合分配过大。而且在高并发,写入量大的系统,建系把该功能禁掉。
相关文章
- How to choose from Viewstate, SessionState, Cookies and Cache
- page cache和buffer cache之间的关系以及验证
- 《计算机存储与外设》----1.4 Cache设计中要考虑的因素
- Linux系统中的page cache和buffer cache的概念、机制及kafka、redis等产品如何利用page cache
- Linux - buff和cache的区别
- cache.config文件配置模板
- Cache模拟器的设计与实现
- [LeetCode] LRU Cache
- 【Redis】基于Spring Cache + Redis + Jackson的注解式自动缓存方案保姆式教程(2022最新)
- Asp.Net Cache缓存技术学习
- leetcode 146. LRU Cache LRU 缓存 (简单)