zoukankan      html  css  js  c++  java
  • mysql 优化之查询缓存(mysql8已经废弃这个功能)

    对于缓存,一般人想到的是 redis、memcache 这些内存型的缓存。

    但是实际上 mysql 也提供了缓存,mysql 里面的缓存是查询缓存,可以把我们查询过的语句缓存下来,下一次查询的时候有可能就直接从缓存返回(缓存命中)。

    当然使用 mysql 缓存也不是没有坏处,mysql 多了个管理缓存的任务,需要写入缓存,然后如果判断里面的缓存已经过期,又要从里面删除缓存。

    查看查询缓存情况:
    mysql> show variables like '%query_cache%'; 
    (query_cache_type 为 ON 表示已经开启)
    +------------------------------+----------+
    | Variable_name                | Value    |
    +------------------------------+----------+
    | have_query_cache             | YES      |
    | query_cache_limit            | 1048576  |
    | query_cache_min_res_unit     | 4096     |
    | query_cache_size             | 20971520 |
    | query_cache_type             | ON       |
    | query_cache_wlock_invalidate | OFF      |
    +------------------------------+----------+
     
    如果不是ON,修改配置文件以开启查询缓存:
    > vi /etc/my.cnf
    [mysqld]中添加:
    query_cache_size = 20M
    query_cache_type = ON
     
    重启mysql服务:
    > service mysql restart
     
    查看缓存使用情况:
    mysql> show status like 'qcache%';  
    +-------------------------+----------+
    | Variable_name           | Value    |
    +-------------------------+----------+
    | Qcache_free_blocks      | 83       |
    | Qcache_free_memory      | 19811040 |
    | Qcache_hits             | 3108196  |
    | Qcache_inserts          | 757254   |
    | Qcache_lowmem_prunes    | 20720    |
    | Qcache_not_cached       | 47219    |
    | Qcache_queries_in_cache | 47       |
    | Qcache_total_blocks     | 276      |
    +-------------------------+----------+

        其中各个参数的意义如下:  

    • Qcache_free_blocks:缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE会对缓存中的碎片进行整理,从而得到一个空闲块。  
    • Qcache_free_memory:缓存中的空闲内存。  
    • Qcache_hits:每次查询在缓存中命中时就增大  
    • Qcache_inserts:每次插入一个查询时就增大。命中次数除以插入次数就是不中比率。  
    • Qcache_lowmem_prunes:缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间来看;如果这个 数字在不断增长,就表示可能碎片非常严重,或者内存很少。(上面的 free_blocks和free_memory可以告诉您属于哪种情况)  
    • Qcache_not_cached:不适合进行缓存的查询的数量,通常是由于这些查询不是 SELECT 语句或者用了now()之类的函数。  
    • Qcache_queries_in_cache:当前缓存的查询(和响应)的数量。  
    • Qcache_total_blocks:缓存中块的数量。 
    对于某些不想使用缓存的语句,可以这样使用:
    select SQL_NO_CACHE count(*) from users where email = 'hello';
     
  • 相关阅读:
    一个涉及到浮点寄存器的CM
    树和二叉树一篇就搞定!
    串的两种模式匹配方式(BF/KMP算法)
    队列的知识讲解与基本实现(数据结构)
    如何用C++实现栈
    判断List集合为空还是null的正确打开方式
    双链表的基本实现与讲解(C++描述)
    Redis从认识安装到实现增删改查
    如何使用C++实现单链表
    线性表——顺序表的实现与讲解(C++描述)
  • 原文地址:https://www.cnblogs.com/eleven24/p/9240533.html
Copyright © 2011-2022 走看看