我是靠谱客的博主 爱笑往事,最近开发中收集的这篇文章主要介绍redis多机数据库的实现,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

    两个redis服务器,让其中一个服务器变成另外一个服务器的从服务器,只要在从服务器上执行ALAVEOF命令,即可开始从主服务器同步数据到从服务器

整个同步过程会遇到两个问题

    1.同步操作是如何进行的。

     2.如果主服务器的数据库状态被修改,导致了主从服务器的数据库状态出现不一致,如果让主从服务器的数据库重新回到一致状态。

一、同步

     同步的步骤分为以下几步:

      1.从服务器向主服务器发送SYNC命令。

      2.收到SYNC命令的主服务器执行BGSAVE命令,在后台生成一个RDB文件,并使用一个缓冲区记录从现在开始执行的所有写命令,这就相当于增量产生的所有指令都放在缓冲区中,而之前的所有命令都会写入到RDB文件。

      3.当主服务器的BGSAVE命令执行完毕时,主服务器会将BGSAVE命令生成的RDB文件发送给从服务器,从服务器接收并载入这个RDB文件,将自己的数据库状态更新至主服务器执行BGSAVE命令前的数据库状态。

     4.主服务器记录在缓冲区里面的所有写命令发送给从服务器,从服务器执行这些命令,而且主服务器新添加的指令都会写入到缓冲区中一份,在不断的增量发送到从服务器的过程中,使得主从服务器变的完全一致。

     重要点:如果主从服务器已经完全同步了,此时主从之间的网络中断,此时主服务器会不停的接收新的指令,而从服务器无法得到主服务器的指令,造成了数据的不一致,当网络恢复以后,如果再次执行上面的SYNC过程,无疑太浪费资源,因此此处引入了部分重同步功能。部分重同步就是指PSYNC,从服务器向主服务器发送PSYNC命令,然后主服务器向从服务器发送+CONTINUE回复,从服务器接受到这个命令后知道后面开始发送增量命令了,从服务器会将网络中断后的所有命令一次性的发送给从服务器,从而达到主从一直状态,这期间的从服务器都是出于阻塞状态,不会单独接受客户端命令。下面是部分重同步的实现过程

    三个部分组成:

a、主从服务器的复制偏移量  主要记录两者的复制偏移 从而知道哪些需要复制 哪些不需要复制

b、主服务器的复制积压缓冲区

c、服务器的运行ID

最后

以上就是爱笑往事为你收集整理的redis多机数据库的实现的全部内容,希望文章能够帮你解决redis多机数据库的实现所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部