分享

Mysql 数据库缓存cache功能总结

 小猪来了 2014-06-05
mysql cache功能分析:  1 mysql的cache功能的key的生成原理是:把select语句按照一定的hash规则生成唯一的key,select的结果生成value,即 key=>value。所以对于cache而言,select语句是区分大小写的,也区分空格的。两个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速度的地方,使用: SELECT SQL_CACHE * FROM… 的方式进行SELECT。 【mysql cache调试笔记】  1 可以使用下列命令开启mysql的select cache功能: SET GLOBAL query_cache_size = 102400000;  因为当query_cache_size默认为0时,是不开启cache功能的。

 


调试:

 

查看

cache

的设置:

 

show variables like ‘%query_cache%’;

 

性能监控:

 

show status like ‘%Qcache%’;

 

3 mysql cache

的清理:

 

可以使用

FLUSH 

QUERY 

CACHE

语句来清理查询缓存碎片以提高内存使用性能。该

语句不从缓存中移出任何查询。

 

RESET 

QUERY 

CACHE

语句从查询缓存中移出所有查询。

FLUSH 

TABLES

语句也执行

同样的工作。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多