本文目录一览:
- 1、五分钟系列之Redis大规模数据存储简述
- 2、redis缓存有什么好处
- 3、Redis缓存过期机制
- 4、面试官:Redis中的缓冲区了解吗-
- 5、面试中问到Redis持久化的原理,本篇在做详细解答
String字符串是最常用的数据类型,他能够存储任何类型的字符串,当然也包括二进制、JSON化的对象、甚至是base64编码之后的图片 。在Redis中一个字符串最大的容量为512MB,可以说是无所不能了 。
Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,zset,hash等数据结构的存储 。Redis支持数据的备份,即master-slave模式的数据备份 。
---Redis的存储分为内存存储、磁盘存储和log文件三部分,重启后,Redis可以从磁盘重新将数据加载到内存中 。
速度快:redis使用内存存储数据 , 使得读写速度非常快 。这是因为内存访问速度比磁盘访问速度快很多 。redis的单线程模型也避免了多线程并发处理中的锁竞争和上下文切换等开销,使得操作更加高效 。
redis缓存有什么好处1、用redis好处:数据存储在内存中,读写速度快;支持的数据类型资源丰富;支持事务,操作都是原子性操作;可以设置数据存活的生命周期 。因为redis比较方便 , 被大众认可的比较多 。
2、使用如Redis这样的缓存,你可以缓存经常请求的内容,从而大大减少请求最多的页面的延迟 , 并且大多数框架针对Redis缓存页面都有hooks 。
3、Redis缓存机制主要作用在于提高数据访问速度、减轻数据库压力、提高系统性能 。
Redis缓存过期机制当内存占满之后,redis提供缓存淘汰机制 。
Redis 中数据过期策略采用定期删除+惰性删除策略 。定期删除策略:Redis 启用一个定时器定时监视所有的 key,判断key是否过期,过期的话就删除 。
【redis做缓存的好处 redis做缓存是被动的还是主动的好】redis过期时间介绍有时候我们并不希望redis的key一直存在 。例如缓存 , 验证码等数据,我们希望它们能在一定时间内自动的被销毁 。redis提供了一些命令,能够让我们对key设置过期时间,并且让key过期之后被自动删除 。
会 。Redis提供了自动的键过期功能,通过该功能,用户可以让特定的键在指定的时间之后自动被移除,从而避免了需要在指定时间内手动执行删除操作的麻烦,所以redis数据会自动过期 。
懒惰处理 Redis在get操作时遇到过期的key会进行删除操作 。集中处理 Redis会将设置了过期时间的key放到一个独立的字典里,默认每秒10次过期扫描 。
Redis可以用使用 expire 指令设置过期时间,在Redis内部 , 每当我们设置一个键的过期时间时,Redis就会将该键带上过期时间存放到一个过期字典中 。
面试官:Redis中的缓冲区了解吗-1、对于同一缓冲系,当缓冲比一定时,总浓度越大,抗酸成分和抗碱成分越多 , 外加同量酸碱后,缓冲比变化越 ?。?缓冲容最大 , 缓冲能力就越强;反之,总浓度越小 , 缓冲容量越小,缓冲能力就越弱 。
2、将程序缓冲区的内容写入文件 当AOF持久化功能处于开启状态时,服务器每执行完一个命令就会将命令以协议格式追加写入redisServer结构体的aof_buf缓冲区 。而在服务重启的时候会把AOF文件加载到缓冲区中 。
3、上一篇文章Redis主从复制原理中简要地说明了主从复制的一个基本原理,包含全量复制、复制积压缓冲区与增量复制等内容 , 有兴趣的同学可以先看下 。利用主从复制,可以实现读写分离、数据备份等功能 。
4、AOF缓冲区不可以替代AOF重写缓冲区的原因是AOF重写缓冲区记录的是从重写开始后的所有需要重写的命令 , 而AOF缓冲区可能只记录了部分的命令 。
5、Redis中默认不开启AOF,appendonly yes ,是开启的配置 。文件的名字默认为appendonly.aof,可以通过参数 appendfilename 来设置 。目录也是通过 dir 来设置 。所有写入命令会追加到 aof_buf(缓冲区) 中 。
6、当主从断连后,主库会把断链期间收到的写命令写入replication buffer(上面有提到) , 同时也会写入repl_backlog_buffer这个缓冲区 。
面试中问到Redis持久化的原理,本篇在做详细解答可在redis.conf中配置,会以一段时间内达到指定修改的次数为规则来触发快照操作,快照文件名为dump.rdb 。每当Redis服务重启的时候都会从该文件中把数据加载到内存中 。在60秒内有10000次操作即触发RDB持久化 。
AOF(append only file)持久化:以独立日志的方式记录每次写命令,重启时再重新执行AOF文件中的命令达到恢复数据的目的 。AOF的主要作用是解决了数据持久化的实时性,目前已经是Redis持久化的主流方式 。
RDB 持久化机制 :是对 redis 数据执行周期性的持久化 。这种方式就是将内存中数据以快照的方式写入到二进制文件中 , 默认的文件名为 dump.rdb 。客户端也可以使用save或者bgsave命令通知redis做一次快照持久化 。
redis提供两种方式进行持久化 , 一种是RDB持久化(原理是将Reids在内存中的数据库记录定时dump到磁盘上的RDB持久化),另外一种是AOF(append only file)持久化(原理是将Reids的操作日志以追加的方式写入文件) 。
在redis的配置里有着这样的一段配置:save 900 1save 300 10save 60 10000很关键的一段配置,这时RDB持久化的核心 。