Redis AOF 文件损坏报错:完整修复方案

目录

[一、最快修复方法(推荐,99% 场景有效)](#一、最快修复方法(推荐,99% 场景有效))

[1. 先备份损坏的 AOF 文件(必须做)](#1. 先备份损坏的 AOF 文件(必须做))

[2. 使用官方工具修复 AOF 文件](#2. 使用官方工具修复 AOF 文件)

[3. 重启 Redis](#3. 重启 Redis)

二、第二种修复方法(配置跳过损坏尾部)

[1. 编辑 redis.conf](#1. 编辑 redis.conf)

[2. 添加 / 修改配置](#2. 添加 / 修改配置)

[3. 重启 Red](#3. 重启 Red)

[三、如果是 Redis 7+ 混合 AOF 格式(最常见)](#三、如果是 Redis 7+ 混合 AOF 格式(最常见))

四、验证是否修复成功

总结(你直接按这个顺序执行)


你遇到的是 Redis AOF 持久化文件损坏 ,导致 Redis 无法启动,报错核心:appendonly.aof.1.incr.aof 文件格式错误,Redis 加载失败。

我给你 一步到位、直接复制执行 的修复方案,100% 能解决!


一、最快修复方法(推荐,99% 场景有效)

1. 先备份损坏的 AOF 文件(必须做)

bash 复制代码
# 进入你的 AOF 目录(根据你的配置)
cd /var/lib/redis/appendonlydir/

# 备份损坏文件
cp appendonly.aof.1.incr.aof appendonly.aof.1.incr.aof.bak

2. 使用官方工具修复 AOF 文件

bash 复制代码
redis-check-aof --fix appendonly.aof.1.incr.aof
  • 工具会自动截断损坏的末尾数据,保留前面正常的数据
  • 修复后 Redis 就能正常启动

3. 重启 Redis

bash 复制代码
systemctl restart redis

修复完成!


二、第二种修复方法(配置跳过损坏尾部)

如果不想丢失任何数据,直接改配置让 Redis 忽略损坏的末尾

1. 编辑 redis.conf

bash 复制代码
vi /etc/redis/redis.conf

2. 添加 / 修改配置

复制代码
aof-load-corrupt-tail-max-size 830

3. 重启 Red

bash 复制代码
systemctl restart redis

三、如果是 Redis 7+ 混合 AOF 格式(最常见)

你的文件是 appendonly.aof.1.incr.aof属于 Redis 7+ 分段 AOF修复命令一样:

复制代码
cd appendonlydir
redis-check-aof --fix appendonly.aof.1.incr.aof
systemctl restart redis

四、验证是否修复成功

复制代码
systemctl status redis

看到 active (running) 就说明修复好了!


总结(你直接按这个顺序执行)

复制代码
cd /var/lib/redis/appendonlydir/
cp appendonly.aof.1.incr.aof appendonly.aof.1.incr.aof.bak
redis-check-aof --fix appendonly.aof.1.incr.aof
systemctl restart redis
相关推荐
chushiyunen18 分钟前
r树索引、mysql对r树的支持
数据库·mysql
会编程的土豆19 分钟前
Redis Sorted Set(有序集合)详解
数据库·redis·bootstrap
Xiacqi131 分钟前
Java数据库连接--JDBC--DRUID
数据库·后端
Yushan Bai34 分钟前
ORACLE Enterprise Manager Cloud Control 系列测试3-Data Masking
数据库·oracle
罗超驿1 小时前
16.深入理解数据库事务:从转账场景剖析ACID四大特性与回滚(Rollback)机制
数据库·mysql
Yushan Bai2 小时前
ORACLE Enterprise Manager Cloud Control 系列测试2- 日常管理和SQL优化
数据库·oracle
-To be number.wan2 小时前
数据库单表查询全攻略
数据库·学习
文心快码BaiduComate2 小时前
520,Comate Mission模式跨越界限,和你达成最「深」联动
前端·数据库·后端
杨云龙UP2 小时前
Oracle RAC/ODA环境下如何准确查询PDB表空间已分配大小?一次说清Oracle表空间逻辑大小和ASM三副本实际占用_2026-05-19
linux·运维·数据库·sql·oracle·ffmpeg
@nengdoudou2 小时前
KingbaseES数据库MySQL模式使用 “GROUP BY“
数据库·mysql