- redis持久化
- redis是一种内存型数据库,一旦服务器进程退出,数据库数据就会丢失,为了解决这个问题,redis提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失。
- RDB持久化
- 这个功能可以将redis在内存中的状态保存到磁盘中,它可以手动执行。
- 也可以在redis。conf中配置,定期执行。
- RDB持久化产生的RDB文件是一个经过压缩的二进制文件,这个文件将保存在硬盘中,redis可以通过这个文件还原数据库当时的状态
#配置文件信息 redis.conf daemonize yes port 6379 logfile /data/6379/redis.log dir /data/6379 #定义持久化文件存储位置 dbfilename dbmp.rdb #rdb持久化文件 bind 10.0.0.10 127.0.0.1 #redis绑定地址 requirepass redhat #redis登录密码 save 900 1 #rdb机制 每900秒 有1个修改记录 save 300 10 #每300秒 10个修改记录 save 60 10000 #每60秒内 10000修改记录
- 启动redis
- 登陆redis设置一个key
- 此时检查,/data/6379中有没有dbmp.rdb文件
- 使用save触发持久化,将数据写入RDB文件
127.0.0.1:6379> set name jam OK 127.0.0.1:6379> save OK
- AOF持久化
- 记录服务器执行的所有变更操作(例如set del等),并在服务器启动时,通过重新执行这些命令来还原数据集
- AOF文件中的命令全部以redis协议的格式保存,新命令追加到文件末尾
- 优点:最大程度保证数据不丢失
- 日志记录非常大
# 配置文件 daemonize yes port 6379 logfile /data/6379/redis.log dir /data/6379 dbfilename dbmp.rdb requirepass redhat save 900 1 save 300 10 save 60 10000 appendonly yes appendfsync everysec
- 启动redis
- 检查redis数据目录/data/6379是否产生了AOF文件
[root@web02 6379]# ls appendonly.aof dbmp.rdb redis.log
- 登陆redis,写入数据,实时检查aof文件信息
[root@web02 6379]# tail -f appendonly.aof
- 设置新key,检查aof信息,然后关闭redis,检查数据是否持久化
- redis不重启,切换RDB备份到AOF备份
# redis.conf服务端配置文件 daemonize yes port 6379 logfile /data/6379/redis.log dir /data/6379 dbfilename dbmp.rdb save 900 1 #rdb机制 每900秒 有1个修改记录 save 300 10 #每300秒 10个修改记录 save 60 10000 #每60秒内 10000修改记录
# 启动
redis-server redis.conf
- 登陆redis
- 插入数据
127.0.0.1:6379> set name jam OK 127.0.0.1:6379> set age 18 OK 127.0.0.1:6379> save OK
- 检查RDB文件 /data/6379
- 备份这个rdb文件,保证数据安全
- 执行命令开始AOF持久化
127.0.0.1:6379> CONFIG set appendonly yes #开启AOF功能 OK 127.0.0.1:6379> CONFIG SET save "" #关闭RDB功能 OK
- 确保数据库的key数量正确
127.0.0.1:6379> keys * 1) "age" 2) "name"
- 确保插入新的key,AOF文件会记录
127.0.0.1:6379> set title python OK
此时已经切换,但还得修改redis.conf添加AOF设置,不然重启后,通过config set 的配置将丢失