一篇学会 C# Redis list 当作队列使用

开发 后端 Redis
Redis的列表经常被用作队列,用于在不同程序之间有序地交换消息。一个客户端通过 LPUSH 命令将消息放入队列中,而另一个客户端通过 RPOP 或者 BRPOP 命令取出队列中等待时间最长的消息。

[[434139]]

本文转载自微信公众号「后端Q」,作者conan  。转载本文请联系后端Q公众号。

Redis的列表经常被用作队列,用于在不同程序之间有序地交换消息。一个客户端通过 LPUSH 命令将消息放入队列中,而另一个客户端通过 RPOP 或者 BRPOP 命令取出队列中等待时间最长的消息。

对于c# 方法

  1. using (var redisClent = RedisManager.GetClient()) 
  2.                         { 
  3.                             while (true
  4.                             { 
  5.                                 if ((DateTime.Now - date).TotalSeconds > maxSeconds) 
  6.                                     break; 
  7.  
  8.                                 var infoJson = redisClent.DequeueItemFromList(CacheKeys.UploadLoginTimeQueue); 
  9.                                 if (string.IsNullOrWhiteSpace(infoJson) || string.IsNullOrEmpty(infoJson)) 
  10.                                     break; 
  11.                                 var info = JsonConvert.DeserializeObject<LoginTimeUpdate>(infoJson); 
  12.                                 UpdateLoginTime(info); 
  13.                             } 
  14.                         } 
  1. client = RedisManager.GetClient(); 
  2.                 if (!client.Get<bool>(key)) 
  3.                 { 
  4.                     client.Set(keytrue, DateTime.Now.Date.AddDays(1).AddSeconds(-1)); 
  5.                 } 
  6.  
  7.                 var jsonObj = JsonConvert.SerializeObject(info); 
  8.                 client.EnqueueItemOnList(CacheKeys.UploadLoginTimeQueue, jsonObj); 

命令

  1. redis 127.0.0.1:6379> LPUSH runoobkey redis 
  2. (integer) 1 
  3. redis 127.0.0.1:6379> LPUSH runoobkey mongodb 
  4. (integer) 2 
  5. redis 127.0.0.1:6379> LPUSH runoobkey mysql 
  6. (integer) 3 
  7. redis 127.0.0.1:6379> LRANGE runoobkey 0 10 
  8.  
  9. 1) "mysql" 
  10. 2) "mongodb" 
  11. 3) "redis" 

问题,上面的队列方法是『不安全』的,因为在这个过程中,一个客户端可能在取出一个消息之后崩溃,而未处理完的消息也就因此丢失。

使用 RPOPLPUSH 命令(或者它的阻塞版本 BRPOPLPUSH )可以解决这个问题:因为它不仅返回一个消息,同时还将这个消息添加到另一个备份列表当中,如果一切正常的话,当一个客户端完成某个消息的处理之后,可以用 LREM 命令将这个消息从备份表删除。

 

最后,还可以添加一个客户端专门用于监视备份表,它自动地将超过一定处理时限的消息重新放入队列中去(负责处理该消息的客户端可能已经崩溃),这样就不会丢失任何消息了。

 

责任编辑:武晓燕 来源: 后端Q
相关推荐

2021-12-09 07:13:25

C#集合类型

2022-01-02 08:43:46

Python

2021-12-28 07:20:43

Hippo WebAssembly云原生

2022-01-12 07:36:01

Java数据ByteBuffer

2022-02-07 11:01:23

ZooKeeper

2023-11-29 13:59:00

trait定义接口

2022-01-01 20:02:25

Metadata动态元数据

2022-08-03 08:17:00

Redis事务内存

2023-01-03 08:31:54

Spring读取器配置

2021-07-06 08:59:18

抽象工厂模式

2021-05-11 08:54:59

建造者模式设计

2021-07-02 09:45:29

MySQL InnoDB数据

2021-07-05 22:11:38

MySQL体系架构

2022-08-26 09:29:01

Kubernetes策略Master

2023-11-28 08:29:31

Rust内存布局

2022-08-23 08:00:59

磁盘性能网络

2021-10-15 09:55:48

Myloader数据教程

2022-04-12 08:30:52

回调函数代码调试

2021-10-27 09:59:35

存储

2021-07-02 08:51:29

源码参数Thread
点赞
收藏

51CTO技术栈公众号