前言:redis提供了很多种功能或模式,可以运用在不同的场景下,今天记录下redis中的发布、订阅模式的基本使用

  注redis安装及主从搭建请参考我其他博文http://www.cnblogs.com/longjee/p/8652374.html,本文不再赘述

  • redis中的发布订阅由三部分组成。发布者(生产者)、通道(类似于topic)、订阅者(消费者),具体结构如下图:

  • redis中实现发布订阅
  1. 首先我们打开两个客户端 A、B
  2. A客户端使用subscribe 命令订阅通道test
  3. 然后客户端B使用publish 命令发送消息
  4. 这个时候客户端A能自动接收到消息
  5. 至此,使用redis简单的搭建一个发布订阅服务就完成了。
  • 使用Java基于redis实现发布订阅
  1. 首先我们新建一个maven的项目。然后建立三个属于该项目的module: redis-pub、redis-sub、redis-common
  2. 在redis-pubsub(下面简称父项目)的pom中添加jedis的依赖 ,本人使用2.9.0版本
  3. redis-common是我写的一个公共组件
  4. 下面开始写sub端(贴出部分为核心代码)
  5.  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);
    } }
  6. pub端代码(部分代码)
  7.  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);
    }
    }
  8. 测试:使用postman进行测试。结果如下。

至此,使用Java搭建一个简单的发布订阅模式已经完成!

如有什么不对之处,敬请指教。

上面为关键部分代码,完整代码请到我的github:https://github.com/wylsource/redis-pubsub

redis发布(pub)、订阅(sub)模式的更多相关文章

  1. 文成小盆友python-num12 Redis发布与订阅补充,python操作rabbitMQ

    本篇主要内容: redis发布与订阅补充 python操作rabbitMQ 一,redis 发布与订阅补充 如下一个简单的监控模型,通过这个模式所有的收听者都能收听到一份数据. 用代码来实现一个red ...

  2. Redis——发布和订阅

    发布与订阅(又称pub/sub),订阅者(listener)负责订阅频道(channel),发送者(publisher)负责向频道发送二进制字符串消息(binary string message).每 ...

  3. Redis - 发布和订阅

    一.概述 1). 发布和订阅是一种消息通信模式. 2). 优点:使消息订阅者和消息发布者耦合度降低,类似设计模式中的观察者模式. 二.发布和订阅 订阅命令: // 订阅一个或多个频道 // 返回值:v ...

  4. redis发布与订阅

    发布与订阅 除了实现任务队列外, Redis还提供了一组命令可以让开发者实现"发布/订阅"(publish/subscribe)模式. "发布/订阅"模式同样可 ...

  5. redis 发布和订阅实现

    参考文献 15天玩转redis -- 第九篇 发布/订阅模式 <Redis设计与实现> 命令简介 在redis用户手册中,跟发布订阅相关的命令有如下的六个: PSUBSCRIBE PUBL ...

  6. redis 发布与订阅原理分析

    前言:用了redis也有一段时间了,但是发布与订阅的使用频率也不高,趁着这次空闲,深究下redis的发布与订阅模式. 一.订阅频道和信息发布 功能说明:Redis 的 SUBSCRIBE 命令可以让客 ...

  7. Redis 发布与订阅 消息

    基于Redis消息队列-实现短信服务化 1.Redis实现消息队列原理 常用的消息队列有RabbitMQ,ActiveMQ,个人觉得这种消息队列太大太重,本文介绍下基于Redis的轻量级消息队列服务. ...

  8. Redis 发布与订阅模式

    subscribe  订阅 publish   发布   频道    发布内容

  9. 03 Redis发布与订阅

    以qq群的公告,单个发布者,多个收听者为例 发布/订阅 实验 发布订阅的命令 PUBLISH channel msg 将信息 message 发送到指定的频道 channel SUBSCRIBE ch ...

  10. php swoft redis 发布和订阅

    //订阅 public function subscribe() { /* @var \Swoft\Redis\Redis $redis */ $redis = App::getBean(\Swoft ...

随机推荐

  1. 51nod1184 第N个质数

    如题.$n \leq 1e9$. 方法零:二分,然后洲阁筛.要魔改一下的洲阁筛.跑得慢.卡卡能过.没意思. //#include<iostream> #include<cstring ...

  2. ES6__数据结构 Map

    /* 数据结构 Map */ /* * 字典:是用来存储不重复的key的hash结构.不同于集合(Set)的是,字典使用的是[键,值]的形式来储存数据的. *javaScript 的对象(Object ...

  3. 从零开始写STL—哈希表

    static const int _stl_num_primes = 28; template<typename T, typename Hash = xhash<T>> cl ...

  4. hihocoder 1579(排列组合)

    题意 给出一个长度为n的字符串的sa数组,n<=1e5,问有多少种不同的字符串的sa数组正好是输入的sa数组(字符串每个位置都是小写字母) 分析 sa数组描述的是字符的大小关系,而不是确切的字符 ...

  5. Eclipse移植项目时JDK版本不匹配Project facet Java version 1.7 is not supported

    Eclipse移植项目时JDK版本不匹配Project facet Java version 1.7 is not supported 如果原有项目用的为JDK1.7,而自己的是低版本JDK,比如1. ...

  6. 学习swift从青铜到王者之Swift控制语句04

    1 if语句基本用法 if boolean_expression { /* 如果布尔表达式为真将执行的语句 */ } 如果布尔表达式为 true,则 if 语句内的代码块将被执行.如果布尔表达式为 f ...

  7. HDU 4115 Eliminate the Conflict(2-sat)

    HDU 4115 Eliminate the Conflict pid=4115">题目链接 题意:Alice和Bob这对狗男女在玩剪刀石头布.已知Bob每轮要出什么,然后Bob给Al ...

  8. Firefox下td用display控制页面导致页面变形

    Firefox下table的td元素假设使用了display:'block'会使得table变形.原因是block会将对象强制作为块对象呈递,为对象之后加入新行,所以并不适合td,改成display: ...

  9. 第五讲:使用html5中的canvas动态画出物理学上平抛运动

    <html> <head> <title>平抛运动</title> <script src="../js/jscex.jscexRequ ...

  10. [Zlib]_[0基础]_[使用zlib库压缩文件]

    场景: 1. WIndows上没找到系统提供的win32 api来生成zip压缩文件, 有知道的大牛麻烦留个言. 2. zlib比較经常使用,编译也方便,使用它来做压缩吧. MacOSX平台默认支持z ...