mysql的查询缓存

     提高单台节点的性能无外乎就那么几种方式,缓存是首当其冲的,因为内存的性能比磁盘高的太多。缓存也是一种典型的空间换时间的策略

     缓存的实现也有太多的方式,从静态页面缓存到服务端动态缓存,再到数据库级别缓存等等。随着大数据的到来也产生了太多太多的内存数据库。

     缓存的工具也多种多样,随口一说就能说出很多,像Redis,Memcached,Hbase等,就连MySQL也有一个memory引擎数据就是直接存储到内存中,所以缓存无处不在。

     缓存的形式也多种多样,上面说的算是比较传统的缓存,其实各种的消息队列何尝又不是一种缓存机制。

     缓存也是有缺陷,既然是缓存,那么针对的对象都是一些不变或者变化不大的对象,如果数据是经常变化的那么对其缓存反而适得其反。

     说了那么多了,下面就说说MySQL的查询缓存吧,MySQL的查询缓存是MySQL内置的一种缓存机制,可以针对sql进行缓存。比如我们发送select * from mysql.user这么一个查询,MySQL首先检索内存中是否有数据并且数据是否过期,如果没有数据或者数据已经过期就去数据库中查找,如果有数据并且没有过期就直接返回数据。对于sql的匹配规则非常简单,就是字符串的比较,只要字符串相同,那么就认为是同一个查询。这里的字符串相同并不是表示sql语义相同,而是查询的sql字符串相同,空格也不行。MySQL的缓存是对全部的sql有效的, 也就是说一旦开启了查询缓存,那么对所有的sql查询默认都是开启的。我们会有很多变化的数据,其实是不希望开启查询缓存的,这个MySQL也给我们想到了,就是在sql中加入 sql_no_cache  比如,select sql_no_cache * from mysql.user这样,MySQL就会绕过缓存直接从库里查找数据。另外还有一个需要注意的,比如我们在sql中使用了now()这样的函数,MySQL是不会给我们缓存的。

     先来看一下有没有开启查询缓存

    

     开启查询缓存的方式也非常简单,在my.cnf配置文件中设置上面的关于查询缓存的变量就可以了,下面具体说说每个变量的含义。

query_caceh_type 是否开启查询缓存

 

0 表示不开启查询缓存,
1 表示始终开启查询缓存(不要缓存使用sql_no_cache) ,
2 表示按需开启查询缓存 (需要缓存使用 sql_cache)。

query_cache_size 给缓存分配的最大内存空间 

 

对于查询缓存的一些操作。

  1. FLUSH QUERY CACHE; // 清理查询缓存内存碎片。
  2. RESET QUERY CACHE; // 从查询缓存中移出所有查询。
  3. FLUSH TABLES; //关闭所有打开的表,同时该操作将会清空查询缓存中的内容。

 

缓存虽然能够大幅度提高性能,但用起来也要慎重,一旦用不好,反而会适得其反。

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值