发布订阅模式中发布消息的为publisher即发布者,接收消息的为subscriber即订阅者。在Redis中,所有的消息通过channel即频道进行发布,一个发布者可以向多个channel发布消息,一个订阅者也可以订阅多个channel。Redis不对消息进行持久化,如果消息发布时订阅者还没有进行订阅,则不会再收到此消息。
subscribe不能重复订阅同一个channel,而psubscribe按照匹配模式订阅时有可能会多次订阅同一个channel。如果psubscribe多次订阅了同一个channel,发布者使用publish发布消息到此channel后,订阅者会多次收到此消息。
unsubscribe只能退订subscribe订阅的channel,punsubscribe只能退订psubscribe订阅的channel。
订阅方法
// <summary> /// 订阅 /// </summary> public static void Subscription() { using (ServiceStack.Redis.RedisClient consumer = new RedisClient("192.168.210.36", 6379)) { //创建订阅 ServiceStack.Redis.IRedisSubscription subscription = consumer.CreateSubscription(); //接收消息处理Action subscription.OnMessage = (channel, msg) => { Console.WriteLine("频道【" + channel + "】订阅客户端接收消息:" + ":" + msg + " [" + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss") + "]"); Console.WriteLine("订阅数:" + subscription.SubscriptionCount); Console.WriteLine("___________________________________________________________________"); }; //订阅事件处理 subscription.OnSubscribe = (channel) => { Console.WriteLine("订阅客户端:开始订阅" + channel); }; //取消订阅事件处理 subscription.OnUnSubscribe = (a) => { Console.WriteLine("订阅客户端:取消订阅"); }; //订阅频道 subscription.SubscribeToChannels("channel-1"); } }发布程序 static void Main(string[] args) { Console.Title = "Redis发布、订阅服务"; RedisClient client = new RedisClient("192.168.210.36", 6379); while (true) { string input = Console.ReadLine(); client.PublishMessage("channel-1", input); } }