在两个java项目中实现Redis的发布订阅模式

如何在两个java项目中实现Redis的发布订阅模式?

    • 1. Redis简介
    • 2. 发布订阅模式介绍
    • 3. 实现思路
    • 4. 代码实现及详细解释
      • 4.1. RedisUtil
      • 4.2. Publisher
      • 4.3. Subscriber
      • 4.4. 运行程序

目录:

  1. Redis简介
  2. 发布订阅模式介绍
  3. 实现思路
  4. 代码实现及详细解释

1. Redis简介

Redis是一种高性能的键值存储系统,常用于缓存、分布式会话和实时分析等场景。它支持多种数据结构(如字符串、哈希、列表、集合和有序集合),同时具备高速读写和持久化功能。

2. 发布订阅模式介绍

Redis的发布订阅模式是其提供的一种通信模式,在这种模式下,消息发布者将消息发送到一个频道,所有订阅该频道的订阅者都会收到这个消息。发布者和订阅者之间通过频道进行信息传递,可以实现解耦和异步处理。

3. 实现思路

要在两个Java项目中实现Redis的发布订阅模式,需要使用Redis的Java客户端,如jedis或lettuce。下面是一种通用的实现思路:

  1. 引入Redis的Java客户端依赖:
    在两个项目的pom.xml文件中,引入Redis的Java客户端依赖,如jedis或lettuce。可以通过Maven或Gradle等构建工具来管理依赖关系。

  2. 初始化Redis连接:
    在每个Java项目中,创建一个RedisUtil类来管理Redis连接。在该类中,可以通过配置文件或硬编码的方式,初始化Redis连接池,并提供获取和释放连接的方法。

  3. 实现发布者:
    在发布者项目中,创建一个Publisher类,通过RedisUtil获取Redis连接,并使用发布方法将消息发送到指定频道。在频道上发布消息时,可以将消息序列化为字符串或其他形式进行传输。

  4. 实现订阅者:
    在订阅者项目中,创建一个Subscriber类,通过RedisUtil获取Redis连接,并注册一个监听器来监听指定频道上的消息。当有消息发布到频道上时,监听器会调用相应的处理逻辑。

4. 代码实现及详细解释

4.1. RedisUtil

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;/*** @author linx 2023-10-24 20:50*/
public class RedisUtil {private static JedisPool jedisPool;// 初始化Redis连接public static void initRedisPool() {JedisPoolConfig config = new JedisPoolConfig();config.setMaxTotal(100);config.setMaxIdle(20);config.setMaxWaitMillis(10000);config.setTestOnBorrow(true);jedisPool = new JedisPool(config, "redis-server", 6379);}// 获取Redis连接public static Jedis getJedis() {if (jedisPool == null) {initRedisPool();}return jedisPool.getResource();}// 释放Redis连接public static void releaseJedis(Jedis jedis) {if (jedis != null) {jedis.close();}}public static void set(String key, String value, int expireSeconds) {Jedis jedis = null;try {jedis = getJedis();jedis.set(key, value);if (expireSeconds > 0) {jedis.expire(key, expireSeconds);}} finally {releaseJedis(jedis);}}public static String get(String key) {Jedis jedis = null;try {jedis = getJedis();return jedis.get(key);} finally {releaseJedis(jedis);}}public static void delete(String key) {Jedis jedis = null;try {jedis = getJedis();jedis.del(key);} finally {releaseJedis(jedis);}}public static Boolean exists(String key) {Jedis jedis = null;try {jedis = getJedis();return jedis.exists(key);} finally {releaseJedis(jedis);}}public static void publish(String channel, String content) {Jedis jedis = null;try {jedis = getJedis();jedis.publish(channel, content);} finally {releaseJedis(jedis);}}public static void main(String[] args){RedisUtil.publish("TESTCHANNEL:001","你好啊");}
}

上述代码中,我们使用了jedis作为Redis的Java客户端。在RedisUtil中,初始化了一个Redis连接池,并提供获取和释放连接的方法。

4.2. Publisher

import redis.clients.jedis.Jedis;public class Publisher {public static void main(String[] args) {Jedis jedis = RedisUtil.getJedis();jedis.publish("channel", "Hello, Redis!");RedisUtil.releaseJedis(jedis);}
}

上述代码中,我们通过RedisUtil获取一个Redis连接,并使用publish方法将消息发送到名为"channel"的频道上。

4.3. Subscriber

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPubSub;/*** @author linx 2023-11-24 4:06*/
public class Subscriber extends JedisPubSub {@Overridepublic void onMessage(String channel, String message) {System.out.println("Received message: " + message);}public static void main(String[] args) {Jedis jedis = RedisUtil.getJedis();Subscriber subscriber = new Subscriber();jedis.subscribe(subscriber, "TESTCHANNEL:001");RedisUtil.releaseJedis(jedis);}
}

上述代码中,我们创建了一个继承自JedisPubSub的Subscriber类,并重写了onMessage方法来处理接收到的消息。然后,我们通过RedisUtil获取一个Redis连接,并使用subscribe方法注册一个监听器,来监听名为"channel"的频道上的消息。

4.4. 运行程序

在这里插入图片描述

在Publisher项目中运行Publisher类,它会向名为"channel"的频道发布一条消息"你好啊"。然后,在Subscriber项目中运行Subscriber类,它会监听"channel"频道上的消息,并在接收到消息时打印出来。

至此,我们已经完成了在两个Java项目中实现Redis的发布订阅模式。

总结:
Redis的发布订阅模式是一种解耦和异步处理的通信模式。通过Redis的Java客户端,我们可以轻松地在多个Java项目中实现该模式。本文通过RedisUtil类对Redis连接进行管理,并通过Publisher和Subscriber类实现了消息的发布和订阅。希望本文对你有所帮助。

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

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

相关文章

HTB Napper WriteUp

Napper 2023年11月12日 14:58:35User Nmap ➜ Napper nmap -sCV -A -p- 10.10.11.240 --min-rate 10000 Starting Nmap 7.80 ( https://nmap.org ) at 2023-11-12 13:58 CST Nmap scan report for app.napper.htb (10.10.11.240) Host is up (0.15s latency). Not shown: …

gitee推荐-SAPI++

一下内容来自gitee。 SaaS-Apps-Engine: 智者|SAPI是多应用、多租户SaaS应用引擎,支持(小程序/公众号/轻应用/企微/抖音/支付宝/百度)等多平台应用。基于ThinkPHP6.1/8.0原生多应用模式开发,简洁、高效、易扩展。集成强大的权限控…

适用于电脑的5个免费文件恢复软件分享

适用于电脑的最佳免费文件恢复软件 任何计算机用户都可能经历过丢失重要文件的恐惧。重要数据的丢失可能会令人不安和沮丧,无论是由于不小心删除、计算机故障还是硬盘格式化造成的。幸运的是,在数字时代,您可以使用值得信赖的解决方案检索这些…

好工具|datamap,一个好用的地图可视化Excel插件,在Excel中实现地理编码、拾取坐标

在做VRP相关研究的时候,需要对地图数据做很多处理,比如地理编码,根据“重庆市沙坪坝区沙正街174号”这样的一个文本地址知道他的经纬度;再比如绘制一些散点图,根据某个位置的经纬度在地图上把它标注出来。还有有的时候…

vue + docxtemplater 导出 word 文档

一、痛点 word 导出 这种功能其实之前都是后端实现的,但最近有个项目没得后端。所以研究下前端导出。 ps: 前端还可以导出 pdf,但是其分页问题需要话精力去计算才可能实现,并且都不是很完善。可参考之前的文章:利用 h…

MIT6.824-Raft笔记:脑裂、Majority Vote(过半投票/过半选举)

本部分主要是问题引入,以及给出一个解决方案 1 脑裂(Split Brain) replication system的共同点:单点 前面几个容错特性(fault-tolerant)的系统,有一个共同的特点。 MapReduce复制了计算&…

JavaScript框架 Angular、React、Vue.js 的全栈解决方案比较

在 Web 开发领域,JavaScript 提供大量技术栈可供选择。其中最典型的三套组合,分别是 MERN、MEAN 和 MEVN。前端框架(React、Angular 和 Vue)进行简化比较。 MERN 技术栈详解 MERN 技术栈包含四大具体组件: MongoDB&am…

蓝桥杯物联网竞赛_STM32L071_3_Oled显示

地位: 对于任何一门编程语言的学习,print函数毫无疑问是一种最好的调试手段,调试者不仅能通过它获取程序变量的运行状态而且通过对其合理使用获取程序的运行流程,更能通过关键变量的输出帮你验证推理的正确与否,朴素的…

常见网络安全防护

1 阻断服务攻击(DOS) 阻断服务攻击,想办法目标网络资源用尽变种:分布式阻断服务攻击 影响: 宽带消耗性(消耗目标的带宽)资源消耗型(消耗目标的计算资源) 解决方案&am…

人工智能对网络安全的影响越来越大

如果问当前IT行业最热门的话题是什么,很少有人会回答除了人工智能(AI)之外的任何话题。 在不到 12 个月的时间里,人工智能已经从一项只有 IT 专业人员才能理解的技术发展成为从小学生到作家、程序员和艺术家的每个人都使用的工具…

MySQL索引事务基础

目录 1. 索引 1.1索引的概念 1.2索引的特点 1.3 索引的使用场景 1.4索引的使用 1.4.1查看索引 1.4.2创建索引 1.4.3删除索引 1.5索引保存的数据结构 2.事务 2.1经典例子 2.2事务的概念 2.3事务的使用 2.4事务的4个核心特性 2.5事务的并发问题 2.5.1脏读 2.5.2不可…

Python + Docker 还是 Rust + WebAssembly?

在不断发展的技术世界中,由大语言模型驱动的应用程序,通常被称为“LLM 应用”,已成为各种行业技术创新背后的驱动力。随着这些应用程序的普及,用户需求的大量涌入对底层基础设施的性能、安全性和可靠性提出了新的挑战。 Python 和…

Java项目如何打包成Jar(最简单)

最简单的办法,使用Maven插件(idea自带) 1.选择需要打包的mudule,点击idea右侧的maven插件 2.clean操作 3.选择需要的其他mudule,进行install操作(如果有) 4.再次选择需要打包的module&#…

Vue.observable 是什么

Observable 翻译过来我们可以理解成可观察的 Vue.js2.6 新增 Vue.observable,让一个对象变成响应式数据。Vue 内部会用它来处理 data 函数返回的对象 。 返回的对象可以直接用于渲染函数和计算属性内,并且会在发生变更时触发相应的更新。也可以作为最小化…

Git的指令

Git 各平台安装包下载地址为:http://git-scm.com/downloads Ubuntu Git 安装命令为: $ apt-get install git用户信息 配置个人的用户名称和电子邮件地址: $ git config --global user.name "runoob" $ git config --global user.…

Python----类对象和实例对象

目录 一.类和类的实例 二.类属性和实例属性 三.私有属性和公有属性 四.静态方法和类方法 五.__init__方法,__new__方法和__del__方法: 六.私有方法和公有方法 七.方法的重载 八.方法的继承 九.方法的重写 十.对象的特殊方法 十一.对象的引用&a…

软件开发模式开源和闭源的优劣之争

开源和闭源,两种截然不同的开发模式,对于大模型的发展有着重要影响。开源让技术共享,吸引了众多人才加入,推动了大模的创新。而闭源则保护了商业利益和技术优势,为大模型的商业应用提供了更好的保障。 开源与闭源软件的…

基于命令行模式设计退款请求处理

前言 这篇文章的业务背景是基于我的另一篇文章: 对接苹果支付退款退单接口-CSDN博客 然后就是说设计模式是很开放的东西,可能我觉得合适,你可能觉得不合适,这里只是做下讨论,没有一定要各位同意的意思.... 相关图文件 这里我先把相关的图文件放上来,可能看着会比较清晰点 代码逻…

sql之left join、right join、inner join的区别

sql之left join、right join、inner join的区别 left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录 inner join(等值连接) 只返回两个表中联结字段相等的行 举例如下&#xff1…

Web服务器(go net/http) 处理Get、Post请求

大家好 我是寸铁👊 总结了一篇Go Web服务器(go net/http) 处理Get、Post请求的文章✨ 喜欢的小伙伴可以点点关注 💝 前言 go http请求如何编写简单的函数去拿到前端的请求(Get和Post) 服务器(后端)接收到请求后,又是怎么处理请求&#xff0c…