Redis缓存理解

本文介绍了Redis作为一款基于K-V存储系统的特性,包括支持多种数据类型如string, hash, list等,并支持原子性操作及不同的排序方式。不同于其他缓存系统,Redis通过VM特性周期性地将数据写入磁盘实现持久化,支持比物理内存更大的数据量。文章还详细讨论了Redis的两种持久化方式(RDB和AOF)以及两种淘汰旧数据策略(LRU和LFU)。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原理:

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)

最常使用原则,根据数据的历史访问频率来淘汰数据,其核心思想是“如果数据过去被访问多次,那么将来被访问的频率也更高”。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值