Bootstrap

Redis

Redis 与其他 key - value 缓存产品有以下三个特点:

  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
  • Redis支持数据的备份,即master-slave模式的数据备份。

Redis与其他key-value存储有什么不同?
Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。

Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

Redis 数据类型
Redis支持种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合),SortedSet,Bitmap。
在这里插入图片描述
在没有Redis之前,对于MySQL来说,容纳的数据以及用户请求越来越多,每个请求都是一个读写操作,其中大部分的请求都是读操作,而且经常会重复查询一个东西,浪费很多时间去进行磁盘I/O.
有了Redis之后,应用程序从MySQL查询到数据,在redis登记,后面再用到会首先去找Redis,没有再找MySQL
在这里插入图片描述

缓存过期&&缓存淘汰

Redis缓存的数据都在内存中,但内存空间资源有限。
给缓存内容设置一个超时时间,具体设置设置多久由应用程序决定,redis会把过期的内容删除。
怎么清理呢?
F1、100ms做一次删除,随机选择部分数据来清理。
问题:有些键值每次都没有被随机算法选中
F2、在F1的基础上,对于那些每次都没有选中的键值,一旦遇到查询请求,若判断已经超时,立即删除。---------------惰性删除
问题:有部分键值两种方法都没有选中
F3、内存淘汰策略
Redia提供了8种策略供应用程序选择。

  • noeviction:返回错误,不会删除任何键值
  • allkeys-lru:使用LRU算法删除最近最少使用的键值
  • volatile-lru:使用LRU算法从设置了过期的时间的键集合中删除最近最少使用的键值
  • allkeys-random:从所有key随机删除
  • volatile-random:从设置了过期时间的键集合中随机删除
  • volatile-ttl:从设置了过期时间的键中删除剩余时间最短的键
  • allkeys-lfu:从所有键中删除使用频率最少的键
  • volatile-lfu:从设置了过期时间的键中删除使用频率最少的键

缓存穿透&&布隆过滤器

在遇到不存在的数据时,应用程序先从Redis中查询,没有,就去MySQL中查询,因为不存在MySQL中没有查询到。因为不存在,所以Redis也没办法缓存,Redis的价值就没有得到体现。-----------------------缓存穿透
由此产生布隆过滤器
擅长:从超多的数据集中快速得到查询的数据是否存在
问题:布隆过滤器查询到存在的数据不一定存在,但查询到不存在的数据一定不存在。

缓存击穿&&缓存雪崩

一个热点数据到了过期时间,刚好被Redis删除,随后来了对这个数据的大量查询请求,大量的请求发送到MySQL中--------------缓存击穿

同样一批热点数据到过期时间被Redis删除,大量热点数据查询请求同时发送到MySQL----------------雪崩

应用程序端把键值的过期时间随机设置并设置热点数据永不过期,上面的问题得到了不少缓解。

;