Redis那些事儿(二)

news2025/1/13 7:43:07

文章目录

    • 1. 前言
    • 2. 消息队列(发布和订阅)
      • 应用场景:消息通知、Websocket集群
    • 3. WebSocket集群示例

1. 前言

        接着上一篇Redis那些事儿(一) ,这一篇主要介绍Redis的发布和订阅功能,可以实现高效的消息通信和事件驱动架构。Redis的发布和订阅功能是一种消息传递模式,通过该功能可以实现消息的广播和订阅。Redis的发布和订阅功能是异步的,发布者和订阅者之间没有直接的通信。当发布者将消息发送到频道后,Redis会将消息传递给所有订阅了该频道的订阅者。订阅者会在接收到消息后立即进行处理,而不需要发布者等待。

2. 消息队列(发布和订阅)

应用场景:消息通知、Websocket集群

        这种发布和订阅模式可以用于实现实时消息推送、事件通知、分布式系统之间的信息交互等场景。Redis的发布和订阅功能,可以实现高效的消息通信和事件驱动架构,作为轻量级的消息中间件,从一定程度上可以替代RabbitMQ、ActiveMQ等主流消息中间件的部分功能,非常好用,示例代码如下:

基础发布订阅实体类

用于存放消息、用户ID等信息,广播实体不需要用户ID

@Data
public class SendMsgAll {
    //发布业务数据(json字符串)
    private String msg;
}
@Data
public class SendMsg {
    //发布业务数据(json字符串)
    private String msg;
    //用户ID
    private String userId;
}

发布者

消息发布订阅的发起方,依赖注入StringRedisTemplate工具类,提供两个方法分别用于广播发送和一对一发送,使用convertAndSend方法进行消息发送处理。此处定义了两个channel,分别是all-topic和single-topic,后期在订阅者中会通过这个channel进行绑定。

@Component
public class RedisPublisher {

    @Autowired
    private StringRedisTemplate redisTemplate;
    
    public void sendMessageAll(String message) {
        SendMsgAll sendMsgAll = new SendMsgAll();
        sendMsgAll.setMsg(message);
        redisTemplate.convertAndSend("all-topic", JSON.toJSONString(sendMsgAll));
    }
    
    public void sendMessageById(String userId, String message) {
        SendMsg sendMsg = new SendMsg();
        sendMsg.setUserId(userId);
        sendMsg.setMsg(message);
        redisTemplate.convertAndSend("single-topic", JSON.toJSONString(sendMsg));
    }
}

订阅者

消息发布订阅的接收方,定义两个方法,分别对应发布者的广播发送方法和一对一发送方法

@Component
public class RedisSubscriber {

    /**
     * 处理一对一消息
     */
    public void sendMsg(String message) {
        SendMsg msg = JSON.parseObject(message, SendMsg.class);
        //TODO 一对一业务处理
    }

    /**
     * 处理广播消息
     */
    public void sendAllMsg(String message){
        SendMsgAll msg = JSONObject.parseObject(message, SendMsgAll.class);
        //TODO 广播业务处理
    }
}

订阅者(发布、订阅关系绑定配置)

与订阅者类RedisSubscriber必须在一个微服务下,与发布者类RedisPublisher不一定在同一个微服务下。添加redis消息队列监听,监听channel消息主题的消息,使用messageListenerAdapter()中设置的类和方法处理消息,添加订阅消息处理类,通过反射获取处理类中的处理方法。

@Configuration
public class RedisMessageListenerConfig {
    
    @Autowired
    private RedisSubscriber redisSubscriber;

    /**
     * 监听redis中的订阅信息
     */
    @Bean
    public RedisMessageListenerContainer getRedisMessageListenerContainer(RedisConnectionFactory redisConnectionFactory) {
        RedisMessageListenerContainer redisMessageListenerContainer = new RedisMessageListenerContainer();
        redisMessageListenerContainer.setConnectionFactory(redisConnectionFactory);
        //监听single-topic消息主题的消息
        redisMessageListenerContainer.addMessageListener(messageListenerAdapter(), new PatternTopic("single-topic"));
        //监听all-topic消息主题的消息
        redisMessageListenerContainer.addMessageListener(messageAllListenerAdapter(), new PatternTopic("all-topic"));
        return redisMessageListenerContainer;
    }

    /**
     * 订阅消息处理类,通过反射获取处理类中的sendMsg方法
     */
    @Bean
    public MessageListenerAdapter messageListenerAdapter() {
        return new MessageListenerAdapter(redisSubscriber, "sendMsg");
    }

    /**
     * 订阅消息处理类,通过反射获取处理类中的sendAllMsg方法
     */
    @Bean
    public MessageListenerAdapter messageAllListenerAdapter(){
        return new MessageListenerAdapter(redisSubscriber, "sendAllMsg");
    }
}

3. WebSocket集群示例

在这里插入图片描述

        由于WebSocket是长连接,session保存在一个Server中,所以在不同Server在使用WebSocket推送消息时就需要获取对应的session进行推送,在分布式系统中就无法获取到所有session。这是Websocket集群中遇到的主要问题,这里就需要使用一个中间件将消息推送到各个系统中,使用Redis的sub/pub功能就可以完美解决。此时,消息发布者位于待推送生产消息微服务中,消息订阅者位于集群下的各个WebSocket服务中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1172997.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

代码随想录算法训练营第11天|20. 有效的括号 1047. 删除字符串中的所有相邻重复项 150. 逆波兰表达式求值

JAVA代码编写 20. 有效的括号 给定一个只包括 (,),{,},[,] 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括…

2024最新mac电脑清理垃圾的软件有哪些?

mac电脑是许多人喜爱的电子产品,它拥有优美的设计、流畅的操作系统和强大的性能。但是,随着使用时间的增长,mac电脑也会积累一些不必要的垃圾文件,这些文件会占用宝贵的存储空间,影响电脑的运行速度和稳定性。因此&…

华为OD机试 - 服务失效判断 - 逻辑分析(Java 2023 B卷 200分)

目录 专栏导读一、题目描述二、输入描述三、输出描述1、输入2、输出3、说明 四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题&a…

第五章:java标识符|关键字|保留字|键盘输入

系列文章目录 文章目录 系列文章目录前言一、标识符二、关键字三、保留字四、键盘输入语句总结 前言 java程序就是对象的操作,对象名要起的好。 一、标识符 标识符命名规范例子包名多单词组成时所有字母都小写: aaa.bbb.ccccom.hsp.crm类名、 接口名多单…

Pycharm的安装与基本使用

Pycharm的安装与基本使用 一、Pycharm介绍1.1 Pycharm简介1.2 Pycharm特点 二、Pycharm软件下载2.1 Pycharm官网2.2 下载Pycharm 三、安装Pycharm3.1 指定安装目录3.2 勾选安装选项3.3 选择菜单目录3.4 安装成功 四、Pycharm的初始配置4.1 新建工程4.2 选择Python解释器4.3 打开…

阅读论文StyleGAN2-ada

在图像分类任务中,使用旋转、噪声等数据增强方法训练图像分类器,可以提高分类器对这些保留语义的扭曲的不变性,这是图像分类器极为期望的一种质量。 引用Bora等人的工作,指出只要增强过程可以表示为概率分布上的可逆变换,那么训练过程中网络可以消除这种增强,找到正确的分布。…

Windows ObjectType Hook 之 OkayToCloseProcedure

1、背景 Object Type Hook 是基于 Object Type的一种深入的 Hook,比起常用的 SSDT Hook 更为深入。 有关 Object Type 的分析见文章 《Windows驱动开发学习记录-ObjectType Hook之ObjectType结构相关分析》。 这里进行的 Hook 为 其中之一的 OkayToCloseProcedure。…

(后续补充)vue+express、gitee pm2部署轻量服务器

首先 防火墙全部关闭算了 首先 防火墙全部关闭算了 首先 防火墙全部关闭算了 首先 防火墙全部关闭算了 首先 防火墙全部关闭算了 首先 防火墙全部关闭算了 关闭防火墙 systemctl stop firewalld 重新载入防火墙使设置生效 firewall-cmd --reload 后端的 pm2.config.cjs …

一文理解JPA中的save()方法为什么有时候只能插入无法更新

总结:使用save()方法更新某一具体的记录(如用户密码),必须要提供该记录的ID。 以常见的用户管理为例,当我们调用userRepository.save()时,这是它背后的逻辑: 如果实体的ID为null或者不在数据库…

C++标准模板(STL)- 类型支持 (类型属性,is_abstract,is_signed,is_unsigned)

类型特性 类型特性定义一个编译时基于模板的结构&#xff0c;以查询或修改类型的属性。 试图特化定义于 <type_traits> 头文件的模板导致未定义行为&#xff0c;除了 std::common_type 可依照其所描述特化。 定义于<type_traits>头文件的模板可以用不完整类型实例…

Qt学习:图形视图框架的使用

文章目录 前言一、场景、视图和图形项的介绍二、图形视图框架的坐标系统三、图形视图框架的事件处理四、示例完整代码五、QtCreator官方示例总结 前言 近期重温了一下Qt中的图形视图框架&#xff0c;这里将所学习的内容进行记录总结。这个框架提供了一个基于图形项的模型视图编…

基于match_phrase搜索的分词优化

ES 的match_phrase 搜索需要完整匹配输入的内容&#xff0c;比如我们搜索 ‘中国人民’ &#xff0c;要保证的是doc中必须有 ‘中国人民’ 的内容出现。再比如我们搜索 ‘国人民’ 时&#xff0c;结果集中的 doc 中就要有 ‘国人民’ 的内容。一般在使用match 或 term 搜索的时…

DL Homework 6

目录 一、概念 &#xff08;1&#xff09;卷积 &#xff08;2&#xff09;卷积核 &#xff08;3&#xff09;特征图 &#xff08;4&#xff09;特征选择 &#xff08;5&#xff09;步长 &#xff08;6&#xff09;填充 &#xff08;7&#xff09;感受野 二、探究不同卷…

植物花粉深度学习图片数据集大合集

最近收集了一波有关于植物花粉的图片数据集&#xff0c;可以用于相关深度学习模型的搭建&#xff0c;废话不多说&#xff0c;上数据集&#xff01;&#xff01;&#xff01; 1、23种花粉类型805张花粉图像数据集 关于此数据&#xff1a;花粉种类和类型的分类是法医抱粉学、考…

2023年中国金融控股公司研究报告

第一章 行业概况 1.1 定义 金融控股公司这一术语最初源自美国&#xff0c;特别是在美国的《金融服务法案》关于银行控股公司组织结构的条文中&#xff0c;首次出现了“金融控股公司”&#xff08;Financial Holding Company&#xff09;这一法律术语&#xff0c;尽管法案中并…

2023年【高压电工】报名考试及高压电工最新解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 高压电工报名考试考前必练&#xff01;安全生产模拟考试一点通每个月更新高压电工最新解析题目及答案&#xff01;多做几遍&#xff0c;其实通过高压电工作业考试题库很简单。 1、【单选题】 ()是指继电器不动作时处于…

Windows 内置Linux子系统的配置(From WSL1 to WSL2)

目录 我是如何从WSL1转到WSL2的? WSL1与WSL2的功能区别: 配置下载源 SSH配置 优雅使用windows的Linux子系统 我是如何从WSL1转到WSL2的? 第一次安装的子系统是WSL1的&#xff0c;因为不能使用systemctl &#xff0c;以及因为WSL1没有完整的Linux内核,所以使得WSL1很多命令…

vivado查看报告和消息1

AMD Vivado ™ 集成设计环境 (IDE) 可生成报告和消息 &#xff0c; 以便告知您各种工具交互期间的设计或设计进程状态。报告由 您&#xff08; 或工具 &#xff09; 在执行设计流程中的任意关键步骤时生成。报告可汇总有关设计的具体信息。 本工具可在设计进程中每个步骤自动…

软通杯算法竞赛--周赛题目(一)

目录 一、S属性大爆发 二、日期杯 三、 三人行必由我师 四、集合之差 五、咱们计算机不懂烷烃 六、适度跑步健康长寿 一、S属性大爆发 测试用例 5 esS qwert codeforces PoSgju LkkJKkO 输出案例 二、日期杯 输入案例&#xff1a; 3 2022 2022 11 1900 2100 15 1989 20…

EtherCAT主站写从站EEPROM抓包分析

0 工具准备 1.EtherCAT主站 2.EtherCAT从站&#xff08;本文使用步进电机驱动器&#xff09; 3.Wireshark1 抓包分析 1.1 报文总览 本文主站设置从站1字地址为0的EEPROM数据为0x3C00&#xff08;设置完毕后请还原字0的EEPROM数据&#xff09;&#xff0c;使用Wireshark抓取到…