MySQL为什么取消了Query Cache?
MySQL之前有一个查询缓存Query Cache,从8.0开始,不再使用这个查询缓存,那么放弃它的原因是什么呢? 在这一篇里将为您介绍。 MySQL查询缓存是查询结果缓存 。 它将以SEL开头的查询与哈希表进行比较,如果匹配,则返回上一次查询的结果。进行匹配时, 查询必须逐字节匹配,例如 SELECT * FROM t1; 不等于select * from t1;,此外,一些不确定的查询结果无法被缓存,任何对表的修改都会导致这些表的所有缓存无效。因此,适用于查询缓存的最理想的方案是只读,特别是需要检查数百万行后仅返回数行的复杂查询。如果你的查询符合这样一个特点,开启查询缓存会提升你的查询性能。 随着技术的进步,经过时间的考验,MySQL的工程团队发现启用缓存的好处并不多。 首先,查询缓存的效果取决于缓存的命中率,只有命中缓存的查询效果才能有改善,因此无法预测其性能。 其次, 查询缓存的另一个大问题是它受到单个互斥锁的保护。 在具有多个内核的服务器上,大量查询会导致大量的互斥锁争用。 通过基准测试发现, 大多数工作负载最好禁用查询缓存(5.6的默认设置): query_cache_type = 0 如果你认为会从查询缓存中获得好处,请按照实际情况进行测试。 数据 写的越多,好处越少 缓冲池中容纳的数据越多,好处越少 查询越复杂,扫描范围越大,则越受益 MySQL8