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. 主从复制主要作用:
- 数据冗余(作为后备数据库)
- 故障恢复
- 负载均衡(主写从读)
- 高可用(集群)基石
2. 环境配置(配从机而不配主机,Redis默认为主机)
- 查看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
- 配置集群,修改对应信息(多台服务器不用配;从机只能读)
- 修改端口 port
- 守护线程开启需要修改pidfile
- 日志文件名 logfile “server_log.txt”
- dump.rdb名 dbfilename dump.rdb
- 主机有密码要填上密码 # masterauth < master-password>
- 设置从库:命令行:SLAVEOF HOST PORT /配置文件:# slaveof < masterip> < masterport>
- 在主机中查看从机信息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 策略是,无论如何,首先会尝试进行增量同步,如不成功,要求从机进行全量同步。