前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >启用 MySQL 和 MariaDB 查询缓存

启用 MySQL 和 MariaDB 查询缓存

作者头像
明月登楼的博客
发布2019-05-15 17:14:21
2.5K0
发布2019-05-15 17:14:21
举报

很多新手都在使用 Memcached 或者 Redis 扩展来加速服务器数据库的运行性能,其实这些扩展对于小博客的服务器来说有时候是个负担和安全隐患的,具体可以参考【理智冷静的使用 Memcached 或者 Redis】一文,那么不使用优化扩展我们如何来提升 MySQL 或 MariaDB 数据库的运行性能呢?

其实 MySQL 和 MariaDB 都是支持“查询缓存”功能,并且启用MySQL查询缓存可以极大地减低数据库服务器的CPU使用率,实际使用情况是:开启前CPU使用率120%左右,开启后降到了10%。明月已经用这个方法加速我的 MariaDB 数据库近一年多时间了,所以我一直都没有再使用过 Memcached 或者 Redis 了。

今天就给大家讲讲如何开启这个“查询缓存”。

查看查询缓存情况

mysql> show variables like '%query_cache%';

query_cache_typeON 表示已经开启)

代码语言:javascript
复制
+------------------------------+----------+| 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

代码语言:javascript
复制
[mysqld]中添加:
query_cache_size = 20M
query_cache_type = ON

重启mysql服务: service mysql restart

查看缓存使用情况

代码语言:javascript
复制
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';

这个“查询缓存”算是 MySQL 或者 MariaDB 默认原生的加速方法了,稳定性和兼容性不用质疑,绝对的可靠!同时还免去了使用第三方缓存扩展带来的安全隐患,没有开启的尽快去开启吧!记住开启前一定要清除 Memcached 或者 Redis 进程哦,否则就起不到加速的效果了!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-09-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 草根博客站长有话说 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 查看缓存使用情况
  • 其中各个参数的意义
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档