Redis的一大重要特征就是支持持久化。

Redis提供了两种不同的持久化方式:RDB和AOF。 RDB持久化可以在指定的时间间隔内生成数据集的快照。由于是定期的生成数据集的快照,所以,如果服务器出现异常停止的时候,那可能就会造成上一次备份后面的数据没有被保存下来。

AOF持久化以纯文本的方式记录了所有的操作命令。aof支持不同的fsync策略,可以选择每秒fsync,默认是每秒。如果在写的时候出现宕机,也可以通过redis-check-aof工具来修复aof备份文件。

这两种持久化方式也可以同时使用。

持久化配置

RDB方式:在默认情况下,Redis将数据库快照保存在名字为dump.rdb的二进制文件中,也可以通过配置文件配置。

可以通过配置文件来决定RDB保存的条件,也可以通过SAVE或者BGSAVE命令来显示的执行保存操作。

例如:save 60 1000的意思是 60秒内至少有1000个键被改动过的话就自动保存一次数据集。

默认情况下是启用RDB方式持久化的。

save 900 1
save 300 10
save 60 10000

默认情况下,没900秒内有一个key被改动就保存,没300秒内有10个key被改动就保存,每60秒内有1万个key被改动就保存。

dbfilename dump.rdb:指定了保存的文件名。

dir ./:指定了保存的路径为当前目录,更改为/usr/local/redis

AOF方式:aof方式的启动只需要配置一个appendonly yes的选项就可以。

aof支持下面几种持久化策略:

1、每次有新命令就执行一次fsync

2、没秒执行一次fsync(默认)

3、从不fsync。

appendonly no:默认情况下没有开启,修改为yes就是开启。

appendfilename "appendonly.aof":默认的持久化文件名称。

# appendfsync always
appendfsync everysec:默认开启这个,每秒fsync一次。
# appendfsync no

RDB方式测试

[root@localhost 13:14 /usr/local/redis]# ll
总用量 276
-rw-rw-r--. 1 root root 127778 7月 24 22:58 00-RELEASENOTES
-rw-rw-r--. 1 root root 53 7月 24 22:58 BUGS
-rw-rw-r--. 1 root root 1815 7月 24 22:58 CONTRIBUTING
-rw-rw-r--. 1 root root 1487 7月 24 22:58 COPYING
drwxrwxr-x. 6 root root 4096 8月 15 19:35 deps
-rw-rw-r--. 1 root root 11 7月 24 22:58 INSTALL
-rw-rw-r--. 1 root root 151 7月 24 22:58 Makefile
-rw-rw-r--. 1 root root 4223 7月 24 22:58 MANIFESTO
-rw-rw-r--. 1 root root 20530 7月 24 22:58 README.md
-rw-rw-r--. 1 root root 57765 9月 3 11:32 redis.conf
-rwxrwxr-x. 1 root root 271 7月 24 22:58 runtest
-rwxrwxr-x. 1 root root 280 7月 24 22:58 runtest-cluster
-rwxrwxr-x. 1 root root 281 7月 24 22:58 runtest-sentinel
-rw-rw-r--. 1 root root 7606 7月 24 22:58 sentinel.conf
drwxrwxr-x. 3 root root 4096 9月 9 12:55 src
drwxrwxr-x. 10 root root 4096 7月 24 22:58 tests
drwxrwxr-x. 8 root root 4096 7月 24 22:58 utils
[root@localhost 13:14 /usr/local/redis]# redis-cli
127.0.0.1:6379> set name zhangsan
OK
127.0.0.1:6379> shutdown save
not connected> exit
[root@localhost 13:18 /usr/local/redis]# ll
总用量 280
-rw-rw-r--. 1 root root 127778 7月 24 22:58 00-RELEASENOTES
-rw-rw-r--. 1 root root 53 7月 24 22:58 BUGS
-rw-rw-r--. 1 root root 1815 7月 24 22:58 CONTRIBUTING
-rw-rw-r--. 1 root root 1487 7月 24 22:58 COPYING
drwxrwxr-x. 6 root root 4096 8月 15 19:35 deps
-rw-r--r--. 1 root root 177 9月 9 13:18 dump.rdb
-rw-rw-r--. 1 root root 11 7月 24 22:58 INSTALL
-rw-rw-r--. 1 root root 151 7月 24 22:58 Makefile
-rw-rw-r--. 1 root root 4223 7月 24 22:58 MANIFESTO
-rw-rw-r--. 1 root root 20530 7月 24 22:58 README.md
-rw-rw-r--. 1 root root 57765 9月 3 11:32 redis.conf
-rwxrwxr-x. 1 root root 271 7月 24 22:58 runtest
-rwxrwxr-x. 1 root root 280 7月 24 22:58 runtest-cluster
-rwxrwxr-x. 1 root root 281 7月 24 22:58 runtest-sentinel
-rw-rw-r--. 1 root root 7606 7月 24 22:58 sentinel.conf
drwxrwxr-x. 3 root root 4096 9月 9 12:55 src
drwxrwxr-x. 10 root root 4096 7月 24 22:58 tests
drwxrwxr-x. 8 root root 4096 7月 24 22:58 utils
[root@localhost 13:18 /usr/local/redis]#

发现,已经有dump.rdb文件了。

我们重新启动服务器查看:

[root@localhost 13:19 /usr/local/redis]# service redis start
Starting Redis server...
3925:C 09 Sep 13:20:03.909 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
3925:C 09 Sep 13:20:03.910 # Redis version=4.0.1, bits=32, commit=00000000, modified=0, pid=3925, just started
3925:C 09 Sep 13:20:03.910 # Configuration loaded
[root@localhost 13:20 /usr/local/redis]# redis-cli
127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379>

可以看到,此时的keys还是存在的。

但是,如果我们把dump文件移动到别的地方呢?

[root@localhost 13:21 /usr/local/redis]# service redis start
Starting Redis server...
3948:C 09 Sep 13:22:03.371 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
3948:C 09 Sep 13:22:03.371 # Redis version=4.0.1, bits=32, commit=00000000, modified=0, pid=3948, just started
3948:C 09 Sep 13:22:03.371 # Configuration loaded
[root@localhost 13:22 /usr/local/redis]# redis-cli
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379>

发现,keys又不存在了,如果我们把dump文件在拿回来,又可以继续读取到。这就可以用来实现备份和恢复了。

AOF方式测试

需要注意的是,当rdb方式和aof方式同时开启的时候,服务器重启会优先读取aof的文件。

修改配置文件如下:

appendonly yes

[root@localhost 13:32 /usr/local/redis]# redis-cli
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> set name lisi
OK
127.0.0.1:6379> set name wangwu
OK
127.0.0.1:6379> get name
"wangwu"
127.0.0.1:6379> shutdown
not connected> exit
[root@localhost 13:34 /usr/local/redis]# ll
总用量 284
-rw-rw-r--. 1 root root 127778 7月 24 22:58 00-RELEASENOTES
-rw-r--r--. 1 root root 91 9月 9 13:33 appendonly.aof
-rw-rw-r--. 1 root root 53 7月 24 22:58 BUGS
-rw-rw-r--. 1 root root 1815 7月 24 22:58 CONTRIBUTING
-rw-rw-r--. 1 root root 1487 7月 24 22:58 COPYING
drwxrwxr-x. 6 root root 4096 8月 15 19:35 deps
-rw-r--r--. 1 root root 175 9月 9 13:34 dump.rdb
-rw-rw-r--. 1 root root 11 7月 24 22:58 INSTALL
-rw-rw-r--. 1 root root 151 7月 24 22:58 Makefile
-rw-rw-r--. 1 root root 4223 7月 24 22:58 MANIFESTO
-rw-rw-r--. 1 root root 20530 7月 24 22:58 README.md
-rw-rw-r--. 1 root root 57765 9月 3 11:32 redis.conf
-rwxrwxr-x. 1 root root 271 7月 24 22:58 runtest
-rwxrwxr-x. 1 root root 280 7月 24 22:58 runtest-cluster
-rwxrwxr-x. 1 root root 281 7月 24 22:58 runtest-sentinel
-rw-rw-r--. 1 root root 7606 7月 24 22:58 sentinel.conf
drwxrwxr-x. 3 root root 4096 9月 9 12:55 src
drwxrwxr-x. 10 root root 4096 7月 24 22:58 tests
drwxrwxr-x. 8 root root 4096 7月 24 22:58 utils
[root@localhost 13:34 /usr/local/redis]#

查看appendonly.aof的文件内容:

[root@localhost 13:34 /usr/local/redis]# cat appendonly.aof
*2
$6
SELECT
$1
0
*3
$3
set
$4
name
$4
lisi
*3
$3
set
$4
name
$6
wangwu
[root@localhost 13:35 /usr/local/redis]#

重新启动服务器查看:

[root@localhost 13:36 /usr/local/redis]# redis-cli
127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> get name
"wangwu"
127.0.0.1:6379>

这就完成了redis的持久化配置了 。

Redis管理之持久化的更多相关文章

  1. 超好用的Redis管理及监控工具,使用后可大大提高你的工作效率!

    Redis做为现在web应用开发的黄金搭担组合,大量的被应用,广泛用于存储session信息,权限信息,交易作业等热数据.做为一名有10年以上JAVA开发经验的程序员,工作中项目也是广泛使用了Redi ...

  2. Shiro经过Redis管理会话实现集群(转载)

    原文:http://www.myexception.cn/software-architecture-design/1815507.html Shiro通过Redis管理会话实现集群 写在前面 1.在 ...

  3. Redis管理及监控工具

    Redis管理及监控工具 Redis做为现在web应用开发的黄金搭担组合,大量的被应用,广泛用于存储session信息,权限信息,交易作业等热数据.做为一名有10年以上JAVA开发经验的程序员,工作中 ...

  4. 推荐一个Redis管理工具

    Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字符串.哈希表.列表.集合.有序集合,位图,hyperloglogs等数据类型.内置复制.Lu ...

  5. Redis两种持久化方式(RDB&AOF)

    爬虫和转载请注明原文地址;博客园蜗牛:http://www.cnblogs.com/tdws/p/5754706.html Redis所需内存 超过可用内存怎么办 Redis修改数据多线程并发—Red ...

  6. 完整的定时任务解决方案Spring集成+定时任务本身管理+DB持久化+集群

    完整的定时任务解决方案Spring集成+定时任务本身管理+DB持久化+集群 maven依赖 <dependency> <groupId>org.quartz-scheduler ...

  7. Redis提供的持久化机制(RDB和AOF)

    Redis提供的持久化机制 Redis是一种面向"key-value"类型数据的分布式NoSQL数据库系统,具有高性能.持久存储.适应高并发应用场景等优势.它虽然起步较晚,但发展却 ...

  8. php版redis插件,SSDB数据库,增强型的Redis管理api实例

    php版redis插件,SSDB数据库,增强型的Redis管理api实例 SSDB是一套基于LevelDB存储引擎的非关系型数据库(NOSQL),可用于取代Redis,更适合海量数据的存储.另外,ro ...

  9. Redis学习手册(持久化)

    一.Redis提供了哪些持久化机制: 1). RDB持久化:    该机制是指在指定的时间间隔内将内存中的数据集快照写入磁盘.        2). AOF持久化:    该机制将以日志的形式记录服务 ...

随机推荐

  1. [日常] NOIWC 2018爆零记

    开个坑慢慢更(逃 (然而没准会坑掉?) day 0 大概 $8:30$ 就滚去雅礼了qwq 过去的时候发现并没有人...进报到处楼门的时候还被强行拍照围观了一波OwO 然后就领了HZ所有人的提包和狗牌 ...

  2. C语言程序设计(基础)- 第0次作业

    亲爱的同学们,恭喜你成为一名大学生,我也很荣幸能够带大家一起学习大学的第一门专业基础课.还在军训的你,肯定对大学生活和计算机专业有着美好的憧憬,那么大学生活是什么样子的那?计算机专业应该怎么学习那?请 ...

  3. 听翁恺老师mooc笔记(1)--为何选择学习C

    知识点1:众多编程语言,为何选择C? 现在我们的同学喜欢java,也参加很多java的培训班,java是比较热门,但是C语言在工业界依然有重要的地位,在很多领域无可替代,几乎所有和硬件打交道的地方都得 ...

  4. 简易web服务器

    当通过Socket开发网络应用程序的时候,首先需要考虑所使用的网络类型,主要包括以下三个方面: 1)Socket类型,使用网络协议的类别,如IPv4的类型为PF_INET. 2)数据通信的类型,常见的 ...

  5. Alpha冲刺Day3

    Alpha冲刺Day3 一:站立式会议 今日安排: 我们把项目大体分为四个模块:数据管理员.企业人员.第三方机构.政府人员.数据管理员这一模块,数据管理员又可细分为两个模块:基础数据管理和风险信息管理 ...

  6. JAVA使用和操作properties文件

    java中的properties文件是一种配置文件,主要用于表达配置信息,文件类型为*.properties,格式为文本文件,文件的内容是格式是"键=值"的格式,在properti ...

  7. 将数组写入Plist文件中

    -(void)writeToPlist:(NSArray *)uploadingfiles  Name:(NSString *)name {                  NSMutableArr ...

  8. zookeeper入门系列:paxos协议

    上一章讨论了一种强一致性的情况,即需要分布式事务来解决,本章我们来讨论一种最终一致的算法,paxos算法. paxos算法是由大牛lamport发明的,关于paxos算法有很多趣事.比如lamport ...

  9. WPF treeview扩展

    记录一下工作中遇到的问题,以便以后忘记了可以来看. 在工作中遇到一个问题,就是要实现类型如下的界面,没有使用Telerik和Dev库.本来最开始是想使用Datagrid,但不知道怎么实现treevie ...

  10. python-map的用法

    map()函数 map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. 1.当seq只 ...