当前位置: 首页 > news >正文

在两个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类实现了消息的发布和订阅。希望本文对你有所帮助。

相关文章:

  • 车载电子电器架构 ——电子电气架构设计方案概述
  • 【C指针(五)】6种转移表实现整合longjmp()/setjmp()函数和qsort函数详解分析模拟实现
  • Linux云服务器打包部署前端Vue项目
  • 从零开始,用Docker-compose打造SkyWalking、Elasticsearch和Spring Cloud的完美融合
  • 【理解ARM架构】操作寄存器实现UART | 段的概念 | IDE背后的命令
  • Linux中flask项目开启https访问
  • 汇编-PROTO声明过程
  • 中职组网络安全B模块-渗透提权2
  • CF -- Educational Codeforces Round 158 (Rated for Div. 2) -- D 补题记录
  • linux查询某个进程使用的内存量
  • springboot(ssm大学生创业网站 毕业生创业平台Java(codeLW)
  • WordPress插件开发教程手册 — 钩子(Hooks)
  • 为何内存不够用?微服务改造启动多个Spring Boot的陷阱与解决方案
  • 量子计算的发展
  • 嵌入式虚拟机原理
  • ES6指北【2】—— 箭头函数
  • [deviceone开发]-do_Webview的基本示例
  • 2017 年终总结 —— 在路上
  • 2017年终总结、随想
  • 2017前端实习生面试总结
  • CentOS7 安装JDK
  • crontab执行失败的多种原因
  • ES6核心特性
  • exif信息对照
  • idea + plantuml 画流程图
  • Java 内存分配及垃圾回收机制初探
  • js
  • js正则,这点儿就够用了
  • leetcode98. Validate Binary Search Tree
  • PHP 程序员也能做的 Java 开发 30分钟使用 netty 轻松打造一个高性能 websocket 服务...
  • rabbitmq延迟消息示例
  • SegmentFault 社区上线小程序开发频道,助力小程序开发者生态
  • Spring Security中异常上抛机制及对于转型处理的一些感悟
  • 阿里研究院入选中国企业智库系统影响力榜
  • 译米田引理
  • gunicorn工作原理
  • # 数据结构
  • ###C语言程序设计-----C语言学习(3)#
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (2/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (4)通过调用hadoop的java api实现本地文件上传到hadoop文件系统上
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (NSDate) 时间 (time )比较
  • (PWM呼吸灯)合泰开发板HT66F2390-----点灯大师
  • (黑马出品_高级篇_01)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (一)WLAN定义和基本架构转
  • (转)C#调用WebService 基础
  • (转)编辑寄语:因为爱心,所以美丽
  • .axf 转化 .bin文件 的方法
  • .NET : 在VS2008中计算代码度量值
  • .NET上SQLite的连接
  • .NET中的十进制浮点类型,徐汇区网站设计
  • @JSONField或@JsonProperty注解使用
  • [ web基础篇 ] Burp Suite 爆破 Basic 认证密码