RedisRepository封装—Redis发布订阅以及StackExchange.Redis中的使用
本文版权归博客园和作者本人吴双共同所有,转载请注明本Redis系列分享地址。http://www.cnblogs.com/tdws/tag/NoSql/
Redis发布订阅—Pub/Sub模式或者说是观察者模式。我想大家即使没有使用过,也已经耳熟能详了。
先简单举例说明下应用场景,在场景中我们可以分析到其优势在哪。
比如你的线上应用应用,你想设置一个日志报警系统,当应用出现异常的时候,立马发送通知给你,可能是短信的形式,也可能是邮件的形式。当然如果只将报警通知给你一个人,实现起来很简单,在报警系统中将你的手机号和短信写死在程序中。但是如果你的项目庞大,每个模块有各自的负责人,并且负责人也经常会变更,那么咱们就不能总修改代码了吧?
或者说你的个人博客可以让读者订阅,读者这么多,咱们根本控制不过来呀。
现在发布订阅模式,就可以解决你的问题。在某一点发生改变的时候,其他客户端立即得到通知。也可以说订阅服务器得到应用发布消息,由服务器立即通知给你手中的客户端。这样的好处就是一种松耦合的模式,你不再需要修改发布端和订阅端的任何代码,你只要提供好发布和订阅的操作接口,今后调用就可以了。
首先看一下Redis在控制台中的发布订阅操作。
我开启两个redis命令客户端对相同的一个redis服务进行操作。
首先我们在第一个客户端我们对message01进行订阅,channel名称是我们自定义的,订阅哪个就是哪个。
其次,我们在第二个客户端对message01这个channel进行发布消息。返回值表示有几个客户端订阅。
发布消息后,订阅的客户端立即受收到消息。
毕竟我们不可能只将其用在Redis命令控制台哈,最后来看一下在.NET中的使用。我们依然借助StackExchange.
基础配置,本系列第一篇分享已经包含。还记得静态构造函数中,下面这段代码吗?
1 _redis.PreserveAsyncOrder = RedisClientConfigurations.PreserveAsyncOrder;//并行
配置中,定义了使用并行的方式来执行命令,大大提高了效率(在你无所谓消息传递的顺序时,可以这样使用)。
在接口中定义如下方法:
1 #region Redis发布订阅 2 /// <summary> 3 /// Redis发布订阅 订阅 4 /// </summary> 5 /// <param name="subChannel"></param> 6 void RedisSub(string subChannel); 7 /// <summary> 8 /// Redis发布订阅 发布 9 /// </summary> 10 /// <typeparam name="T"></typeparam> 11 /// <param name="channel"></param> 12 /// <param name="msg"></param> 13 /// <returns></returns> 14 long RedisPub<T>(string channel, T msg); 15 /// <summary> 16 /// Redis发布订阅 取消订阅 17 /// </summary> 18 /// <param name="channel"></param> 19 void Unsubscribe(string channel); 20 /// <summary> 21 /// Redis发布订阅 取消全部订阅 22 /// </summary> 23 void UnsubscribeAll(); 24 25 #endregion
实现如下:
1 #region Redis发布订阅 2 /// <summary> 3 /// Redis发布订阅 订阅 4 /// </summary> 5 /// <param name="subChannel"></param> 6 public void RedisSub(string subChannel) 7 { 8 sub.Subscribe(subChannel, (channel, message) => 9 { 10 Console.WriteLine((string)message); 11 }); 12 } 13 /// <summary> 14 /// Redis发布订阅 发布 15 /// </summary> 16 /// <typeparam name="T"></typeparam> 17 /// <param name="channel"></param> 18 /// <param name="msg"></param> 19 /// <returns></returns> 20 public long RedisPub<T>(string channel, T msg) 21 { 22 23 return sub.Publish(channel, SerializeContent(msg)); 24 } 25 /// <summary> 26 /// Redis发布订阅 取消订阅 27 /// </summary> 28 /// <param name="channel"></param> 29 public void Unsubscribe(string channel) 30 { 31 sub.Unsubscribe(channel); 32 } 33 /// <summary> 34 /// Redis发布订阅 取消全部订阅 35 /// </summary> 36 public void UnsubscribeAll() 37 { 38 sub.UnsubscribeAll(); 39 } 40 #endregion
客户端测试,我将建立一个ConsoleApp和一个Winform程序,并在其中定义两个按钮。代码如下:
在ConsoleApp中我们作为订阅
1 static void Main(string[] args) 2 { 3 IRedisClient client = new RedisClient(); 4 5 client.RedisSub("myFirstChannel"); 6 client.RedisSub("mySecondChannel"); 7 }
在Winform程序中进行发布
1 IRedisClient client = new RedisClient(); 2 private void button1_Click(object sender, EventArgs e) 3 { 4 client.RedisPub("myFirstChannel", "first"); 5 } 6 7 private void button2_Click(object sender, EventArgs e) 8 { 9 client.RedisPub("mySecondChannel", "second"); 10 }
将两个应用运行起来,操作以及结果如下:
下面操作两个按钮,得到结果。
订阅成功。
如果我的点滴分享,对您能有一点帮助,欢迎点赞支持,也欢迎大牛们持续关注和给予指导建议。
RedisRepository封装—Redis发布订阅以及StackExchange.Redis中的使用相关推荐
- Redis 发布订阅原理以及springboo中RedisTemplate集成
一.Redis发布订阅原理 Redis的架构包括两个部分:Redis Client和Redis Server,即客户端和服务端.客户端负责向服务器端发送请求并接受来自服务器端的响应.服务器端负责处理客 ...
- nodejs redis 发布订阅_SpringBoot整合Redis,怎么实现发布/订阅?
一.简介 1.发布订阅 SUBSCRIBE, UNSUBSCRIBE 和 PUBLISH 实现了 发布/订阅消息范例,发送者 (publishers) 不用编程就可以向特定的接受者发送消息 (subs ...
- Redis 发布订阅,小功能大用处,真没那么废材!
假设我们有这么一个业务场景,在网站下单支付以后,需要通知库存服务进行发货处理. 上面业务实现不难,我们只要让库存服务提供给相关的给口,下单支付之后只要调用库存服务即可. 后面如果又有新的业务,比如说积 ...
- Redis发布订阅机制
1. 什么是Redis Redis是一个开源的内存数据库,它以键值对的形式存储数据.由于数据存储在内存中,因此Redis的速度很快,但是每次重启Redis服务时,其中的数据也会丢失,因此,Redis也 ...
- Spring Boot 使用Redis发布订阅模式处理消息
Spring Boot 使用Redis发布订阅模式 1. Redis发布订阅模式 2. Spring Boot中订阅消息 2.1 Redis监听器容器配置 2.2 创建通道监听器 2.3 测试订阅功能 ...
- 5.Redis 发布订阅
转自:http://www.runoob.com/redis/redis-tutorial.html Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub ...
- python redis订阅_Python -- Redis 发布订阅
一.前言 Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息. Redis 客户端可以订阅任意数量的频道. 下图展示了频道 channel1 ...
- google的api key调用次数是多少_Sprint Boot如何基于Redis发布订阅实现异步消息系统的同步调用?...
前言 在很多互联网应用系统中,请求处理异步化是提升系统性能一种常用的手段,而基于消息系统的异步处理由于具备高可靠性.高吞吐量的特点,因而在并发请求量比较高的互联网系统中被广泛应用.与此同时,这种方案也 ...
- 使用Spring Redis发布/订阅
继续发现功能强大的Redis功能集,值得一提的是对发布/订阅消息的开箱即用支持. 发布/订阅消息传递是许多软件体系结构的重要组成部分. 某些软件系统要求消息传递解决方案提供高性能,可伸缩性,队列持久性 ...
- Redis发布订阅模式
使用银行卡消费的时候,银行往往会通过微信.短信或邮件通知用户这笔交易的信息,这便是一种发布订阅模式,这里的发布是交易信息的发布,订阅则是各个渠道.这在实际工作中十分常用,Redis 支持这样的一个模式 ...
最新文章
- 详解何恺明团队4篇大作 !(附代码)| 从特征金字塔网络、Mask R-CNN到学习分割一切
- Fabricjs对Canvas画布和对象的事件监听
- python自动化工具开发_初识TPOT:一个基于Python的自动化机器学习开发工具
- [Qt教程] 第36篇 网络(六)UDP
- Kali渗透测试——利用metasploit攻击靶机WinXP SP1
- esp8266单片机透传_基于WeMos D1(ESP8266)的校园卡门禁系统
- 计算机科学对个人而言最大的影响,论材料科学对计算机科学技术的深远影响.doc...
- JS中的关于类型转换的性能优化
- java多线程之计算数量
- HDU2084 数塔【DP】
- 信号与系统_严国志_第一章_绪论
- JavaWeb框架学习文章索引
- 锐明部标视频设备和博实结设备对部标1078协议支持程度评测对比
- 华为交换机console口密码配置
- curl命令详解 (curl -I)
- mac下实用的代码编辑器
- Oracle作业第四章
- 对象及日期定时器、延时器
- windows 优化大师免费专业版下载
- 世界杯结束了,但盼盼的“世界杯”才刚刚开始
热门文章
- paip.文件读写api php java python总结.txt
- 易筋经:现代化支付系统脉络梳理
- (转)When Milliseconds Make Millions
- Rust: 如何在Windows下Atom中配置Rust环境?
- 进阶之路:Java 日志框架全画传(下)
- 14个阿里高管的研发管理实践和思考 | 凌云时刻
- 更适合私有云的网络部署模式-动态路由
- 【雷达测角】基于matlab和差波束加权【含Matlab源码 1674期】
- 【协同任务】基于matlab蚁群算法多组群UAV协同任务路径规划【含Matlab源码 1578期】
- 【无线通信】基于matlab无线传感网络WSN仿真【含Matlab源码 1237期】