一、环境准备
master:192.168.1.203
slave:192.168.1.202
分别已经装redis,防火墙和selinux均已关闭
二、Redis主从配置
master配置文件不用动
slave配置文件上加上如下内容:
slaveof 192.168.1.203 6379 (主服务器ip和redis端口号)
masterauth passwd //主服务器密码,如果没有可以不加
分别启动master和slave
测试主从是否配置成功,在主服务器创建个key
set key1 fansik
在从服务器上去看看从服务器上是否有这个key
get key1
三、Redis主从其他相关配置
slave-read-only yes #让从只读
repl-ping-slave-period 10 #设置slave向master发起ping的频率,每10秒发起一次
repl-timeout 60 #设置slave ping不通master多少s后就超时
repl-disable-tcp-nodelay no #是否开启tcp_nodelay,开启后将会使用更少的带宽,但会有延迟,所以建议关闭
repl-backlog-size 1mb #同步队列的长度,backuplog是master的一个缓冲区,主从断开后,master会把数据写到缓冲区,slave再次连接会从缓冲区中同步数据
repl-backlog-ttl 3600 #主从断开后,缓冲区的有效期,默认1小时
slave-priority 100 #多个slave是可以设置优先级的,数值越小优先级越高,应用于集群中,支持slave切换为master,优先级最高的才会切换
min-slaves-to-write 3 #和下面的一起使用,他的意思是master发现有超过3个slave的延迟高于10s,那么master就会暂时停止写操作。这两个数值任何一个为0,则关闭该功能,默认第一数值是0
min-slaves-max-lag 10