Redis 笔记1

REDIS 线程模型

REDIS 使用 IO多路复用模型 来处理 网络事件(连接事件和消息事件)

所有的事件放到一个队列里, 我们所说的单线程指的是REDIS 使用一个线程处理这个队列里的事件。

实际上 REDIS 的一些其他操作 都是fork出一个新的进程进行处理的。

REDIS 持久化 只 AOF

AOF是在命令被执行成功之后 将执行的命令 以 追加的方式写入到 AOF 日志中。

有三种模式 :

always 每次追加命令之后就刷盘 阻塞主线程,降低效率

everysecond 每一秒钟刷一次盘 相较于 always 效率高一些,相较于 no 安全性好一些。折中的一种策略

no 每次将命令写入缓冲区,由操作系统决定何时刷盘。效率最高,但是一旦服务器崩溃可能会丢失比较多的数据。

AOF是追加形式持久化变更命令,数据文件会比较大,一旦服务器重启 从AOF恢复会比较慢

REDIS 之 RDB

RDB是redis内存在某个时间的快照,每次做RDB快照 ,默认fork出一个bg进程去复制当前内存

到RDB文件, 为了防止复制快照时被修改,REDIS使用了 Copy on write 技术, 主线程修改数据时,先将原数据复制一份给bg进程。这样bgwrite进程看到的数据一直是原来的快照数据。

RDB复制相AOF来说消耗的资源更多。但是有个好处是相较于AOF,能更快的将数据恢复到某个时间点。

实际部署可以选择 RDB+AOF混合模式,这样恢复时由RDB恢复数据到最近的快照备份时间点,然后由AOF采用增量的方式恢复到最后的记录。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值