MySQL 查询缓存
MySQL查询缓存提高单台节点的性能无外乎就那么几种方式,缓存是首当其冲的,因为内存的性能比磁盘高的太多。缓存也是一种典型的空间换时间的策略,缓存的实现也有太多的方式,从静态页面缓存到服务端动态缓存,再到数据库级别缓存等等。随着大数据的到来也产生了太多太多的内存数据库。缓存的工具也多种多样,随口一说就能说出很多,像 Redis,Memcached, Hbase 等,就连 MySQL 也有一个 memory 引擎数据就是直接存储到内存中,所以缓存无处不在。
视频链接:http://www.roncoo.com/course/view/658088f6e77541f5835b61800314083e
缓存的形式也多种多样,上面说的算是比较传统的缓存,其实各种的消息队列何尝又不是一种缓存机制。用到缓存的还有一个对于我们开发者都比较熟悉的,就是谷歌的低成本之道,据说谷歌最初的时候为了降低成本,提高性能,所有的机器中都没有装有硬盘,而是直接使用内存,数据靠多个节点的冗余来避免数据丢失。
缓存也是有缺陷,既然是缓存,那么针对的对象都是一些不变或者变化不大的对象,如果数据是经常变化的那么对其缓存反而适得其反。
MySQL 的查询缓存是MySQL 内置的一种缓存机制,可以针对 sql 进行缓存。比如我们发送 select * from mysql.user 这么一个查询,MySQL 首先检索内存中是否有数据并且数据是否过期,如果没有数据或者数据已经过期就去数据库中查找,如果有数据并且没有过期就直接返回数据。对于 sql 的匹配规则非常简单,就是字符串的比较,只要字符串相同,那么就认为是同一个查询。这里的字符串相同并不是表示 sql 语义相同,而是查询的 sql 字符串相同,空格也不行。MySQL 的缓存是对全部的 sql 有效的, 也就是说一旦开启了查询缓存,那么对所有的 sql 查询默认都是开启的。我们会有很多变化的数据,其实是不希望开启查询缓存的,这个 MySQL 也给我们想到了,就是在 sql 中加入 sql_no_cache 比如, select sql_no_cache * from mysql.user 这样,MySQL 就会绕过缓存直接从库里查找数据。另外还有一个需要注意的,比如我们在 sql 中使用了 now()这样的函数,MySQL 是不会给我们缓存的。
先来看一下有没有开启查询缓存
开启查询缓存的方式也非常简单,在 my.cnf 配置文件中设置上面的关于查询缓存的变量就可以了,下面具体说说每个变量的含义。
query_caceh_type 是否开启查询缓存 ,0 表示不开启查询缓存, 1 表示始终开启查询缓存(不要缓存使用 sql_no_cache) , 2 表示按需开启查询缓存 (需要缓存使用 sql_cache)。 query_cache_size 给缓存分配的最大内存空间
对于查询缓存的一些操作。
1、FLUSH QUERY CACHE; //清理查询缓存内存碎片。 2、RESET QUERY CACHE; //从查询缓存中移出所有查询。 3、FLUSH TABLES; //关闭所有打开的表,同时该操作将会清空查询缓存中的内容。
缓存虽然能够大幅度提高性能,但用起来也要慎重,一旦用不好,反而会适得其反。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
给网站配置免费的HTTS证书
最近看到网上说https的网站Google会优先收录,所以就抽时间记录下配置博客的过程。 ACME 使用LetEncrypt证书作为博客的https实现方式。 acme.sh实现了acme协议, 可以从letsencrypt生成免费的证书. githubhttps://github.com/Neilpang/acme.sh 主要步骤: 安装acme.sh 生成证书 copy 证书到 nginx/apache 或者其他服务 更新证书 更新acme.sh 测试https 1. 安装acme.sh 安装很简单, 一个命令: curlhttps://get.acme.sh|sh 普通用户和 root 用户都可以安装使用. 安装过程进行了以下几步: 把 acme.sh 安装到你的home目录下: cd~/.acme.sh/ 并创建 一个bash的alias, 方便你的使用:alias acme.sh=~/.acme.sh/acme.sh 2). 自动为你创建cronjob, 每天 0:00 点自动检测所有的证书, 如果快过期了, 需要更新, 则会自动更新证书. 2. 生成证书 并且完成验证 ac...
- 下一篇
Docker-compose 基于容器编排构建实践
上一篇我们介绍了通过使用Dockerfile构建LNMP环境,但是我们也发现了其中的缺陷;就是容器多的时候我们管理起来也是不方便的;我们需要考虑的就是把一组环境分组,然后按照执行顺序一键启动即可。 下面我们具体按照上一次咱们构建的wordpress环境: 1、安装docker compose,我们还是使用daocloud来进行安装,你懂得github有时候也挺慢的: [root@test~]#curl-Lhttps://get.daocloud.io/docker/compose/releases/download/1.11.2/docker-compose-`uname-s`-`uname-m`>/usr/local/bin/docker-compose [root@test~]#chmod+x/usr/local/bin/docker-compose [root@test~]#docker-composeversion docker-composeversion1.11.2,builddfed245 docker-pyversion:2.1.0 CPythonver...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS关闭SELinux安全模块
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- 设置Eclipse缩进为4个空格,增强代码规范
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS7安装Docker,走上虚拟化容器引擎之路