Redis的主从复制

一、什么是主从复制

       持久化保证了即使redis服务重启也不会丢失数据,因为redis服务重启后会将硬盘上持久化的数据恢复到内存中,但是当redis服务器的硬盘损坏了可能会导致数据丢失,如果通过redis的主从复制机制就可以避免这种单点故障,如下图:

说明:

  1. 主redis中的数据有两个副本(replication)即从redis1和从redis2,即使一台redis服务器宕机其它两台redis服务也可以继续提供服务。
  2. 主redis中的数据和从redis上的数据保持实时同步,当主redis写入数据时通过主从复制机制会复制到两个从redis服务上。
  3. 只有一个主redis,可以有多个从redis。
  4. 主从复制不会阻塞master,在同步数据时,master 可以继续处理client 请求
  5. 一个redis可以即是主又是从,如下图

 

二、主从复制设置

2.1 从机配置

第一步:复制出一个从机

        [root@localhost redis]# cp bin/ bin2  –r

第二步:修改从机的redis.conf

           语法:Slaveof masterip masterport

           slaveof 192.168.19.26  6379

第三步:修改从机的port地址为6380

                在redis.conf中修改  

第四步:清除从机中的持久化文件

                [root@localhost bin2]# rm -rf appendonly.aof dump.rdb

第五步:启动从机

              [root@localhost bin2]# ./redis-server redis.conf

第六步:启动6380的客户端

             [root@localhost bin2]# ./redis-cli -h 192.168.19.26 -p 6380 

可查看主从配置信息: info replication 

192.168.19.26:6380> info replication
# Replication
role:slave(角色:从机)
master_host:192.168.19.26(主机ip)
master_port:6379(主机端口)

注意:

      主机一旦发生增删改操作,那么从机会将数据同步到从机中

      从机不能执行写操作(读写分离)

192.168.19.26:6380> set ss s
(error) READONLY You can't write against a read only slave.

三 、主从复制原理  

3.1 主从同步?

  • Master接到命令启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令,在后台进程执行完毕之后,master将传送整个数据文件到slave,以完成一次完全同步
  • 全量复制:而slave服务在接收到数据库文件数据后,将其存盘并加载到内存中。(配置好主从复制后,启动从redis
  • 增量复制:Master继续将新的所有收集到的修改命令依次传给slave,完成同步。
  • 但是只要是重新连接master,一次完全同步(全量复制)将被自动执行

3.2 复制存在的问题

由于所有的写操作都是先在Master上操作,然后同步更新到Slave上,所以从Master同步到Slave机器有一定的延迟,当系统很繁忙的时候,延迟问题会更加严重,Slave机器数量的增加也会使这个问题更加严重。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值