zoukankan      html  css  js  c++  java
  • Redis之持久化和主从同步

      Redis作为内存数据库,所有数据都保存在内存中, 一旦程序停止工作, 数据都将丢失. 需要我们重新从其他地方加载数据. 不过Redis提供了两种方式保存Redis中的数据一种是dump内存直接存入rdb文件中,一种是存在aof文件中,aof文件存储的是一条一条存储和修改数据的命令,类似于mysql的二进制日志形式。

      rdb文件格式由于直接dump内存数据结构,因此重新加载rdb文件速度更快,直接将文件内容读入内存中即可。Redis进行主从同步时,首先slave连接上master,master创建一个进程,将内存中的数据存储为rdb格式到磁盘上,然后通过网络将文件数据发送至slave,rdb文件生成和传输过程中,客户端对master进行的修改都以一条条的命令保存在内存中,rdb文件传输完毕,再将这些命令传递给slave执行。如果参数repl-diskless-sync设置了值,则master创建一个进程不会将数据存储在磁盘中,而是直接发送给slave,其他操作一致。

      如果同时有几个slave连接到master上,则master同时只会创建一个进程将内存中数据dump到磁盘上,因此Redis建议如果一台机器上只有一个Redis实例,则设置的最大内存物理内存的一般左右,确保fork新的进程时,不会将物理内存耗光,导致程序崩溃。

      如果客户端修改master上面数据,则master会将命令同步给slave节点,大部分时候slave连接master所有的数据都会重新同步一次,如果master和slave网络断开时间不长,slave重新连接master,slave会首先发送一个上次同步位置的psync命令,master验证psync命令中同步位置有效,则master不会要求slave同步所有数据,而是从slave发送的位置开始同步,psync命令中同步位置一旦无效,master会要求slave同步所有的数据。

  • 相关阅读:
    java_泛型
    java工具类Collections
    Map集合的遍历
    集合元素顺序的实现
    apk比较版本大小
    存储过程与SQL语句怎么选择
    线程协作-生产者/消费者问题
    线程中断、线程让步、线程睡眠、线程合并
    如何将字符串去重复demo工具
    JavaScript 中的函数介绍
  • 原文地址:https://www.cnblogs.com/ourroad/p/4918744.html
Copyright © 2011-2022 走看看