偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

一篇學(xué)會(huì) C# Redis list 當(dāng)作隊(duì)列使用

開(kāi)發(fā) 后端 Redis
Redis的列表經(jīng)常被用作隊(duì)列,用于在不同程序之間有序地交換消息。一個(gè)客戶(hù)端通過(guò) LPUSH 命令將消息放入隊(duì)列中,而另一個(gè)客戶(hù)端通過(guò) RPOP 或者 BRPOP 命令取出隊(duì)列中等待時(shí)間最長(zhǎng)的消息。

[[434139]]

本文轉(zhuǎn)載自微信公眾號(hào)「后端Q」,作者conan  。轉(zhuǎn)載本文請(qǐng)聯(lián)系后端Q公眾號(hào)。

Redis的列表經(jīng)常被用作隊(duì)列,用于在不同程序之間有序地交換消息。一個(gè)客戶(hù)端通過(guò) LPUSH 命令將消息放入隊(duì)列中,而另一個(gè)客戶(hù)端通過(guò) RPOP 或者 BRPOP 命令取出隊(duì)列中等待時(shí)間最長(zhǎng)的消息。

對(duì)于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" 

問(wèn)題,上面的隊(duì)列方法是『不安全』的,因?yàn)樵谶@個(gè)過(guò)程中,一個(gè)客戶(hù)端可能在取出一個(gè)消息之后崩潰,而未處理完的消息也就因此丟失。

使用 RPOPLPUSH 命令(或者它的阻塞版本 BRPOPLPUSH )可以解決這個(gè)問(wèn)題:因?yàn)樗粌H返回一個(gè)消息,同時(shí)還將這個(gè)消息添加到另一個(gè)備份列表當(dāng)中,如果一切正常的話(huà),當(dāng)一個(gè)客戶(hù)端完成某個(gè)消息的處理之后,可以用 LREM 命令將這個(gè)消息從備份表刪除。

 

最后,還可以添加一個(gè)客戶(hù)端專(zhuān)門(mén)用于監(jiān)視備份表,它自動(dòng)地將超過(guò)一定處理時(shí)限的消息重新放入隊(duì)列中去(負(fù)責(zé)處理該消息的客戶(hù)端可能已經(jīng)崩潰),這樣就不會(huì)丟失任何消息了。

 

責(zé)任編輯:武曉燕 來(lái)源: 后端Q
相關(guān)推薦

2021-12-09 07:13:25

C#集合類(lèi)型

2022-01-02 08:43:46

Python

2022-02-07 11:01:23

ZooKeeper

2021-12-28 07:20:43

Hippo WebAssembly云原生

2022-01-12 07:36:01

Java數(shù)據(jù)ByteBuffer

2021-07-02 09:45:29

MySQL InnoDB數(shù)據(jù)

2021-07-06 08:59:18

抽象工廠(chǎng)模式

2023-01-03 08:31:54

Spring讀取器配置

2021-07-05 22:11:38

MySQL體系架構(gòu)

2021-05-11 08:54:59

建造者模式設(shè)計(jì)

2022-08-26 09:29:01

Kubernetes策略Master

2022-08-23 08:00:59

磁盤(pán)性能網(wǎng)絡(luò)

2023-11-28 08:29:31

Rust內(nèi)存布局

2023-11-29 13:59:00

trait定義接口

2022-01-01 20:02:25

Metadata動(dòng)態(tài)元數(shù)據(jù)

2021-09-28 08:59:30

復(fù)原IP地址

2021-10-14 10:22:19

逃逸JVM性能

2022-04-12 08:30:52

回調(diào)函數(shù)代碼調(diào)試

2021-10-27 09:59:35

存儲(chǔ)

2021-07-16 22:43:10

Go并發(fā)Golang
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)