IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Redis发布订阅、主从复制 -> 正文阅读

[大数据]Redis发布订阅、主从复制

一、Redis发布订阅

Redis发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅(sub)接收消息。
Redis客户端可以订阅任意数量的频道:
第一个:消息发送者,第二个:频道,第三个:消息订阅者
当有新的消息通过PUBLISH命令发送给频道channel1,这个消息就会被发送给订阅他的三个客户端
?
以下操作需要打开两个redis-clc.exe
解释:右边是订阅端,订阅名“kuang”:subscribe kuang
左边是发布者,发布者发送消息到频道? publish kuang "hello"订阅端
"message"表示消息,“kuang”表示频道,“hello”和“hello vv”表示消息的具体内容
Redis通过PUBLISH? SUBSCRIBE? PSUBSCRIBE等命令实现订阅功能
微信公众号:
通过subscribe命令订阅某频道后redis-server里维护了一个字典,字典的键就是一个个频道,而字典的值是链表,链表中保存了所有订阅这个channel的客户端,subscribe命令的关键,就是将客户端添加到给定channel的订阅链表中。
通过publish命令向订阅者发送消息,redis-server会使用给定的频道作为键,在它所维护的channel字典中查找记录了订阅这个频道的所有客户端的链表,遍历这个链表,将消息发布给所有订阅者
pub/sub从字面上理解就是发布与订阅,在Redis中,你可以设定对某一个key值进行发消息以及消息订阅,当一个key值上进行消息发布后,所有订阅它的客户端都会收到相应的消息。比如群聊等。
使用场景
实时消息系统
实时聊天
订阅、关注系统

二、Redis主从复制

概念
主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器,前者称为主节点(master/leader)后者称为从节点(slave/follower);
数据的复制只能是单向的,只能从主节点到从节点。Master以写为主,Slave以读为主
默认:每台Redis服务器都是主节点,且一个主节点可以有多个从节点(或者没有节点),但是一个从节点只能有一个主节点。
主从复制的作用:
1.数据冗余(除了持久化之外)
2.故障恢复(服务冗余)
3.负载均衡(分担服务器负载)
4.高可用基石(是哨兵和集群实施的基础)
对于这种场景,我们可以使用如下架构:
80%的情况在进行读操作
环境配置
只需要配置从库,不需要配置主库
查看当前库的信息:角色是master ,没有从机
至少打开三个端口
复制3个配置文件,然后修改对应的信息
1.port
2.pid名字
3.log文件名字
4.dump.rdb文件名
一般情况下只配置从机、

命令 slaveof? host? 6379
主机可以写,从机不能写,只能读
如果主机断开连接,从机依旧能连接到主机,但是不能写
如果使用命令行配置主从,这个时候重启就会变成主机,但是变回从机,就可以从主机中获取值
replication(复制原理)
Slave启动成功连接到master后会发送一个sync同步命令
Master接到命令,启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令,在后台进程执行完后,master将传输整个数据文件到slave,并完成一次完全同步。
全量复制:slave服务在接收到数据库文件数据后,将其存盘并加载到内存中
增量复制:Master继续将新的收集的修改指令依次传给slave,完成同步
但是只要是重新连接master。一次完全同步(全量复制)将自动执行,数据一定可以在从机中看到
层层链路
上一个M(主节点)连接下一个S(从节点)
此时。中间的仍然是从节点,不能写。
当主机宕机,可以手动让自己变成主机,通过 : slaveof? no? one(手动)
如果此时主机修复,只能重新连接。
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-24 08:01:04  更:2021-11-24 08:03:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:14:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码