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助手
相关推荐
码云骑士16 小时前
32-慢查询排查全流程(下)-索引优化实战与最左前缀原则麦聪聊数据17 小时前
数据服务化时代:企业数据能力输出的核心路径shushangyun_17 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?JAVA96517 小时前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的闵孚龙17 小时前
《PyTorch 深度修炼》Dataset 和 DataLoader:数据如何喂给模型DARLING Zero two♡17 小时前
【MySQL数据库】数据类型与表约束goldenrolan17 小时前
A公司物料替代测试系统 v1.7:从需求到 exe/apk 的 AI 辅助全链路实践菜板春17 小时前
jupyter入门-手册-特征探索Metaphor69218 小时前
使用 Python 将 PDF 转换为 HTML极光代码工作室18 小时前
基于数据仓库的电商数据分析平台