原理:
Redis是基于K-V的存储系统,支持的存储类型相对较多,包括string,hash,list,set,sorted set,并且支持原子性操作,Redis也支持各种不同方式的排序,和其他缓存系统不一样的是Redis会利用VM特性周期性的把数据写入磁盘来达到冷热数据分离和持久化,所以Redis能够支援比物理内存限制更大的数据量。
性能:
因为Redis不是纯内存操作,理论上性能会比纯内存缓存系统低。
优势:
1.支持的数据类型较全
2.支持持久化
3.支持集群,支持主从同步
两种持久化方式:
1. RDB (Redis Database)
默认的持久化方式,定期将内存的快照存入磁盘,效率高,当如果中途储存则很可能会引起数据丢失,可靠性不能得到保证。
2. AOF (Append Only File)
可选的持久化方式,会将所有操作写入日志中,效率相对RDB较低,而且储存的文件体积更大,不过可以保证数据的可靠性。
两种淘汰旧数据策略:
Redis可用时间策略定期淘汰旧数据,当如果时间策略不够用,数据量还是达到了设定限制时则会使用一些淘汰策略淘汰旧数据:
1. LRU (Least recently used)
最近使用原则,redis会保留最近使用的数据(即使它只用了一次),而淘汰最近没用的数据(即使它之前用了很多次)。
2. LFU (Least frequently used)
最常使用原则,根据数据的历史访问频率来淘汰数据,其核心思想是“如果数据过去被访问多次,那么将来被访问的频率也更高”。