Redis主从复制读写分离故障主从切换

Redis主从复制读写分离
一. 主从复制
  1. 准备3个实例Redis,端口分别为6379(master主),6380(slave1从1),6381(slave2从2)

  2. 在slave1和slave2的redis.conf配置文件中分别添加
    slaveof 127.0.0.1 6379 (关联本地端口为6379的Redis)

    masterauth 123456 :master密码

    requirepass 123456 :当前实例密码

  3. 先启动Master实例再启动slave则可以完成主从复制操作,后期可以实现水平扩容(只要将实例的redis.conf配置文件添加第2步操作即可)

  4. 在slave节点执行info replication可以查询当前节点信息以及master节点

    1、主从架构的核心原理

    当启动一个slave node的时候,它会发送一个PSYNC命令给master node

    如果这是slave node重新连接master node,那么master node仅仅会复制给slave部分缺少的数据; 否则如果是slave node第一次连接master node,那么会触发一次full resynchronization

    开始full resynchronization的时候,master会启动一个后台线程,开始生成一份RDB快照文件,同时还会将从客户端收到的所有写命令缓存在内存中。RDB文件生成完毕之后,master会将这个RDB发送给slave,slave会先写入本地磁盘,然后再从本地磁盘加载到内存中。然后master会将内存中缓存的写命令发送给slave,slave也会同步这些数据。

    slave node如果跟master node有网络故障,断开了连接,会自动重连。master如果发现有多个slave node都来重新连接,仅仅会启动一个rdb save操作,用一份数据服务所有slave node。

    2、主从复制的断点续传

    从redis 2.8开始,就支持主从复制的断点续传,如果主从复制过程中,网络连接断掉了,那么可以接着上次复制的地方,继续复制下去,而不是从头开始复制一份

    master node会在内存中常见一个backlog,master和slave都会保存一个replica offset还有一个master id,offset就是保存在backlog中的。如果master和slave网络连接断掉了,slave会让master从上次的replica offset开始继续复制

    但是如果没有找到对应的offset,那么就会执行一次resynchronization

主配置
#端口
port 6379 

#以后台进程方式运行
daemonize yes

pidfile "/data/soft/redis/redis_6379.pid"

#日志等级
loglevel notice
logfile "/data/soft/redis/log/redis6379.log"

#dump.rdb与aof存放路径
dir "/data/soft/redis/6379"

#开启AOF模式
appendonly yes
#每秒保存一次AOF
appendfsync everysec
no-appendfsync-on-rewrite yes
#当文件超64mb一倍时创建新的aof
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
#其他默认
从配置
port 6381

daemonize yes

pidfile "/data/soft/redis_slave2/redis_6381.pid"

dir "/data/soft/redis_slave2/data"

loglevel notice
logfile "/data/soft/redis_slave2/log/redis6381.log"

#关联ip为127.0.0.1 端口为6379
slaveof 127.0.0.1 6379

#master节点的密码
masterauth 123456
#当前节点的密码 
requirepass 123456
#其他默认
二.主从切换
  1. 为了解决当master宕机时的情况利用Redis提供sentinel(哨兵)完成主从故障切换,类似zookeeper,并使用投票协议(agreement protocols)来决定是否执行自动故障迁移

    以及选择哪个从服务器作为新的主服务器。

  2. 配置sentinel(哨兵)配置文件

	#sentinel端口
	port 26380

	#工作路径,注意路径不要和主重复
	dir "/data/soft/redis/sentinel"

	# 守护进程模式
	daemonize yes

	# 指明日志文件名
	logfile "/data/soft/redis/sentinel/sentinel.log"

	#哨兵监控的master,主从配置一样,
	sentinel monitor mymaster 127.0.0.1 6379 1

	# master或slave多长时间(默认30秒)不能使用后标记为s_down状态。
	sentinel down-after-milliseconds mymaster 5000

	#若sentinel在该配置值内未能完成failover操作(即故障时master/slave自动切换),则认为本次failover失败。
	sentinel failover-timeout mymaster 18000
	
	#设置master和slaves验证密码
	sentinel auth-pass mymaster 123456
  1. 主从配置sentinel都启动src/redis-sentinel sentinel.conf --sentinel实现故障主从切换
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值