Redis-第八章節(jié)-應(yīng)用場(chǎng)景

目錄

  • 概述
  • 詳解

1、概述

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

2、詳解

1、String(字符串)

定義: String 是 redis 最基本的類型,一個(gè) key 對(duì)應(yīng)一個(gè) value。String 類型是二進(jìn)制安全的。因?yàn)?string 底層的實(shí)現(xiàn)是簡(jiǎn)單動(dòng)態(tài)字符串 sds,是可以修改字符串。

應(yīng)用場(chǎng)景: 單值緩存、對(duì)象緩存、分布式鎖、常規(guī)計(jì)數(shù)(粉絲數(shù)量、評(píng)論數(shù)量)、分布式session共享、分布式全局序列號(hào)。

具體實(shí)現(xiàn):
單值緩存:

  set key value
  get key

對(duì)象緩存:

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

常規(guī)計(jì)數(shù)器:

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

分布式系統(tǒng)全局序列號(hào):

  incrby orderid 1000  # redis批量生成序列號(hào)提升性能

分布式鎖:

  # 相關(guān)操作
  線程1: setnx product:1001 true # 返回1代表獲取鎖成功
  線程2: setnx product:1001 true # 返回0代表獲取鎖失敗
  。。。執(zhí)行業(yè)務(wù)操作
  del product:1001               # 執(zhí)行完業(yè)務(wù)釋放鎖
  set product:1001 true ex 10 nx # 防止程序意外終止導(dǎo)致死鎖
 
 # 案例
    setnx product:1001 true
         1.查詢商品1001的庫(kù)存
         2.減庫(kù)存
         3.重新把減完剩余的庫(kù)存更新回?cái)?shù)據(jù)庫(kù)
    del product:1001

setnx 如果插入的key一樣不會(huì)對(duì)數(shù)據(jù)有任何操作,如果第二次對(duì)庫(kù)存再進(jìn)行減對(duì)的話就返回錯(cuò)誤。

2、Hash(哈希)

定義: Hash是一個(gè)鍵值對(duì)集合。他相當(dāng)于java中的雙重map。<key,<filed,value>>。
應(yīng)用場(chǎng)景: 購(gòu)物車。
具體實(shí)現(xiàn):
購(gòu)物車:

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

3、List(列表)

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

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

4、Set(集合)

定義: Set 是 string 類型的無(wú)序集合。
應(yīng)用場(chǎng)景: 微信抽獎(jiǎng)小程序、微信微博點(diǎn)贊、收藏、標(biāo)簽、關(guān)注模型,就是可能認(rèn)識(shí)的人的關(guān)系。
具體實(shí)現(xiàn):
微信抽獎(jiǎng):

  # 點(diǎn)擊參與抽獎(jiǎng)加入集合
      sadd key {userId}
  # 查看參與抽獎(jiǎng)的所有用戶
      smembers key
  # 抽取count名中獎(jiǎng)?wù)撸?) // srandmember不會(huì)將元素從集合中刪除
      srandmember key [count] //抽取兩名中獎(jiǎng)?wù)?srandmember act:1008 2
  # 抽取count名中獎(jiǎng)?wù)撸?) // SPOP會(huì)將元素從集合中刪除
      spop key 2

微信微博點(diǎn)贊、收藏、標(biāo)簽:

  # 點(diǎn)贊
    sadd like:{消息ID} {用戶id}
  # 取消點(diǎn)贊
    srem like:{消息ID} {用戶id}
  # 檢查用戶是否點(diǎn)過(guò)贊
    sismember like:{消息ID} {用戶id}
  # 獲取點(diǎn)贊的用戶列表
    smembers like:{消息ID}
  # 獲取點(diǎn)贊的用戶樹(shù)
    scard like:{消息ID}

5、Zset(有序集合)

定義: zset和set一樣也是string類型元素的集合,且不允許重復(fù)的成員。不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)dobule類型的分?jǐn)?shù),redis正是通過(guò)分?jǐn)?shù)為集合成員進(jìn)行從小到大的排序,zset的成員是唯一的但是分?jǐn)?shù)可以重復(fù)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容