启用MySQL查询缓存
2016-03-30 08:29
501 查看
启用MySQL查询缓存能够极大地减低数据库server的CPU使用率,实际使用情况是:开启前CPU使用率120%左右,开启后降到了10%。
查看查询缓存情况:
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';
(原创文章。转载请注明转自Clement-Xu的csdn博客。)
查看查询缓存情况:
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';
(原创文章。转载请注明转自Clement-Xu的csdn博客。)
相关文章推荐
- mysql常用操作 mysql备份与恢复
- node.js操作mysql数据库之增删改查
- mysql导入csv文件出错解决办法
- 跟我一起学习MySQL技术内幕(第五版):(第一章学习日记4)
- mysql恢复报错 ERROR 1142 (42000)
- MySQL的两个存储引擎--MyISAM和InnoDB
- Windows环境—Mysql_5.5设置日志方法
- mysql学习笔记-索引
- MySQL的my.ini配置
- Error:MySQLAdministrator无法连接到实例
- 浅谈mysql事务
- mysql集群
- 主从 mysql (master slave) 复制原理及配置
- 采用MySQL数据连接
- MySQL性能优化的最佳经验,随时补充
- MySQL性能分析
- MySQL表类型
- 安装mysql 5.7.11,初始登录出现:mysql Access denied for user 'root'@'localhost' (using password: YES)
- mysql别名
- mysql绿色版安装使用配置教程?