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的成員是惟一的可是分數能夠重複。