使用C#的StackExchange.Redis实现订阅分发模式

一、订阅分发模式介绍

Redis发布订阅—Pub/Sub模式或者说是观察者模式。我想大家即使没有使用过,也已经耳熟能详了。

先简单举例说明下应用场景,在场景中我们可以分析到其优势在哪。

比如你的线上应用应用,你想设置一个日志报警系统,当应用出现异常的时候,立马发送通知给你,可能是短信的形式,也可能是邮件的形式。当然如果只将报警通知给你一个人,实现起来很简单,在报警系统中将你的手机号和短信写死在程序中。但是如果你的项目庞大,每个模块有各自的负责人,并且负责人也经常会变更,那么咱们就不能总修改代码了吧?

或者说你的个人博客可以让读者订阅,读者这么多,咱们根本控制不过来呀。

现在发布订阅模式,就可以解决你的问题。在某一点发生改变的时候,其他客户端立即得到通知。也可以说订阅服务器得到应用发布消息,由服务器立即通知给你手中的客户端。这样的好处就是一种松耦合的模式,你不再需要修改发布端和订阅端的任何代码,你只要提供好发布和订阅的操作接口,今后调用就可以了。

二、Redis帮助类

1、连接redis数据库

public static ConnectionMultiplexer Manager

private static ConnectionMultiplexer GetManager(string connectionString=null)

{

if(string.IsNullOrEmpty(connectionString))

{

connectionString = "127.0.0.1";

}

return ConnectionMultiplexer.Connect(connectionString);

}

2、发布函数

public long RedisPub(string channel, T msg)

{

ISubscriber sub = Manager.GetSubscriber();

return sub.Publish(channel, SerializeContent(msg));

}

3、订阅函数

订阅函数的回调函数的输入参数为得到的消息

public void RedisSub(string subChannael,Actioncallback)

{

ISubscriber sub = Manager.GetSubscriber();

sub.Subscribe(subChannael, (channel, message) =>

{

Console.WriteLine(channel+":"+message);

callback(message);

});

}

4、取消订阅函数

public void Unsubscribe(string channel)

{

ISubscriber sub = Manager.GetSubscriber();

sub.Unsubscribe(channel);

}

5、取消所有订阅函数

public void UnsubscribeAll()

{

ISubscriber sub = Manager.GetSubscriber();

sub.UnsubscribeAll();

}

三、订阅客户端程序

1、Main函数

static void Main(string[] args)

{

RedisHelp.RedisHelp client = new RedisHelp.RedisHelp();

client.RedisSub("myFirstChannel", SubCallBack);

client.RedisSub("mySecondChannel");

Console.ReadLine();

}

2、消息回调函数

只有当收到消息时,回调函数被调用,不用使用另外的线程来循环订阅。订阅只需要一次即可。

private static void SubCallBack(string msg)

{

Console.WriteLine("Cliect1:{0}",msg);

}

四、发布客户端程序

1、后台代码

private void button1_Click(object sender, EventArgs e)        

{            client.RedisPub("myFirstChannel", textBox1.Text);

}

2、UI界面(winform)


五、测试结果

发布客户端发送A,订阅客户端接收到A,第一个接收结果是RedisHelp库中的函数打印的,第二个是库函数调用回调函数打印的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,374评论 19 139
  • # 一度蜜v3.0协议 --- # 交互协议 [TOC] ## 协议说明 ### 请求参数 下表列出了v3.0版协...
    c5e350bc5b40阅读 3,875评论 0 0
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,929评论 18 399
  • 安全性 设置客户端连接后进行任何其他指令前需要使用的密码。 警告:因为redis 速度相当快,所以在一台比较好的服...
    OzanShareing阅读 5,820评论 1 7
  • 小伙伴听说我要去学习茶艺师,一脸吃惊的问“你喜欢那种翘个兰花指,茶泡出来都不敢喝,还假装自己特美的演技派?” 我当...
    废话宅女阅读 7,645评论 5 16