mysql SQL cache

Advertisement

Query Cache(QC)

mysql SQL cache

有如下规则,如果数据表被更改,那么和这个数据表相关的全部Cache全部都会无效,并删除之。这里“数据表更改”包括: INSERT, UPDATE, DELETE, TRUNCATE, ALTER TABLE, DROP TABLE, or DROP DATABASE等。举个例子,如果数据表posts访问频繁,那么意味着它的很多数据会被QC缓存起来,但是每一次posts数据表的更新,无论更新是不是影响到了cache的数据,都会将全部和posts表相关的cache清除。如果你的数据表更新频繁的话,那么Query Cache将会成为系统的负担。有实验表明,糟糕时,QC会降低系统13%[1]的处理能力。

Query Cache相关参数:

query_cache_size QC占用空间大小,通过将其设置为0关闭QC功能
query_cache_type 0表示关闭QC;1表示正常缓存;2表示SQL_CACHE才缓存
query_cache_limit 最大缓存结果集
query_cache_min_res_unit 手册上说,QC会按照这个值分配缓存block的大小。
Qcache_lowmem_prunes 这是一个状态变量(show status),当缓存空间不够需要

释放旧的缓存时,该值会自增。

Qcache_hits –表示sql在缓存中直接得到结果,不需要再去解析

have_query_cache –查询缓存是否可用
query_cache_limit –可缓存具体查询结果的最大值
query_cache_size –查询缓存的大小
query_cache_type –阻止或是支持查询缓存
set global query_cache_size = 600000; –设置缓存内存
set session query_cache_type = ON; –开启查询缓存
Qcache_free_blocks 缓存中相邻内存块的个数。数目大说明可能有碎片。

FLUSH QUERY CACHE 会对缓存中的碎片进行整理,从而得到一个空闲块。
Qcache_free_memory 缓存中的空闲内存。
Qcache_hits 每次查询在缓存中命中时就增大。
Qcache_inserts 每次插入一个查询时就增大。命中次数除以插入次数就是不中比率;

用1 减去这个值就是命中率。在上面这个例子中,

大约有 87% 的查询都在缓存中命中。
Qcache_lowmem_prunes 缓存出现内存不足并且必须要进行清理以便为更多查询提供空

间的次数。这个数字最好长时间来看;如果这个数字在不断增长,就

表示可能碎片非常严重,或者内存很少。(上面的 free_blocks 和

free_memory 可以告诉您属于哪种情况)。
Qcache_not_cached 不适合进行缓存的查询的数量,通常是由于这些查询不是

SELECT 语句。
Qcache_queries_in_cache 当前缓存的查询(和响应)的数量。
Qcache_total_blocks 缓存中块的数量。

1 通过配置实现:只对“数据变动少,select多”的table开启cache功能。(这个能否通过配置实现,还需要调查,在mysql手册中似乎没有提到)

2 配置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…

【mysql cache调试笔记】

1 可以使用下列命令开启mysql的select cache功能:

SET GLOBAL query_cache_size = 102400000;

因为当query_cache_size默认为0时,是不开启cache功能的。

2 调试:

查看cache的设置:

show variables like ‘%query_cache%’;

性能监控:

show status like ‘%Qcache%’;

3 mysql cache的清理:

可以使用FLUSH QUERY CACHE语句来清理查询缓存碎片以提高内存使用性能。该语句不从缓存中移出任何查询。

RESET QUERY CACHE语句从查询缓存中移出所有查询。FLUSH TABLES语句也执行同样的工作。

Similar Posts:

  • mysql sql no cache

    缓存2(SQL_NO_CACHE和SQL_CACHE的区别) 可以在 SELECT语句中指定查询缓存的选项,对于那些肯定要实时的从表中获取数据的查询,或者对于那些一天只执行一次的查询,我们都可以指定不进行查询缓存,使用SQL_NO_CACHE 选项. 对于那些变化不频繁的表,查询操作很固定,我们可以将该查询操作缓存起来,这样每次执行的时候不实际访问表和执行查询,只是从缓存获得结果,可以有效地改善查询的性能,使用SQL_CACHE 选项. 下面是使用 SQL_NO_CACHE 和 SQL_CACH

  • 8.10.3 The MySQL Query Cache

    8.10.3 The MySQL Query Cache [+/-] 8.10.3.1 How the Query Cache Operates 8.10.3.2 Query Cache SELECT Options 8.10.3.3 Query Cache Configuration 8.10.3.4 Query Cache Status and Maintenance query cache 存储了SELECT 语句连同相应的结果(发送到客户端的)的文本信息, 如果后来收到相同的语句,ser

  • mysql sql profiler 分析

    MySQL从5.0.37起,提供了profile的功能,对性能调试极其有用. profile的功能主要用途是显示 sql 执行的整个过程中各项资源的使用情况.分析器可以更好的展示出不良 SQL 的性能问题所在. 下面我们举例介绍一下 MySQL SQL Profiler 的使用方法: 首先,开启 MySQL SQL Profiler mysql> SELECT @@profiling; +-----+ | @@profiling | +-----+ | 0 | +-----+ 1 row in

  • MySQL Query Cache查询缓存介绍

    顾名思义,MySQL Query Cache 就是用来缓存和 Query 相关的数据的.具体来说,Query Cache 缓存了我们客户端提交给 MySQL 的 SELECT 语句以及该语句的结果集.大概来讲,就是将 SELECT 语句和语句的结果做了一个 HASH 映射关系然后保存在一定的内存区域中. 在大部分的 MySQL 分发版本中,Query Cache 功能默认都是打开的,我们可以通过调整 MySQL Server 的参数选项打开该功能.主要由以下5个参数构成: query_cache

  • 【mysql】mysql query cache配置与使用

    顾名思义,MySQL Query Cache 就是用来缓存和 Query 相关的数据的.具体来说,Query Cache 缓存了我们客户端提交给 MySQL 的 SELECT 语句以及该语句的结果集.大概来讲,就是将 SELECT 语句和语句的结果做了一个 HASH 映射关系然后保存在一定的内存区域中. 使用举例: # 强制使用缓存 SELECT SQL_CACHE id,field FROM table WHERE 1 # 强制不使用缓存 SELECT SQL_NO_CACHE id,fiel

  • jbpm3.2中jbpm.jpdl.mysql.sql文件运行报错的问题

    这是一个很久之前遇到的问题,就是用从官网下下载的jbpm组件,它的jbpm.jpdl.mysql.sql不能正常运行.其原因是该sql文件中有一句语句有错误.现在附上正确的jbpm.jpdl.mysql.sql文件代码: ;alter table JBPM_ACTION drop foreign key FK_ACTION_REFACT ;alter table JBPM_ACTION drop foreign key FK_CRTETIMERACT_TA ;alter table JBPM_A

  • MySql Query Cache 查询缓存介绍(1)

    MySql Query Cache 查询缓存介绍(1) MySql Query Cache 和 Oracle Query Cache 是不同的, Oracle Query Cache 是缓存执行计划的,而MySql Query Cache 不缓存执行计划而是整个结果集.缓存整个结果集的好处不言而喻,但由于缓存的是结果集因此Query必须是完全一样的,这样带来的后果就是平均 Hit Rate 命中率一般不会太高. Query Cache 对于一些小型应用程序或者数据表的数据量不大的情况下效果是最为

  • Scott Mitchell 的ASP.NET 2.0数据教程之61:使用SQL Cache Dependencies

    本文英文原版及代码下载: http://www.asp.net/learn/dataaccess/tutorial61cs.aspx?tabid=63 Scott Mitchell 的ASP.NET 2.0数据教程之61:使用SQL Cache Dependencies 导言: 在58和59章探讨的缓存技术使用的是基于时间的缓存周期,当过了某段时间后便将缓存数据从内存清除.当设置缓存时间为x秒时,数据在x秒内都是"新"的.当然,就像在60章谈到的那样,对静态数据来说,x可延伸到web应

  • MySql sql 备忘

    ************************************** ****MySql sql 查询备忘**** ************************************** 一.外连接: 1.左外连接(把join左边表里的所有数据都查出来.然后把join 右边表中的符合条件的数据加在左边表的后面....) SELECT * FROM t_empl_info as a LEFT OUTER JOIN t_dept as b ON a.dept_no=b.dept_id

  • 使用SQL Cache Dependency 代替 Ibatisnet 提供的CacheModel

    用IBatisNet作为持久层工具,有一个很好的好处就是很方便地使用它本身的缓存模型,可以控制在数据修改后缓存过期,但它的限制也是相当明显的,数据缓存和数据的更新操作必须在同一个应用程序域当中,当我在一台机器上缓存数据,而在另一台机器上修改数据(或者直接修改数据表)时就无法通知缓存过期了.这一个很棘手的问题,到底要不要使用缓存呢?在Asp.Net 2.0 当中有提供一个运行Sql Server的数据库更新通知缓存过期策略,(实现Cache SqlDependency,请参阅SQL Cache D