- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
?
?
Redis设计与实现之复制
?
?
Redis中用户通过执行slaveof命令或者设置slaveof选项,让一个服务器去复制另一个服务器。被复制的称为主服务器(master),复制的称为从服务器(slave)。
1,旧版复制功能及其缺点
redis的复制功能,分为同步和命令传播两个操作: 同步:将从服务器的状态更新至主服务器目前所处的状态 命令传播:主服务器对数据库状态进行修改导致主从服务器状态不一致时,让主从服务器数据库恢复至统一状态。
1,1同步
当客户端向服务器发送slaveof命令,要求从服务器复制主服务器时,从服务器要先执行同步操作。 同步操作是从服务器向主服务器发送sync命令完成,执行步骤: 1)从服务器向主服务器发送sync命令 2)收到sync的主服务器开始执行bgsave,在后台生成一个RDB文件,并使用一个缓冲区记录当前开始服务器执行的所有写命令 3)bgsave执行完毕之后,主服务器将bgsave命令生成的RDB文件发送给从服务器。从服务器使用RDB文件,更新数据库到执行bgsave时的状态 4)主服务器将记录在缓冲区中的所有写命令发送给从服务器,从服务器执行这些命令,将数据库更新到主服务器当前的状态
1,2命令传播
同步操作完成之后,主从服务器达到的数据库一致状态并不是一成不变的。当主服务器再执行写命令,就会再次导致主从不一致这个时候需要使用命令传播操作:主服务器将导致主从不一致的写命令发送给从服务器执行,再次达到主从一致状态。
1,3旧版复制功能缺点
Redis中的复制有初次复制和断线后重复制两种。对于初次复制,旧版复制功能可以很好的完成。但是对于断线后复制,旧版复制功能会效率比较低,原因是断线后重复制只需要执行断线期间执行的写命令并不需要重新生成RDB文件,但是旧版复制功能会再次使主服务器执行非常耗费资源的bgsave从而导致效率低下。
2,新版复制功能
新版复制功能解决了旧版复制处理断线重复制遇到的问题,使用psync代替sync命令,将复制分为完整重同步和部分重同步两个模式: 完整重同步:适用于初次复制的情况与sync的执行过程一样。 部分重同步:适用于断线重复制的情况,从服务器断线后重新连接主服务器,并请求同步。主服务器根据情况将断开期间执行的写命令发给从服务器,而不必重新生成RDB文件。 部分重同步功能的实现由三个部分构成: 1,主从服务器各自维护的复制偏移量 2,主服务器的复制积压缓冲区 3,服务器的运行ID 复制偏移量:主从服务器各自维护的复制偏移量表示当前复制了多少字节数据。主服务器想从服务器传播N个字节数据时,就将自己的复制偏移量加N。从服务器每次从主服务器接受N字节的数据,也将自己的复制偏移量加N。主从双方通过复制偏移量判断状态是否一致。 复制积压缓冲区:由主服务器维护的一个固定长度的先进先出队列,默认大小1MB。因为是固定大小,所以当缓冲区满的时候旧元素就会被弹出给新元素留出空间。主服务器运行期间复制积压缓冲区会根据每秒产生的命令数和服务器断线重连的时间间隔进行调整。不小于2*second*write_size_per_second 当主服务器进行命令传播的时候,不仅会将写命令发送给所有的从服务器,也会写入复制积压缓冲区中。因此复制积压缓冲区中保存了一部分最近传播的写命令,并且复制积压缓冲区也会为队列中的每一个字节记录相应的复制偏移量。当从服务器再次连上主服务器时,发送psync命令将自己的offset发给主服务器,主服务根据offset来决定对其执行哪种同步操作: 1)如果offset偏移量后的数据还在复制积压缓冲区中,就执行部分重同步操作,将需要的命令发送给从服务器执行 2)如果offset偏移量后的数据不在复制积压缓冲区中,就执行完整重同步操作。 服务器运行ID:每个Redis服务器(所有)都会在启动的时候自动生成一个40个随机的16进制字符的运行ID。 从服务器进行初次复制的时候,主服务器会将自己的ID发送给从服务器,从服务器会保存主服务器ID。当从服务器断线并重新连接到一个主服务器时,从服务器会将之前保存的ID发送给当前的主服务器: 1)如果从服务器发送的ID和当前主服务器ID相同,可以尝试部分重同步 2)两个ID不同,说明之前链接的不是同一个服务器,要执行完整重同步 psync的执行过程如下:
3,复制功能的实现
使用slaveof 命令,我们让一个从服务器去复制主服务器,详细步骤如下:
3.1,设置主服务器ip和port
从服务器收到命令之后,会在redisServer的masterhost和masterport属性中设置master的ip和port,然后向发送slaveof命令的客户端返回ok,表
您可能关注的文档
- Python语言程序设计-文件和数据格式化.docx
- Python语言程序设计基础.docx
- Python课程设计爬虫篇.docx
- QT学习1:设计可视化窗口的框架-Ui-Class.docx
- RBAC权限系统分析、设计与实现.docx
- Redis+Nginx+JVM+设计模式+Spring全家桶+Dubbo.docx
- Redis+Nginx+设计模式+Spring全家桶+Dubbo精选.docx
- Redis+Nginx+设计模式+Spring全家桶+Dubbo精选概述.docx
- redis-list类型的设计与实现.docx
- redis-string类型的设计与实现.docx
- 2024年浙江省杭州市临安市上甘街道招聘社区工作者真题及参考答案详解一套.docx
- 2024年河南省许昌市长葛市石固镇招聘社区工作者真题含答案详解.docx
- 2024年河南省郑州市登封市大冶镇招聘社区工作者真题及参考答案详解.docx
- 2024年浙江省宁波市余姚市低塘街道招聘社区工作者真题及参考答案详解一套.docx
- 2024年浙江省丽水市莲都区峰源乡招聘社区工作者真题及答案详解1套.docx
- 2024年河南省郑州市中原区石佛镇招聘社区工作者真题及答案详解1套.docx
- 2024年浙江省杭州市萧山区河庄镇招聘社区工作者真题带答案详解.docx
- 2024年浙江省嘉兴市桐乡市河山镇招聘社区工作者真题含答案详解.docx
- 2024年河南省郑州市金水区未来路街道招聘社区工作者真题参考答案详解.docx
- 2024年浙江省宁波市慈溪市观海卫镇招聘社区工作者真题及参考答案详解一套.docx
最近下载
- 物资管理知识题库-填空题.doc VIP
- Yamaha 雅马哈 乐器音响 PSR-SX600 Owner's Manual (Traditional Chinese) 用户手册.pdf
- 2025年危险性较大工程项目领导带班制度.pdf VIP
- 安徽工程大学【个人简历】简单风格四页精美套装简历-简历模板.docx VIP
- 2024年其他类-化验员-水质化验员考试历年常考点试题带答案.docx VIP
- 中国粮油公司年度经营计划.ppt VIP
- 2024年其他类-化验员-水质化验员考试历年常考点试题带答案.docx VIP
- 2024年其他类-化验员-水质化验员考试历年常考点试题带答案版.docx VIP
- 株洲湘江四桥42米现浇箱梁贝雷支架施工技术方案.doc VIP
- GB50312-2016 综合布线系统工程验收规范.docx VIP
文档评论(0)