redis发布(pub)、订阅(sub)模式
前言:redis提供了很多种功能或模式,可以运用在不同的场景下,今天记录下redis中的发布、订阅模式的基本使用
注redis安装及主从搭建请参考我其他博文http://www.cnblogs.com/longjee/p/8652374.html,本文不再赘述
- redis中的发布订阅由三部分组成。发布者(生产者)、通道(类似于topic)、订阅者(消费者),具体结构如下图:

- redis中实现发布订阅
- 首先我们打开两个客户端 A、B
- A客户端使用subscribe 命令订阅通道test

- 然后客户端B使用publish 命令发送消息

- 这个时候客户端A能自动接收到消息

- 至此,使用redis简单的搭建一个发布订阅服务就完成了。
- 使用Java基于redis实现发布订阅
- 首先我们新建一个maven的项目。然后建立三个属于该项目的module: redis-pub、redis-sub、redis-common

- 在redis-pubsub(下面简称父项目)的pom中添加jedis的依赖 ,本人使用2.9.0版本

- redis-common是我写的一个公共组件
- 下面开始写sub端(贴出部分为核心代码)
package com.star4j.redissub.client; import com.star4j.rediscommon.helper.JedisConnectionHelper;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPubSub; /**
* @Author: WuYL
* @Description: 实现订阅功能
* @Date: Create in 2018/3/29 15:21
* @Modified By:
*/
public abstract class SubClient extends JedisPubSub{ private Jedis jedis = null; public SubClient(Jedis jedis){
this.jedis = jedis;
} protected SubClient(){
jedis = JedisConnectionHelper.get();
} /**
* 订阅一个通道 (必须实现该类才行)
* @param channal
*/
public final void sub(String channal){
jedis.subscribe(this, channal);
} /**
* 有消息被推送过来时调用(子类实现)
* @param channel
* @param message
*/
public abstract void message(String channel, String message); @Override
public void onMessage(String channel, String message) {
this.message(channel, message);
} }- pub端代码(部分代码)
package com.star4j.redispub.client; import com.star4j.rediscommon.helper.JedisConnectionHelper;
import redis.clients.jedis.Jedis; /**
* @Author: WuYL
* @Description: 发布端实现
* @Date: Create in 2018/3/29 15:41
* @Modified By:
*/
public class PubClient { /**
* 发布消息
* @param channel
* @param message
*/
public static void pub(String channel, String message){
Jedis jedis = JedisConnectionHelper.get();
jedis.publish(channel, message);
JedisConnectionHelper.close(jedis);
}
}- 测试:使用postman进行测试。结果如下。

至此,使用Java搭建一个简单的发布订阅模式已经完成!
如有什么不对之处,敬请指教。
上面为关键部分代码,完整代码请到我的github:https://github.com/wylsource/redis-pubsub
redis发布(pub)、订阅(sub)模式的更多相关文章
- 文成小盆友python-num12 Redis发布与订阅补充,python操作rabbitMQ
本篇主要内容: redis发布与订阅补充 python操作rabbitMQ 一,redis 发布与订阅补充 如下一个简单的监控模型,通过这个模式所有的收听者都能收听到一份数据. 用代码来实现一个red ...
- Redis——发布和订阅
发布与订阅(又称pub/sub),订阅者(listener)负责订阅频道(channel),发送者(publisher)负责向频道发送二进制字符串消息(binary string message).每 ...
- Redis - 发布和订阅
一.概述 1). 发布和订阅是一种消息通信模式. 2). 优点:使消息订阅者和消息发布者耦合度降低,类似设计模式中的观察者模式. 二.发布和订阅 订阅命令: // 订阅一个或多个频道 // 返回值:v ...
- redis发布与订阅
发布与订阅 除了实现任务队列外, Redis还提供了一组命令可以让开发者实现"发布/订阅"(publish/subscribe)模式. "发布/订阅"模式同样可 ...
- redis 发布和订阅实现
参考文献 15天玩转redis -- 第九篇 发布/订阅模式 <Redis设计与实现> 命令简介 在redis用户手册中,跟发布订阅相关的命令有如下的六个: PSUBSCRIBE PUBL ...
- redis 发布与订阅原理分析
前言:用了redis也有一段时间了,但是发布与订阅的使用频率也不高,趁着这次空闲,深究下redis的发布与订阅模式. 一.订阅频道和信息发布 功能说明:Redis 的 SUBSCRIBE 命令可以让客 ...
- Redis 发布与订阅 消息
基于Redis消息队列-实现短信服务化 1.Redis实现消息队列原理 常用的消息队列有RabbitMQ,ActiveMQ,个人觉得这种消息队列太大太重,本文介绍下基于Redis的轻量级消息队列服务. ...
- Redis 发布与订阅模式
subscribe 订阅 publish 发布 频道 发布内容
- 03 Redis发布与订阅
以qq群的公告,单个发布者,多个收听者为例 发布/订阅 实验 发布订阅的命令 PUBLISH channel msg 将信息 message 发送到指定的频道 channel SUBSCRIBE ch ...
- php swoft redis 发布和订阅
//订阅 public function subscribe() { /* @var \Swoft\Redis\Redis $redis */ $redis = App::getBean(\Swoft ...
随机推荐
- C#特性入门《详解》
原文发布时间为:2008-11-22 -- 来源于本人的百度文章 [由搬家工具导入] <转>http://www.bccn.net/Article/net/cs/jszl/200709/6 ...
- 微软2016校园招聘在线笔试 B Professor Q's Software [ 拓扑图dp ]
传送门 题目2 : Professor Q's Software 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 Professor Q develops a new s ...
- python学习之-- Mysql 基础知识
数据库介绍及MYSQL基础操作了解 关系型数据库(RDBMS)是按照数据结构来组织,存储和管理数据的仓库.特点:1:数据以表格的形式出现2:每行为各种记录名称3:每列为记录名称所对应的数据域4:许多的 ...
- python学习之-- redis模块基本介绍
数据缓存系统: 1:mongodb:是直接持久化,直接存储于硬盘的缓存系统 2:redis: 半持久化,存储于内存和硬盘 3:memcache:数据只能存储在内存里的缓存系统关于memcache 学习 ...
- HDU 6396 贪心+优先队列+读入挂
Swordsman Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total ...
- python 爬虫(转,我使用的python3)
原文地址:http://blog.csdn.net/pi9nc/article/details/9734437 [Python]网络爬虫(一):抓取网页的含义和URL基本构成 分类: 爬虫 Pyt ...
- Java fail-fast 与 fail-safe 机制对比
关于fail-fast参考这篇文章: 从 modCount 看 java集合 fail-fast 机制 一.fail-safe概述以及与fail-fast区别 首先 fail-safe 并不属于J ...
- 【APUE】孤儿进程与僵死进程
基本概念: 在unix/linux中,正常情况下,子进程是通过父进程创建的,子进程在创建新的进程.子进程的结束和父进程的运行是一个异步过程,即父进程永远无法预测子进程 到底什么时候结束. 当一个 进程 ...
- POJ3262 Protecting the Flowers 【贪心】
Protecting the Flowers Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 4418 Accepted: ...
- mysql innodb插入意向锁
innodb中有插入意向锁.专门针对insert,假设插入前,该间隙已经由gap锁,那么Insert会申请插入意向锁. 那么这个插入意向锁的作用是什么? 1.为了唤起等待.由于该间隙已经有锁,插入时必 ...