Redis-第八章節-應用場景

目錄

  • 概述
  • 詳解

1、概述

Redis支持五種數據類型:String(字符串)、Hash(哈希)、List(列表)、Set(集合)、Zset(有序集合)。

2、詳解

1、String(字符串)

定義: String 是 redis 最基本的類型,一個 key 對應一個 value。String 類型是二進制安全的。因為 string 底層的實現是簡單動態字符串 sds,是可以修改字符串。

應用場景: 單值緩存、對象緩存、分布式鎖、常規計數(粉絲數量、評論數量)、分布式session共享、分布式全局序列號。

具體實現:
單值緩存:

  set key value
  get key

對象緩存:

  set user:1 value(json格式數據)
  mset user:1:name tsingli user:1:balance 1888
  mget user:1:name user:1:balance

常規計數器:

  incr article:readcount:{文章id}
  get article:readcount:{文章id}

分布式系統全局序列號:

  incrby orderid 1000  # redis批量生成序列號提升性能

分布式鎖:

  # 相關操作
  線程1: setnx product:1001 true # 返回1代表獲取鎖成功
  線程2: setnx product:1001 true # 返回0代表獲取鎖失敗
  。。。執行業務操作
  del product:1001               # 執行完業務釋放鎖
  set product:1001 true ex 10 nx # 防止程序意外終止導致死鎖
 
 # 案例
    setnx product:1001 true
         1.查詢商品1001的庫存
         2.減庫存
         3.重新把減完剩余的庫存更新回數據庫
    del product:1001

setnx 如果插入的key一樣不會對數據有任何操作,如果第二次對庫存再進行減對的話就返回錯誤。

2、Hash(哈希)

定義: Hash是一個鍵值對集合。他相當于java中的雙重map。<key,<filed,value>>。
應用場景: 購物車。
具體實現:
購物車:

  # 說明:
    # 用戶id為1001,商品的編碼是10088。
    # 用戶id為key,商品id為field,商品數量為value。
    
  # 案例:
     # 添加商品:
        hset cart:1001 10088 1
     # 增加數量:
        hincrby cart:1001 10088 1
     # 商品總數:
        hlen cart:1001
     # 刪除商品:
        hdel cart:1001 10088
     # 獲取購物車所有商品:
        hgetall cart:1001

3、List(列表)

定義: 列表是簡單的字符串列表,按照插入順序排序,可以添加一個元素在列表的頭部或者尾部。
應用場景: Stack(棧)= LPUSH + LPOP -> FILO //先進后出Queue(隊列)= LPUSH + RPOP //先進先出Blocking MQ(阻塞隊列)= LPUSH + BRPOP //消息隊列微博微信公眾號消息流
具體實現:
微博和微信公眾號消息流:

  # 李雷發微博,消息id為10018
      lpush msg:111111 10018
  # 韓梅梅車發微博,消息id為10086
      lpush msg:111111 10086
  # 查看最新微博消息
      lrange msg:11111 0 5 //0至5條微博消息。

4、Set(集合)

定義: Set 是 string 類型的無序集合。
應用場景: 微信抽獎小程序、微信微博點贊、收藏、標簽、關注模型,就是可能認識的人的關系。
具體實現:
微信抽獎:

  # 點擊參與抽獎加入集合
      sadd key {userId}
  # 查看參與抽獎的所有用戶
      smembers key
  # 抽取count名中獎者(1) // srandmember不會將元素從集合中刪除
      srandmember key [count] //抽取兩名中獎者 srandmember act:1008 2
  # 抽取count名中獎者(2) // SPOP會將元素從集合中刪除
      spop key 2

微信微博點贊、收藏、標簽:

  # 點贊
    sadd like:{消息ID} {用戶id}
  # 取消點贊
    srem like:{消息ID} {用戶id}
  # 檢查用戶是否點過贊
    sismember like:{消息ID} {用戶id}
  # 獲取點贊的用戶列表
    smembers like:{消息ID}
  # 獲取點贊的用戶樹
    scard like:{消息ID}

5、Zset(有序集合)

定義: zset和set一樣也是string類型元素的集合,且不允許重復的成員。不同的是每個元素都會關聯一個dobule類型的分數,redis正是通過分數為集合成員進行從小到大的排序,zset的成員是唯一的但是分數可以重復。

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,698評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,202評論 3 426
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,742評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,580評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,297評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,688評論 1 327
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,693評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,875評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,438評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,183評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,384評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,931評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,612評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,022評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,297評論 1 292
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,093評論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,330評論 2 377

推薦閱讀更多精彩內容