目錄
- 概述
- 詳解
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的成員是唯一的但是分數可以重復。