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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

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

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

OpenCV滑块验证码图像缺口位置识别

OpenCV图像缺口位置识别 1、背景2、图像缺口位置识别原理3、图像缺口位置识别实现4、滑块验证码HTTP图像需要保存到本地吗1、背景 在使用Selenium完成自动化爬虫时,许多网站为了防止机器人爬取数据会使用验证码(例如滑块验证码)。通过Selenium动作操作,爬虫可以模拟用户输入…

由红黑树引出的HashMap扩容机制的思考

红黑树是什么? 三大特点: 根节点是黑色,叶节点是不存储数据的黑色空节点 任何相邻的两个节点不能同时为红色 任意节点到其可到达的节点间包含相同数量的黑色节点 联想:Java HashMap底层红黑树原理 HashMap基于哈希表Map接口实…

node与 pnpm、node-sass 等工具的版本兼容关系

1. node & pnpm 2. node & node-sass 3. node-sass & sass-loader sass-loader依赖于node-sass,以下是部分版本号对应

ES 万条以外分页检索功能实现及注意事项

背景 以 ES 存储日志,且需要对日志进行分页检索,当数据量过大时,就面临 ES 万条以外的数据检索问题,如何利用滚动检索实现这个需求呢?本文介绍 ES 分页检索万条以外的数据实现方法及注意事项。 需求分析 用 ES 存储数…

GPU服务器常见故障修复记录

日常写代码写方案文档,偶尔遇上服务器出现问题的时候,也需要充当一把运维工程师,此帖用来记录GPU服务器报错的一些解决方案,仅供参考! 文章目录 一、服务器简介二、机箱拆解三、基本操作四、常见故障4.1 电源开关键闪烁…

HBuilderX前端软件社区+Thinkphp后端源码

HBuilderX前端软件社区thinkphp后端源码,搭建好后台在前端找到 util 这个文件把两个js文件上面的填上自己的域名,登录HBuilderX账号没有账号就注册账号然后上传文件即可。打包选择发行 可以打包app或h5等等 后端设置运行目录为public(重要),…

解决:ImportError: cannot import name ‘Adam‘ from ‘keras.optimizers‘

解决:ImportError: cannot import name ‘Adam‘ from ‘keras.optimizers‘ 背景 在使用之前的代码时,报错: from keras.optimizers import Adam ImportError: cannot import name ‘Adam’ 报错问题 from keras.optimizers import Adam I…

Unity调用dll踩坑记

请用写一段代码,让unity无声无息的崩溃。 你说这怕是有点难哦,谁会这么不幸呢?不幸的是,我幸运的成为了那个不幸的人。 unity里面调用dll的方式是使用 DllImport ,比如有一个 Hello.dll,里面有一个 char* …

计算机网络之应用层

一、概述 引入目的: 为了方便用户去使用; 该如何方便用户使用网络呢,即怎样帮助用户使用网络? 1.用户需要知道网络资源所在的位置 2.网络上资源一定是在资源子网的主机上 3.资源子网上的主机,在通信子网中用IP地…

Android设计模式--装饰模式

千淘万漉虽辛苦,吹尽黄沙始到金 一,定义 动态地给一个对象添加一些额外的职责。就增加功能来说,装饰模式相比生成子类更为灵活。 装饰模式也叫包装模式,结构型设计模式之一,其使用一种对客户端透明的方式来动态地扩展…

基于SpringBoot+Vue的电子产品销售管理系统

基于SpringBootVue的电子产品销售管理系统的设计与实现~ 开发语言:Java数据库:MySQL技术:SpringBootMyBatisVue工具:IDEA/Ecilpse、Navicat、Maven 系统展示 主页 购物车 管理员界面 摘要 基于Spring Boot和Vue的电子产品销售管…

如何开启MySQL的慢查询日志

说明:如果需要查看某一条SQL查询速度慢,并对慢的SQL进行优化,那么开启MySQL慢查询日志是一定要做的事情,本文介绍如何开启MySQL的慢查询日志; 查看MySQL慢查询是否开启 首先,输入下面的命令,查…

再添千万级罚单,某银行年内罚款过亿!金融行业合规问题亟待解决

11月17日晚间,国家金融监管总局上海监管局披露行政处罚信息显示,某银行因32项违法违规事实收到两张690万元的大额罚单,合计罚款金额达1380万元。但这并不是银行该今年收到的第一张大额罚单。今年4月28日,该行因在结售汇、外币理财…

Okhttp 浅析

安全的连接 OkHttpClient: OkHttpClient: 1.线程调度 2.连接池,有则复用,没有就创建 3.interceptor 4.interceptor 5.监听工厂 6.是否失败重试 7.自动修正访问,如果没有权限或认证 8是否重定向 followRedirects 9.协议切换时候是否继续重定向 10.Cookie jar 容器 默认…

Electron+VUE3开发简版的编辑器【文件预览】

简版编辑器的功能主要是: 打开对话框,选择文件后台读取文件文件前端展示文件内容。主要技术栈是VUE3、Electron和Nodejs,VUE3做页面交互,Electron提供一个可执行Nodejs的环境以及支撑整个应用的环境,nodeJS负责读取文件内容。 环境配置、安装依赖这些步骤就不再叙述了。 …

PHP众筹系统源码+支持报名众筹+商品众筹+无偿众筹+市面上所有的众筹模式 附带完整的搭建教程

大家好啊,罗峰今天来给大家分好用的源码系统了。今天要给大家分享的是一款PHP众筹系统源码。众筹作为一种新型的融资方式,逐渐在市场上占据了重要的地位。从公益众筹到商品众筹,再到股权众筹,各种众筹模式层出不穷。然而&#xff…

Go lumberjack 日志轮换和管理

在开发应用程序时,记录日志是一项关键的任务,以便在应用程序运行时追踪问题、监视性能和保留审计记录。Go 语言提供了灵活且强大的日志记录功能,可以通过多种方式配置和使用。其中一个常用的日志记录库是 github.com/natefinch/lumberjack&am…

Proteus下仿真AT89C51报“串行口通信失败,请检查电平适配是否正确。”解决办法

在Proteus下进行AT89C51串行口仿真时,如果遇到“串行口通信失败,请检查电平适配是否正确”的错误提示,以下是一些解决办法: 1. 了解AT89C51和外部设备的电平要求: 首先,了解AT89C51和外部设备之间的电平…