Redis如何记录每一次写操作_开启AOF持久化机制实现命令级追加记录
Redis AOF 是将写命令追加到文件以实现持久化,但并非所有场景都适用:appendfsync 配置影响安全性与性能,everysec 是线上折中选择,always 性能差,no 不可靠;AOF 重写可能耗资源,切换时需检查文件完整性、路径及时间戳。Redis AOF 是什么,为什么不是所有场景都该开AOF(Append Only File)本质是把每个写命令原样记进文件,重启时重放这些命令来恢复数据。它不等于“更安全”——如果 appendfsync 设成 no,可能丢一整秒操作;设成 always,吞吐直接掉 30% 以上,尤其小包高频写时磁盘 I/O 成瓶颈。常见误判:以为开了 AOF 就不会丢数据。实际 Redis 进程崩溃但系统没崩,AOF 文件还在;可如果整个机器断电且 appendfsync 是 everysec,最后一秒的缓冲区就没了。appendonly yes 必须显式开启,配置默认是 no,改完要 redis-cli config rewrite 或重启才生效不要和 RDB 同时关——否则实例重启即空库;建议至少保留 RDB 做冷备快照AOF 重写(bgrewriteaof)期间仍持续追加,重写完成前旧文件不删,磁盘空间可能翻倍怎么配 appendfsync 才不拖慢服务又不太丢数据这个参数决定命令写入磁盘的时机,只有三个合法值:always、everysec、no。线上几乎只用 everysec——它让主线程把命令写进内核缓冲区后立即返回,后台线程每秒刷一次盘。always:每次写都 fsync(),延迟高、磁盘寿命短,仅限金融级强一致场景(比如账务流水必须 100% 不丢)everysec:折中选择,实测单节点 QPS 5w+ 时延迟波动在 0.2–0.8ms,丢失窗口 ≤1 秒no:全靠系统调度刷盘,不可控,连 everysec 的兜底都没有,生产环境禁用注意:everysec 模式下若 Redis 进程 crash,未刷盘的缓冲区命令会丢失;但如果是系统级 crash,只要内核缓冲区还没被覆盖,仍有概率 recover。 RedClaw 百度推出的手机端万能AI Agent助手
