zoukankan      html  css  js  c++  java
  • mysql基础之查询缓存、存储引擎

    一、查询缓存  

      “查询缓存”,就是将查询的结果缓存下载,如果查询语句完全相同,则直接返回缓存中的结果。

      如果应用程序在某个场景中,需要经常执行大量的相同的查询,而且查询出的数据不会经常被更新,那么,使用查询缓存会有一定的性能提升。

    查看当前服务是否开启了查询缓存功能:

    MariaDB [ren]> show variables like '%query_cache%';
    +------------------------------+---------+
    | Variable_name                | Value   |
    +------------------------------+---------+
    | have_query_cache             | YES     |
    | query_cache_limit            | 1048576 |
    | query_cache_min_res_unit     | 4096    |
    | query_cache_size             | 1048576 |
    | query_cache_strip_comments   | OFF     |
    | query_cache_type             | OFF     |
    | query_cache_wlock_invalidate | OFF     |
    +------------------------------+---------+
    7 rows in set (0.00 sec)

    query_cache_type的值设置了OFF,表示目前没有开启查询缓存功能

    query_cache_type的值可以设置为:ON、OFF、DEMAND,分别表示已启用、已禁用、按需缓存,设置在配置文件/etc/my.cnf.d/server.cnf中即可。

    have_query_cache的值为YES,表示当前数据库支持缓存功能

    query_cache_limit表示单条查询缓存的最大值,如果查询结果超过此值的大小,即时指定缓存当前结果,结果也不会被缓存,默认值为1M。

    query_cache_min_res_unit表示缓存存储于内存的最小单元,默认为4K,也就是说,即时查询结果只有1K,也会占用4K内存,所以,如果此值设置的过大,会造成内存空间的浪费,如果此值设置的过小,则会频繁的分配内存单元或者频繁的回收内存单元。

    query_cache_size表示查询缓存的总大小,也就是说,内存中用于查询缓存的空间大小,如果其值为0,即时开启了查询缓存,也无法缓存。

    query_cache_wlock_invalidate表示查询语句所查询的表如果被写锁锁定,是否仍然使用缓存返回结果。也就是“查询缓存遭遇写锁时是否失效”,设置为OFF表示“不失效”;设置为ON表示“失效”。当此值设置为ON,如果表被施加了写锁,那么当写锁释放时,数据可能发生了改变,所以在表被施加写锁期间,即时此时有查询语句命中了查询缓存,也不能从缓存获取结果。(此值设置为OFF时,性能更好,并发能力更好,此值设置为ON时,更加安全,保证了数据的一致性)(写锁时独立的,排他的)

    查询语句完全相同时,缓存才能够被命中,完全相同表示大小写也相同。

    一般在数据变化不频繁,且又需要重复执行相同查询的场景中使用缓存。

    二、使用查询缓存

    使用方式:

    开启缓存:query_cache_type=ON后,指定对应的查询语句不适用缓存:
    select
     sql_no_cache name from stu;
    按需使用缓存:query_cache_type=DEMAND,指定对应的查询语句使用缓存
    select sql_cache name from stu;

    第一种是默认符合缓存条件的都缓存,只有使用sql_no_cache指定的语句不缓存

    第二种是默认所有查询语句的结果都不缓存,只有使用sql_cache指定的语句才会缓存

    例子:

    [root@ren7 ~]# vim /etc/my.cnf.d/server.cnf 
    #############################################
    [server] query_cache_type=DEMAND query_cache_size=100M
    #############################################
    [root@ren7 ~]# systemctl restart mariadb

    查看查询缓存相关的参数:

    MariaDB [ren]> show variables like '%query%';
    +------------------------------+---------------+
    | Variable_name                | Value         |
    +------------------------------+---------------+
    | expensive_subquery_limit     | 100           |
    | ft_query_expansion_limit     | 20            |
    | have_query_cache             | YES           |
    | long_query_time              | 10.000000     |
    | query_alloc_block_size       | 16384         |
    | query_cache_limit            | 1048576       |
    | query_cache_min_res_unit     | 4096          |
    | query_cache_size             | 104857600     |
    | query_cache_strip_comments   | OFF           |
    | query_cache_type             | DEMAND        |
    | query_cache_wlock_invalidate | OFF           |
    | query_prealloc_size          | 24576         |
    | slow_query_log               | OFF           |
    | slow_query_log_file          | ren7-slow.log |
    +------------------------------+---------------+
    14 rows in set (0.00 sec)
    执行三次查询语句:
    MariaDB [ren]> select sql_cache * from students where id=8; +----+--------------+------+------+--------+--------+-----------+ | id | name | age | high | gender | cls_id | is_delete | +----+--------------+------+------+--------+--------+-----------+ | 8 | 周杰伦儿 | 34 | NULL || 1 | | +----+--------------+------+------+--------+--------+-----------+ 1 row in set (0.00 sec)

    查看缓存命中的情况:

    MariaDB [ren]> show status like 'Qcache%';
    +-------------------------+-----------+
    | Variable_name           | Value     |
    +-------------------------+-----------+
    | Qcache_free_blocks      | 1         |
    | Qcache_free_memory      | 104838240 |
    | Qcache_hits             | 2         |
    | Qcache_inserts          | 1         |
    | Qcache_lowmem_prunes    | 0         |
    | Qcache_not_cached       | 0         |
    | Qcache_queries_in_cache | 1         |
    | Qcache_total_blocks     | 4         |
    +-------------------------+-----------+
    8 rows in set (0.00 sec)

    Qcache_free_blocks表示已分配的内存中空闲块的数量;

    Qcache_free_memory表示查询缓存的空闲总量大小;

    Qcache_hits表示以被缓存的条目的命中次数;

    Qcache_inserts表示在未命中缓存时,将查询结果写入缓存的次数;

    Qcache_lowmem_prunes表示用于查询缓存的内存区域的修剪次数(当用于缓存的内存被占满时,mysql会使用LRU算法清除命中率低的缓存项,从而空余出部分内存空间,用于缓存新的“查询缓存”);

    Qcache_not_cached表示没有被缓存的查询语句的数量;

    Qcache_queries_in_cache表示已经缓存的SQL语句的数量;

    Qcache_total_blocks表示当前查询缓存占用的内存的block数量。

    查询缓存的碎片率 = (Qcache_free_blocks / Qcache_total_blocks)* 100%
    
    查询缓存利用率 = (Qcache_cache_size - Qcache_free_memory) / query_cache_size * 100%
    
    query_cache_min_res_unit的预估值参考计算公式:(query_cache_size - Qcache_free_memory)/ Qcache_queries_in_cache
    
    查询缓存命中率 = (Qcache_hits / Com_select)* 100%

    Com_select表示查询语句的执行次数:

    MariaDB [ren]> show status like 'Com_select%';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | Com_select    | 3     |
    +---------------+-------+
    1 row in set (0.00 sec)

    flush query cache;可以清理查询缓存碎片,但并不会从缓存中移除任何缓存;

    reset query cache;会从查询缓存中移除所有查询结果的缓存。

    三、存储引擎

      mysql中,存储引擎是插件式的,同一个数据库中的不同的表可以使用不同的存储引擎,所以,存储引擎是表级别的概念,存储引擎也被称为“表类型”,每张表可以使用不同的存储引擎类型。

      mysql中最常用的存储引擎是innodb与myisam。

    MYISAM:支持表级锁,不支持行级锁,不支持事务,不支持外键约束,支出全文索引,表空间文件相对小;

    INNODB:支持表级锁,行级锁,支持事务,支持外键,不支持全文索引,表空间文件相对较大。

     1、查看表类型,查看存储引擎

    MariaDB [ren]> show engines;
    +--------------------+---------+----------------------------------------------------------------------------------+--------------+------+------------+
    | Engine             | Support | Comment                                                                          | Transactions | XA   | Savepoints |
    +--------------------+---------+----------------------------------------------------------------------------------+--------------+------+------------+
    | MRG_MyISAM         | YES     | Collection of identical MyISAM tables                                            | NO           | NO   | NO         |
    | CSV                | YES     | Stores tables as CSV files                                                       | NO           | NO   | NO         |
    | SEQUENCE           | YES     | Generated tables filled with sequential values                                   | YES          | NO   | YES        |
    | MyISAM             | YES     | Non-transactional engine with good performance and small data footprint          | NO           | NO   | NO         |
    | MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables                        | NO           | NO   | NO         |
    | InnoDB             | DEFAULT | Supports transactions, row-level locking, foreign keys and encryption for tables | YES          | YES  | YES        |
    | Aria               | YES     | Crash-safe tables with MyISAM heritage                                           | NO           | NO   | NO         |
    | PERFORMANCE_SCHEMA | YES     | Performance Schema                                                               | NO           | NO   | NO         |
    +--------------------+---------+----------------------------------------------------------------------------------+--------------+------+------------+
    8 rows in set (0.00 sec)
  • 相关阅读:
    jQuery.ajax()方法笔记
    Docker安装
    Linux下Nginx+keepalived实现高可用
    Linux安装Nginx
    Redis主从、哨兵、Cluster特性
    Linux搭建redis集群
    Linux搭建redis单机
    HashMap知识总结(jdk1.8)
    如何避免form提交进行页面跳转
    异步上传文件,jquery+ajax,显示进度条
  • 原文地址:https://www.cnblogs.com/renyz/p/11448692.html
Copyright © 2011-2022 走看看