Redis学习小记5 - 订阅发布&主从复制

Redis学习小记5

Redis订阅发布

参考、详解传送:分布式缓存Redis之发布/订阅(Pub/Sub)

原理:[频道] , [订阅者]-> [订阅者]-> [订阅者]-> [订阅者]-> [订阅者] (哈希表+链表)

相关命令描述例子
PSUBSCRIBE通过模式匹配相应的频道并订阅PSUBSCRIBE m*
PUBLISH发布信息到相应的频道PUBLISH msg hi (注意模式匹配订阅的m*也能收到)

在这里插入图片描述

PUBSUB查看相应频道或者频道订阅者数量 (patterns 接受模式匹配)PUBSUB < subcommand > … args …如PUBSUB CHANNELS msg

pubsub的subcommand如下

127.0.0.1:6379> pubsub help
PUBSUB <subcommand> arg arg ... arg. 

Subcommands are:
1) CHANNELS [<pattern>] -- Return the currently active channels matching a pattern (default: all).
2) NUMPAT -- Return number of subscriptions to patterns.
3) NUMSUB [channel-1 .. channel-N] -- Returns the number of subscribers for the specified channels (excluding patterns,
PUNSUBSCRIBE对应PSUBSCRIBE,取关操作PUNSUBSCRIBE m*
SUBSCRIBE订阅对应频道SUBSCRIBE msg
UNSUBSCRIB取关对应频道UNSUBSCRIB msg

Redis主从复制

主从复制,是指将一台Redis服务器的数据,复制到其他Redis服务器。前者为父节点,后者为从节点。

1. 主从复制主要作用:
  1. 数据冗余(作为后备数据库)
  2. 故障恢复
  3. 负载均衡(主写从读)
  4. 高可用(集群)基石
2. 环境配置(配从机而不配主机,Redis默认为主机)
  1. 查看Redis REPLICATION 配置
127.0.0.1:6379> INFO  REPLICATION
# Replication
role:master
connected_slaves:0
master_replid:f633aa4125b26de00c8637f7f008a12328d54283
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
  1. 配置集群,修改对应信息(多台服务器不用配;从机只能读)
    1. 修改端口 port
    2. 守护线程开启需要修改pidfile
    3. 日志文件名 logfile “server_log.txt”
    4. dump.rdb名 dbfilename dump.rdb
    5. 主机有密码要填上密码 # masterauth < master-password>
    6. 设置从库:命令行:SLAVEOF HOST PORT /配置文件:# slaveof < masterip> < masterport>
    7. 在主机中查看从机信息INFO REPLICATION
3. 复制原理

参考,原文链接:https://www.cnblogs.com/daofaziran/p/10978628.html

3.1 全量同步

Redis全量复制一般发生在Slave初始化阶段,这时Slave需要将Master上的所有数据都复制一份。具体步骤如下:

  • 从服务器连接主服务器,发送SYNC命令;
  • 主服务器接收到SYNC命名后,开始执行BGSAVE命令生成RDB文件并使用缓冲区记录此后执行的所有写命令;
  • 主服务器BGSAVE执行完后,向所有从服务器发送快照文件,并在发送期间继续记录被执行的写命令;
  • 从服务器收到快照文件后丢弃所有旧数据,载入收到的快照;
  • 主服务器快照发送完毕后开始向从服务器发送缓冲区中的写命令;
  • 从服务器完成对快照的载入,开始接收命令请求,并执行来自主服务器缓冲区的写命令;
    在这里插入图片描述
3.2 增量同步

Redis增量复制是指Slave初始化后开始正常工作时主服务器发生的写操作同步到从服务器的过程。
增量复制的过程主要是主服务器每执行一个写命令就会向从服务器发送相同的写命令,从服务器接收并执行收到的写命令。

3.3 Redis主从同步策略

主从刚刚连接的时候,进行全量同步;全同步结束后,进行增量同步。当然,如果有需要,slave 在任何时候都可以发起全量同步。redis 策略是,无论如何,首先会尝试进行增量同步,如不成功,要求从机进行全量同步。

4. 哨兵模式(自动选举,手动请在要当主机中使用命令行SLAVEOF NO ONE)

参考 Redis哨兵(Sentinel)模式 from简书

官网 - Redis Sentinel Documentation

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值