Redis-第八章節-應用場景

目錄

  • 概述
  • 詳解

一、概述

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

二、詳解

一、String(字符串)

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

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

具體實現:
單值緩存:json

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同樣不會對數據有任何操做,若是第二次對庫存再進行減對的話就返回錯誤。session

二、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
三、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條微博消息。
四、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}
五、Zset(有序集合)

定義: zset和set同樣也是string類型元素的集合,且不容許重複的成員。不一樣的是每一個元素都會關聯一個dobule類型的分數,redis正是經過分數爲集合成員進行從小到大的排序,zset的成員是惟一的可是分數能夠重複。

相關文章
相關標籤/搜索