一、什么是数据库缓存?
mysql等一些常见的关系型数据库的数据都存储在磁盘当中,在高并发场景下,业务应用对mysql产生的增删改查的操作会造成巨大的IO开销和查询压力,这无疑对数据库和服务器都是一种巨大的压力,为了解决这类问题,缓存数据的概率应运而生。
极大的解决了数据库服务器的压力。
提高应用数据的想用速度。
内存缓存。
文件缓存。
用户请求--> 数据查询--->连接数据库服务器并查询数据-->将数据缓存起来(HTML、 内存、JSON、序列号数据)-->显示给客户端。(有一个对数据处理的开销)
当用户再次请求或者新用户访问-->数据查询-->直接从缓存中获取数据-->显示给客户端。
缓存方式的选择。
缓存场景的选择。
缓存数据的实时性。(真是数据发送改变,缓存是否需要立马改变?一般情况下,我们可以给缓存设置一个失效时间,比如过5分钟再去更新一遍缓存就可以了)
缓存数据的稳定性。
启用mysql查询缓存可以极大的降低CPU使用率。
query_cache_type//查询缓存类型
//0 : 不使用查询缓存。
//1 : 始终使用查询缓存。
//2 : 按需使用查询缓存。query_cache_size //为查询缓存预留的内存,默认值为0,即无法使用查询缓存。
//临时设置方法,或者在my.cnf中永久设置SETGLOBALquery_cache_size = 1024;
a、当 query_cache_type = 1 时,亦可关闭查询缓存
SELECTSQL_NO_CACHE*FROMtable_name WHRE condition;
b、当 query_cahce_type = 2 时,可按需使用查询缓存。
SELECTSQL_CACHE*FROMtable_name WHRE condition;
查询缓存可看作是SQL文本和查询结果的映射。
第二次查询的SQL和第一次查询的SQL完全相同,则会使用缓存。只要第二次的sql稍微跟第一次的sql不太一样,比如多了一个空格,多了一个字段,都不会使用缓存。
SHOW STATUSLIKE'Qcache_hits';//查看缓存命中次数
FLUSHQUERY CACHE;//清理查询缓存中的内存碎片RESETQUERY CACHE;//从查询缓存中移除所有查询FLUSHTABLES;//关闭所有打开的表,同时该操作将会清空查询缓存中的内容
对于大型的站点,如果没有中间缓存层,当流量打入数据库存时,即便有之前的几层为我们挡住一部分流量,但是在大并发的情况下,还是会有大批量请求涌入数据库层,这样对于数据库服务器的压力冲击非常大,响应速度也会下降,因此添加中间缓存层很有必要。
memcache是一个高性能的分布式的内存对象缓存系统,通过在内存中维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像,视频,文件,以及数据库检索的结果等。简单的说就是将数据调用到内存,然后从内存中读取,从而大大提高读取速度。
先检查客户端的请求数据是否在memcached中,如果有,直接把请求数据返回,不在对数据库进行任何操作;如果请求的数据不在memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到mencached中。
get(key);//获取数据set(key, value, exipre);//设置数据delete(key);//删除数据
注:memcache拓展和 memcached 拓展是两个不同的 Memcache拓展,memcached拓展方法更丰富一些。
性能差距不大
Redis在2.0版本后增加了自己的VM特性,突破物理内存限制,Memcache可以修改最大可用内存,采用LRU算法。
Redis依赖客户端来实现分布式读写。‘
Memcache 本身没有数据冗余机制。
Redis支持(快照、AOF),依赖快照进行持久化,aof增强了可靠性的同时,对性能有所影响。
Memcache不支持持久化,通常做缓存,提升性能。
Memcache在并发场景下,用case来保持一致性,Redis事务支持比较弱,只能保证事务中的每个操作连续执行。
Redis支持多种数据类型。
Redis用于数据量较小的高性能操作和运算上。
Memcache用于在动态系统中减少数据库负载,提升性能,适合做缓存,提高性能。
转载于:https://www.cnblogs.com/chrdai/p/11293680.html