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(新)

 

 

 

 

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • SCOM警报通知新特性:即时消息通知

    SCOM警报通知新特性:即时消息通知

  • Mac下SVN基本操作和常见错误

    Mac下SVN基本操作和常见错误

    2021年10月20日
  • Ubuntu 卸载 Docker

    Ubuntu 卸载 Docker1.卸载dockersudoapt-getautoremovedockerdocker-cedocker-enginedocker.iocontainerdrunc2.查看删除docker其他有没有没有卸载干净的包dpkg-l|grepdocker3.卸载相应的包sudoapt-getautoremovedocker-ce-*4.删除docker的相关配置&目录sudorm-rf/etc/systemd/system/docker.serv

  • system WinExec ShellExecuteEx

    system WinExec ShellExecuteExwindows编程的时候经常需要调用操作系统提供的命令,比如调用netuser命令可以在系统中新建一个用户等。    1.最简单的调用方法就是使用函数system(),例如    system(“copyd:\\1.rard:\\2.rar”);    属于CRuntimeLibrary,调用该函数会阻塞调用线程。    优点:简单方便,既

  • 什么是PXE及PXE启动

    什么是PXE及PXE启动PXE(Pre-bootExecutionEnvironment)是由Intel设计的协议,它可以使计算机通过网络启动。协议分为client和server两端,PXEclient在网卡的ROM中,当计算机引导时,BIOS把PXEclient调入内存执行,并显示出命令菜单,经用户选择后,PXEclient将放置在远端的操作系统通过网络下载到本地运行。  PXE协议的成功运行需要解决

  • jdbc java_Springdata

    jdbc java_Springdata刚进公司,人生地不熟,偷偷藏着本《mybatis入土为安》,以为可以靠mybatis混的轻松点,谁知天有不测风云,大家用的是JPA。我这个小白没有听说过,全英文名叫,就是java持久化api,是SUN公司推出的一套基于的规范。持久化想必如雷贯耳,都0202年了,谁还不用个持久化框架啊,举起mybatis。ORM呢?全英文名为:对象关系映射,简单来说为了不用JDBC那一套原始方法来操作数据库,ORM框架横空出世(mybatis、hibernate等等)。…

    2022年10月20日

发表回复

您的电子邮箱地址不会被公开。

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