欢迎投稿

今日深度:

Mysql 数据库缓存cache功能分析,调试以及性能总结

Mysql 数据库缓存cache功能分析,调试以及性能总结


mysql cache 功能分析:

1 mysql 的 cache 功能的 key 的生成原理是:把 select 语句按照一定的 hash 规 则生成唯一的 key,select 的结果生成 value,即 key=>value。所以对于 cache 所以对于而言,语句是区分大小写的,也区分空格的。两个 select 语句必须完完全全一致,才能够获取到同一个 cache。

2 生成 cache 之后,只要该 select 中涉及到的 table 有任何的数据变动(insert,update,delete 操作等),相 关的所有 cache 都会被删除。因此只有数据很少变动的 table,引入 mysql 的 cache 才较有意义。关于这方面的测试,可以参考:《Query Cache,看上去很美》一文。

所以,mysql 的 cache 功能只适用于下列场合:数据变动较少,select 较多的 table。

那么。在复杂的系统中,如何使用 mysql 的 cache 功能呢,基本方法如下:

query_cache_type,同时改写程序。

query_cache_type 0 代表不使用缓冲, 1 代表使用缓冲,2 代表根据需要使用。

设置 1 代表缓冲永远有效,如果不需要缓冲,就需要使用如下语句:

SELECT SQL_NO_CACHE * FROM my_table WHERE …

如果设置为 2 ,需要开启缓冲,可以用如下语句:

SELECT SQL_CACHE * FROM my_table WHERE …

So,最简单又可靠的做法是:把 query_cache_type 设置为 2,然后在需要提高 速度的地方,使用:

SELECT SQL_CACHE * FROM…

的方式进行 SELECT。

【mysql cache 调试笔记】

1 可以使用下列命令开启 mysql 的 select cache 功能:

SET GLOBAL query_cache_size = 102400000;

因为当 query_cache_size 默认为 0 时,是不开启 cache 功能的。

2 调试: 查看 cache 的设置:

show variables like ‘%query_cache%’;

性能监控:

show status like ‘%Qcache%’;

3 mysql cache 的清理:

可以使用 FLUSH QUERY CACHE 语句来清理查询缓存碎片以提高内存使用性能。该 语句不从缓存中移出任何查询。

RESET QUERY CACHE 语句从查询缓存中移出所有查询。FLUSH TABLES 语句也执行同样的工作。

您可能感兴趣的文章

  • MySQL 大数据量快速插入方法和语句性能优化
  • 如何定位,排除和避免MySQL数据库性能问题
  • Navicat for mysql 远程连接 mySql数据库提示10061,1045错误的解决办法
  • 合理使用MySQL数据库索引以使数据库高效运行
  • 学会设置MySQL数据库的五个常用参数
  • windows环境下mysql数据库的主从同步备份步骤
  • 忘记PHPnow的MySQL数据库密码的解决办法
  • 总结MySQL数据库服务器逐渐变慢的原因和解决办法

www.htsjk.Com true http://www.htsjk.com/Mysql/10292.html NewsArticle Mysql 数据库缓存cache功能分析,调试以及性能总结 mysql cache 功能分析: 1 mysql 的 cache 功能的 key 的生成原理是:把 select 语句按照一定的 hash 规 则生成唯一的 key,select 的结果生成 val...
评论暂时关闭