开发者社区> 问答> 正文

redis持久化的几种方式

redis持久化的几种方式

展开
收起
不语奈何 2020-01-09 19:49:19 1115 0
1 条回答
写回答
取消 提交回答
  • 精于基础,广于工具,熟于业务。

    1、快照(snapshots)   缺省情况情况下,Redis把数据快照存放在磁盘上的二进制文件中,文件名为dump.rdb。你可以配置Redis的持久化策略,例如数据集中每N秒钟有超过M次更新,就将数据写入磁盘;或者你可以手工调用命令SAVE或BGSAVE。   工作原理   . Redis forks.   . 子进程开始将数据写到临时RDB文件中。   . 当子进程完成写RDB文件,用新文件替换老文件。   . 这种方式可以使Redis使用copy-on-write技术。 2、AOF   快照模式并不十分健壮,当系统停止,或者无意中Redis被kill掉,最后写入Redis的数据就会丢失。这对某些应用也许不是大问题,但对于要求高可靠性的应用来说,   Redis就不是一个合适的选择。   Append-only文件模式是另一种选择。   你可以在配置文件中打开AOF模式 3、虚拟内存方式   当你的key很小而value很大时,使用VM的效果会比较好.因为这样节约的内存比较大.   当你的key不小时,可以考虑使用一些非常方法将很大的key变成很大的value,比如你可以考虑将key,value组合成一个新的value.   vm-max-threads这个参数,可以设置访问swap文件的线程数,设置最好不要超过机器的核数,如果设置为0,那么所有对swap文件的操作都是串行的.可能会造成比较长时间的延迟,但是对数据完整性有很好的保证.

      自己测试的时候发现用虚拟内存性能也不错。如果数据量很大,可以考虑分布式或者其他数据库

    2020-01-09 19:49:51
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Redis集群演化的心路历程——从2.x到3.0时代 立即下载
微博的Redis定制之路 立即下载
云数据库Redis版的开源之路 立即下载