Redis主从复制实现

Redis中的主从复制,也就是Master-Slave模型,其实现相对比较简单,一般使用在多个Redis实例间的数据同步以及Redis集群中用的比较多。• 工作原理• 特征说明• 如何配置• 验证使用

大家好,又见面了,我是你们的朋友全栈君。

Redis主从复制实现:

Redis中的主从复制,也就是Master-Slave模型,其实现相对比较简单,一般使用在多个Redis实例间的数据同步以及Redis集群中用的比较多。

 

·     工作原理

·     特征说明

·     如何配置

·     验证使用

 

1、工作原理

在Master和Slave互通之后,首先,Slave会发送sync同步指令,当Master收到指令后,将在后台启动存盘进程,同时收集所有来自Slave的修改数据集的指令信息,当后台进程完成之后,Master将发送对应的数据库文件到对应的Slave中,以完成一次完整的同步工作。其次Slave在接受到数据库文件之后,将其存盘并加载到内存中。最后,Master继续收集修改命令和新增的修改指令,并依次发送给Slave,其将在本次执行这些数据的修改命令,从而最终达到数据同步的实现。

 

NOTE:

A、 当Master与Slave出现当机时,Slave会自动重新连接并一次性完成同步;

B、 当Master收到多个Slave发送sync指令时,其会在后台开启个队列来保持多个Slave可以有序高效的执行;

 

2、特征说明

A、一个Master可以同步多个Slave,实现主从复制;

B、一个Slave同时也可以接收其它Slaves的连接和同步请求,以缓解Master同步的压力;

C、Master Server是以非阻塞的方式为Slave提供服务,所以其在与Slave同步时,也可以接受正常的查询和修改的指令;

D、Slave Server同样也是以非阻塞方式完成数据同步,在同步期间,也可以继续接受客户端的查询请求;

E、Master可以将数据保存操作交给Slaves完成,从而避免了在Master中要有独立的进程来完成此操作;

 

3、如何配置

因为限于只有一台电脑设备,所以这里是在一台设备上同时启动两个Redis服务器实例,端口号分别为:6379和6380,具体如下操作:

A、创建6379和6380配置文件

redis.conf:6379为默认配置文件,作为Master服务配置;

redis_6380.conf:6380为同步配置,作为Slave服务配置;

 

B、配置slaveof同步指令

在Slave对应的conf配置文件中,添加以下内容:

slaveof 127.0.0.1 6379

 

NOTE:

添加slaveof指令,重启redis服务,生效Master-Slave同步执行;

修改该文件的port为6380,以及数据库文件存放为止dir,确保Master和Slave存放的数据不冲突和被覆盖;

 

4、验证使用

A、开启Master和Slave服务

$redis-server /redis/etc/redis.conf  // 6379实例-Master

$redis-server /redis/etc/redis_6380.conf // 6380实例-Slave

然后,在两个客户端打开redis-cli:

$redis-cli –p 6379  // 6379实例客户端

$redis-cli  -p 6380  // 6380实例客户端

 

B、在Master中添加mykey和mykey2键值

Redis主从复制实现

 

C、在Slave中检查mykey和mykey2是否存在

Redis主从复制实现

 

从上面的截图可以看出,Master和Slave已经同步完成,因为在Slave中没做任何的set/get操作,所有操作在Master进行,但是可以在Slave中查看到同样的操作。

 

D、在Master中删除mykey2,查看Slave中显示

在Master删除mykey2:

Redis主从复制实现

在Slave查看mykey2是否存在:

Redis主从复制实现

 

E、在Slave中新增和删除键可以吗?

默认在Slave中修改键会报错:

(error) READONLY You can’t write against a read only slave.

 

原因是需要设置slave-read-only为no,重启服务之后生效,然后再执行set/get是可以的,但是不会同步到Master中去,因为需要在Master的redis.conf添加slaveof<server>:<port>才行,此时Master也已经变为Slave了。

 

 

好了,到这里已经使用例子总结说明了,Redis的复制原理、特性以及主从复制的使用。

 

 

 

 

技术讨论群:

489451956(新)

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/127044.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月8日 下午11:20
下一篇 2022年4月8日 下午11:20


相关推荐

  • PyCharm激活码永久有效PyCharm2017.1.8激活码教程-持续更新,一步到位

    PyCharm激活码永久有效PyCharm2017.1.8激活码教程-持续更新,一步到位PyCharm激活码永久有效2017.1.8激活码教程-Windows版永久激活-持续更新,Idea激活码2017.1.8成功激活

    2022年6月19日
    39
  • jsp开发环境搭建实验报告_eclipse安卓开发环境搭建

    jsp开发环境搭建实验报告_eclipse安卓开发环境搭建一.配置Java开发工具(JDK)1.下载JDKhttp://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html使用默认安装路径,默认安装在C盘中。如果更改安装路径,在安装jre时,更改安装路径,会出现选择文件夹不为空的情况。所以最好的办法是安装在默认路径下。2.环

    2022年10月20日
    4
  • echarts中国地图 飞线 热力

    echarts中国地图 飞线 热力template divstyle width 100 height 100 padding 5px10px divid map style width 788px height 700px divid map style width 788px height 700px divstyle width 100 height 100 padding 5px10px template script importaxiosf axios importchinaf script

    2026年3月26日
    2
  • Springboot + Redis 哨兵模式

    Springboot + Redis 哨兵模式RedisSentine 是一个分布式系统 你可以在一个架构中运行多个 Sentinel 进程 progress 这些进程使用流言协议 gossipprotoc 来接收关于主服务器是否下线的信息 并使用投票协议 agreementpro 来决定是否执行自动故障迁移 以及选择哪个从服务器作为新的主服务器

    2026年3月17日
    2
  • java 佛祖保佑_佛祖保佑,永无bug

    java 佛祖保佑_佛祖保佑,永无bug写这一篇博客是因为有意思 想和大家分享一下 新建一个类读取并打印文本内容 Author Date 2017 2 8 17 37 publicclassB publicstatic String args throwsExcept Class getResource 文件名 查找带有给定

    2026年3月18日
    2
  • python从linux下载文件_python gzip

    python从linux下载文件_python gzip解决python调用OpenCV保存视频时使用”avc1″格式出现#Couldnotfindencoderforcodecid27:Encodernotfound的错误(此错误不能保存视频文件),以及使用”mpeg”格式出现的#OpenCV:FFMPEG:tag0x6765706d/’mpeg’isnotsupportedwithcodecid2a…

    2026年4月13日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号