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)
复制代码
posted @ 2019-09-02 16:14  kuying  阅读(207)  评论(0编辑  收藏  举报