参考:狂神说Java
主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master/Leader),后者称为从节点(Slave/Follower),
数据的复制是单向的!只能由主节点复制到从节点(主节点以写为主、从节点以读为主)。
默认情况下,每台Redis服务器都是主节点,
一个主节点可以有0个或者多个从节点,但每个从节点只能由一个主节点。(父子关系)
只配置从库,不用配置主库!,因为每个redis默认都是主库。
info replication
# 查看当前库的信息 # Replication
在这里插入代码片127.0.0.1:6379> info replication # 查看当前库的信息 # Replication
role:master # 角色
master connected_slaves:0 # 没有从机
master_replid:b63c90e6c501143759cb0e7f450bd1eb0c70882a
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:0
second_repl_offset:-1
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0
通过配置文件启动redis,分别在三个端口启动redis服务
windows操作如下
分别改端口
开三个命令行
windows/linux: 在redis目录下查看是否启动成功,有log文件
linux:修改完毕之后,启动我们的3个redis服务器,可以通过进程信息查看!
默认情况下,每台Redis服务器都是主节点;我们一般情况下只用配置从就好了!
认老大! 一主 (79)二从(80,81)
开三个窗口,命令如下
命令 slaveof [ip] [port]
如下配置6380。6381的配置操作相同
127.0.0.1:6380> SLAVEOF 127.0.0.1 6379 # SLAVEOF host 6379 找谁当自己的老大!
OK
127.0.0.1:6380> info replication
# Replication
role:slave # 当前角色是从机
master_host:127.0.0.1 # 可以的看到主机的信息
master_port:6379
master_link_status:up
master_last_io_seconds_ago:3
master_sync_in_progress:0
slave_repl_offset:14
slave_priority:100
slave_read_only:1
connected_slaves:0 master_replid:a81be8dd257636b2d3e7a9f595e69d73ff03774e
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:14
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:14
# 在主机中查看!
127.0.0.1:6379> info replication
# Replication
role:master connected_slaves:1 # 多了从机的配置
slave0:ip=127.0.0.1,port=6380,state=online,offset=42,lag=1 # 多了从机的配置
master_replid:a81be8dd257636b2d3e7a9f595e69d73ff03774e
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:42
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:42
info replication
如果两个都配置完了,就是有两个从机
真实的从主配置应该在配置文件中配置,这样的话是永久的,我们这里用的是命令,暂时的!
去掉注释,换成对应的ip和端口
主机可以写,从机不能写只能读!主机中的所有信息和数据,都会自动从机保存!
主机断开连接,从机依旧连接到主机的,但是没有写操作,这个候,主机如果回来了,从机依旧可以直接获取到主机写的信息!
如果是使用命令行来配置的主从(而不是配置文件),这个时候从机如果重启了,就会变回主机!但是只要变为从机,立马就会从主机中获取值!
上一个M链接下一个 S!
这时候也可以完成我们的主从复制!
如果没有老大了,这个时候能不能选择一个老大出来呢?在哨兵模式之前需要手动!
如果主机断开了连接,我们可以使用 SLAVEOF no one
让自己变成主机!其他的节点就可以手动连接到最新的这个主节点(手动)!如果这个时候老大修复了,那就只能重新配置连接!
上面这些都是手动的,后面会有哨兵模式(自动)