【Redis运行状态下切换RDB备份至AOF备份】 𾃨

原文:
http://blog.gqylpy.com/gqy/324

redis持久化方式有哪些?又有何区别?

  1. rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能。
  2. aof:以追加的方式记录redis操作日志的文件,可最大程度的保证redis数据安全,类似于mysql的binlog。

本文将在redis5.0.2版本中,通过CONFIG SET命令,达到不重启redis服务的情况下,从RDB存储模式切换至AOF存储模式。

确保redis版本在2.2以上

[[email protected] redis5]# redis-server -v
Redis server v=5.0.2 sha=00000000:0 malloc=jemalloc-5.1.0 bits=64 build=55a56548bc97ef03


redis当前的配置文件如下

# pid文件路径
pidfile /var/run/redis/6380.pid

# 日志级别
loglevel notice

# redis数据存放位置
dir /usr/local/redis5/db/6380/

# 日志文件路径
logfile /var/log/redis/6380.log

# redis3.0之后的安全模式
# 安全模式可能会阻挡远程连接,可给redis设置密码解决这个问题
protected-mode yes 

# reids密码
requirepass redis_password

"""重点配置:重点在下面的配置"""

# 指定本地数据库文件名,其存储的数据为二进制类型
dbfilename dump.rdb

# 指定在多长时间内,有多少次更新操作才将数据同步到数据文件,redis默认提供了3个条件:
save 900 1
save 300 10
save 60 10000
# 其分别为:
# save 900 1 每900秒内有1个修改记录时转存
# save 300 10 每300秒内有10个修改记录时转存
# save 60 10000 每60秒内有10000修改记录时转存

可以看到,我们的当前实验环境为rdb持久化存储模式

开始切换
.
登陆redis-cli插入些数据,并手动持久化:

192.168.43.149:6380> set k1 v1
OK
192.168.43.149:6380> set k2 v2
OK
192.168.43.149:6380> save
OK

安全起见,我们备份RDB数据:

[[email protected] redis5]# cp /usr/local/redis5/db/6380/dump.rdb /opt/

此时,再进入redis-cli,执行如下命令,开启AOF持久化:

# 开启AOF功能
192.168.43.149:6380> CONFIG set appendonly yes
OK
# 关闭RDB功能
192.168.43.149:6380> CONFIG set save ''
OK

确保数据库中的key数量正确:

192.168.43.149:6380> keys *
1) "k2"
2) "k1"

开启AOF模式后,会自动生成appendonly.aof持久化文件:

[[email protected] redis5]# ls /usr/local/redis5/db/6380/
appendonly.aof  dump.rdb

此时进入redis-cli的操作,都会被记录,且追加到appendonly.aof文件中,以达到持久化的目的。

192.168.43.149:6380> set k3 v3
OK

此时RDB已经正确切换至AOF,注意还得修改redis配置文件,添加AOF设置,不然重启后,通过config set的配置将丢失。

修改配置文件,使AOF模式永久生效
.
将上面展示的redis配置文件中标记的"重点配置"的配置项替换为下面的配置项:

appendonly no
appendfsync everyses

appendonly no 指定是否在每次更新操作后进行日志记录
·
redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内> 的数据丢失
因为redis本身同步数据文件是按上面的save条件来同步的,所以有的数据会在一段时间内> 只存在于内存中
.
appendfsync everyses 指定更新日志的条件
此配置有3个可选值:
no:等待操作系统进行数据缓存同步到磁盘(快)
always:每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)
everysec:每秒同步一次(折衷,默认值)

原文:
http://blog.gqylpy.com/gqy/324

原文地址:https://www.cnblogs.com/ggg566/p/11415819.html

时间: 2024-11-06 12:37:00

【Redis运行状态下切换RDB备份至AOF备份】 𾃨的相关文章

【Redis运行状态下切换RDB备份至AOF备份】 -- 2019-08-11 19:35:28

原文: http://106.13.73.98/__/99/ redis持久化方式有哪些?又有何区别? rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能. aof:以追加的方式记录redis操作日志的文件,可最大程度的保证redis数据安全,类似于mysql的binlog. 本文将在redis5.0.2版本中,通过CONFIG SET命令,达到不重启redis服务的情况下,从RDB存储模式切换至AOF存储模式. 确保redis版本在2.2以上 [[email 

redis不重启,切换RDB备份到AOF备份

确保redis版本在2.2以上 [[email protected] /data 22:23:30]#redis-server -v Redis server v=4.0.10 sha=00000000:0 malloc=jemalloc-4.0.3 bits=64 build=64cb6afcf41664c 本文在redis4.0中,通过config set命令,达到不重启redis服务,从RDB持久化切换为AOF 实验环境准备 redis.conf服务端配置文件 daemonize yes

redis系列(四):切换RDB备份到AOF备份

1.准备环境 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服务端 redis-server redis.conf 登录redis-cli

redis学习之——持久化RDB 和AOF

RDB: 在指定的时间间隔内将内存中的数据集快照写入磁盘, 也就是行话讲的Snapshot快照,它恢复时是将快照文件直接读到内存里.rdb 保存的是dump.rdb文件 RDB工作原理: Redis会单独创建(fork)一个子进程来进行持久化,会先将数据写入到一个临时文件中,待持久化过程都结束了,再用这个临时文件替换上次持久化好的文件.整个过程中,主进程是不进行任何IO操作的,这就确保了极高的性能,如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方,式要比AOF方式更加

Redis之AOF备份

redis在进行备份的时候有2种方式:1.RDB:2.AOF:现在主要讲哈AOF的备份 1.找到redis.config配置文件,大部分下载下来和redis-service同目录: 2.打开redies.config找到#appendonly noAOF配置节点进行配置 appendfsync always   # 每1个命令,都立即同步到aof. 安全,速度慢 appendfsync everysec # 折衷方案,每秒写1次 appendfsync no      # 写入工作交给操作系统,

进阶的Redis之数据持久化RDB与AOF

大家都知道,Redis之所以性能好,读写快,是因为Redis是一个内存数据库,它的操作都几乎基于内存.但是内存型数据库有一个很大的弊端,就是当数据库进程崩溃或系统重启的时候,如果内存数据不保存的话,里面的数据就会丢失不见了.这样的数据库并不是一个可靠的数据库. 所以数据的持久化是内存型数据库的重中之重.它不仅提供数据保存硬盘的功能,还可以借此用硬盘容量扩展数据存储空间,使得Redis的可以存储超过机器本身内存大小的数据. Redis对于数据持久化提供了两种持久化的方案,RDB与AOF.它们的原理

redis配置文件基本解析以及RDB持久化与AOF持久化

redis.conf 我们安装成功之后就会有这个配置文件,但是我们一般都不推荐直接使用出厂的配置文件,而是单独拷贝一份使用,以避免我们因为配置错误而带来不必要的麻烦. 如图我单独拷贝了一份在根目录下面的文件夹: redis单元: Tcp-backlog: 设置tcp的backlog,backlog其实是一个连接队列,backlog队列总和=未完成三次握手队列+已经完成三次握手队列. 在这里三次握手队列我参考另一篇博文:https://blog.csdn.net/ityouknow/article

Redis持久化配置(rdb,aof)

Redis的持久化有2种方式 1快照 2是日志 Rdb快照的配置选项(内存中的快照写入磁盘速度更快) 配置文件:save 900 1 // 900秒内,有1条写入,则产生快照 save 300 1000 // 如果300秒内有1000次写入,则产生快照save 60 10000 // 如果60秒内有10000次写入,则产生快照(这3个选项都屏蔽,则rdb禁用) stop-writes-on-bgsave-error yes // 后台备份进程出错时,主进程停不停止写入?rdbcompressio

Redis的持久化机制(RDB、AOF)

1. 为什么需要持久化? 因为Redis是内存数据库,它将自己的数据存储在内存里面,一旦Redis服务器进程退出或者运行Redis服务器的计算机停机,Redis服务器中的数据就会丢失. 为了避免数据丢失,所以Redis提供了持久化机制,将存储在内存中的数据保存到磁盘中,用于在Redis服务器进程退出或者运行Redis服务器的计算机停机导致数据丢失时,快速的恢复之前Redis存储在内存中的数据. Redis提供了2种持久化方式,分别为: RDB持久化 AOF持久化 接下来,我们一一详解. 2. R