亿级流量电商详情页系统实战-8.redis replication

1.图解基本原理

在这里插入图片描述

2.核心机制

  • redis采用异步方式复制数据到slave节点,不过redis 2.8开始,slave node会周期性地确认自己每次复制的数据量
  • 一个master node是可以配置多个slave node的
  • slave node也可以连接其他的slave node
  • slave node做复制的时候,是不会block master node的正常工作的
  • slave node在做复制的时候,也不会block对自己的查询操作,它会用旧的数据集来提供服务; 但是复制完成的时候,需要删除旧数据集,加载新数据集,这个时候就会暂停对外服务了
  • slave node主要用来进行横向扩容,做读写分离,扩容的slave node可以提高读的吞吐量

3.master持久化对于主从架构的安全保障的意义

  • 如果采用了主从架构,那么建议必须开启master node的持久化!

  • 不建议用slave node作为master node的数据热备,因为那样的话,如果你关掉master的持久化,可能在master宕机重启的时候数据是空的,然后可能一经过复制,salve node数据也丢了
    (1) master -> RDB和AOF都关闭了 -> 全部在内存中
    (2) master宕机,重启,是没有本地数据可以恢复的,然后就会直接认为自己的数据是空的
    (3) master就会将空的数据集同步到slave上去,所有slave的数据全部清空
    (4) 100%的数据丢失
    (5) 即使采用了后续讲解的高可用机制,slave node可以自动接管master node,但是也可能sentinal还没有检测到master failure,master node就自动重启了,还是可能导致上面的所有slave node数据清空故障

猜你喜欢

转载自blog.csdn.net/weixin_42868638/article/details/113122690