7.redis主从配置

redis复制的非常重要特性:

  • 一个Master可以有多个Slaves。

  • Slaves能过接口其他slave的链接,除了可以接受同一个master下面slaves的链接以外,还可以接受同一个结构图中的其他slaves的链接。

  • redis复制是在master段是非阻塞的,这就意味着master在同一个或多个slave端执行同步的时候还可以接受查询。

  • 复制在slave端也是非阻塞的,假设你在redis.conf中配置redis这个功能,当slave在执行的新的同步时,它仍可以用旧的数据信息来提供查询,否则,你可以配置当redis slaves去master失去联系是,slave会给发送一个客户端错误。

  • 为了有多个slaves可以做只读查询,复制可以重复2次,甚至多次,具有可扩展性(例如:slaves对话与重复的排序操作,有多份数据冗余就相对简单了)。

  • 他可以利用复制去避免在master端保存数据,只要对master端redis.conf进行配置,就可以避免保存(所有的保存操作),然后通过slave的链接,来实时的保存在slave端。

redis复制是怎么进行工作

如果设置了一个slave,不管是在第一次链接还是重新链接master的时候,slave会发送一个同步命令

然后master开始后台保存,收集所有对修改数据的命令。当后台保存完成,master会将这个数据文件传送到slave,然后保存在磁盘,加载到内存中;master接着发送收集到的所有的修改数据的命令,这好比一个流命令,是redis协议本身来实现的。

你可以自己通过远程登录来进行尝试,当服务器在做一些工作并发送同步命令的时候链接到redis端口,你将会看到大量的数据传输,然后收到的每个命令会会显示在远程登录的会话中。

当master和slave因一些故障当机时,slaves会自动的重链,如果master收到多个slave的同步请求,master会执行一个后台保存,以确保所有的slaves都是正常的。

当master和slave能够维持链接,就会有一个完整的同步进行。

 

配置

我们这里在同一个机器上配置:

    Master  127.0.0.1 4444 

    Salves   127.0.0.1 6379

1.修改redis.conf 在salves中配置要复制的master节点

    # slaveof <masterip> <masterport>
     slaveof 127.0.0.1 4444

2.设置salves到master的认证

如果master需要通过密码登陆,那就需要配置slave在进行所有同步操作也要使用到密码。

# masterauth <master-password>
masterauth liuli

3.启动Maser 和Salves

 
7.redis主从配置_第1张图片
 

 4.验证

 
7.redis主从配置_第2张图片
 5.修改Master看Salves数据变化

 
7.redis主从配置_第3张图片
 

 

你可能感兴趣的:(redis)