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

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

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

确保redis版本在2.2以上

[root@master 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数据:

[root@master 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持久化文件:

[root@master 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:每秒同步一次(折衷,默认值)

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

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

    "redis持久化方式有哪些?又有何区别? rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能. aof:以追加的方式记录redis操作日志的文件,可最大程 ...

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

    redis不重启,切换RDB备份到AOF备份 确保redis版本在2.2以上 查看redis版本 redis-server -v 实验环境准备 本文是在redis4.0中,通过config set命令 ...

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

    确保redis版本在2.2以上 [root@pyyuc /data ::]#redis-server -v Redis server v= sha=: malloc=jemalloc- bits= b ...

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

      确保redis版本在2.2以上 [root@pyyuc /data ::]#redis-server -v Redis server v= sha=: malloc=jemalloc- bits= ...

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

    确保redis版本在2.2以上 [root@pyyuc /data 22:23:30]#redis-server -v Redis server v=4.0.10 sha=00000000:0 mal ...

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

    1.准备环境 redis.conf服务端配置如下: daemonize yes port logfile /data//redis.log dir /data/ dbfilename dbmp.rdb ...

  7. redis++:Redis的两种持久化 RDB 和 AOF

    Redis持久化备份数据的方式有两种:RDB(Redis DataBase) . AOF(Append Only  File). RDB 什么是RDB: 在指定时间间隔内,将内存中的数据集快照写入磁盘 ...

  8. Redis 通过 RDB 方式进行数据备份与还原

    Redis 通过 RDB 方式进行数据备份与还原 Intro 有的时候我们需要对 Redis 的数据进行迁移,今天介绍一下通过 RDB(快照)文件进行 Redis 数据的备份和还原 Redis 持久化 ...

  9. redis介绍(3)RDB和AOF原理解析

    简单科普一下redis的概念:(会的可忽略) Redis的概念 redis基于内存的Key Value类型的NoSQL数据库. Redis的特点 1. Redis是一个高性能的Key/Value数据库 ...

随机推荐

  1. hadoop-02-关闭防火墙

    hadoop-02-关闭防火墙 su root service iptables status #查看状态 即时关闭: service iptables stop #关闭 重启之后关闭: chkcon ...

  2. HDU 4756 Install Air Conditioning(次小生成树)

    题目大意:给你n个点然后让你求出去掉一条边之后所形成的最小生成树. 比較基础的次小生成树吧. ..先prime一遍求出最小生成树.在dfs求出次小生成树. Install Air Conditioni ...

  3. WinCE的C#中使用StreamReader 来读取TXT文档,读取文本文档。

    using System.IO; private void button1_Click(object sender, EventArgs e) { string strFilePath = " ...

  4. 程序员之--C语言细节13(二维数组和指针,&*a[i][0]的理解,数组1[e]和e[1]非常可能你没见过)

    主要内容:二维数组和指针.&*a[i][0]的理解.数组1[e]和e[1] #include <stdio.h> #define NUM_ROWS 10 #define NUM_C ...

  5. Cocos2dx学习报告2

    记录二:创建项目,其名曰DFJ(仿照微信打飞机) 上一个记录我们说到开发环境的配置以及如何去建立自己的项目. 如今我们就通过之前说所的方法来建立一个项目.这里我就不再截图了. 建立了自己的项目之后,我 ...

  6. C语言:constkeyword、结构体

    前几节内容的解说,主要是内存地址及指针的分析.这一节解说一下easy混淆的keywordconstant及结构体的知识. 一.constkeyword 1. 字符常量的指针 char const *p ...

  7. 冒泡,简单选择,直接插入排序(Java版)

    冒泡.简单选择,直接插入这三种排序都是简单排序. 工具类 package Utils; import java.util.Arrays; public class SortUtils { public ...

  8. m_Orchestrate learning system---二十五、复制类的时候最容易出现的错误是什么

    m_Orchestrate learning system---二十五.复制类的时候最容易出现的错误是什么 一.总结 一句话总结:命名空间错误导致Analyze类虽然继承了Base类,但是没有执行里面 ...

  9. zookeeper图形界面工具zooinspector

    链接: https://pan.baidu.com/s/1rabrwuC 密码: trwa zooinspector下载地址 解压后进入

  10. Android 自定义EditText实现类iOS风格搜索框

    最近在项目中有使用到搜索框的地方,由于其样式要求与iOS的UISearchBar的风格一致.默认情况下,搜索图标和文字是居中的,在获取焦点的时候,图标和文字左移.但是在Android是并没有这样的控件 ...