目錄
- 概述
- 詳解
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)是簡單動(dòng)態(tài)字符串 sds,是可以修改字符串。
應(yī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的庫存
2.減庫存
3.重新把減完剩余的庫存更新回?cái)?shù)據(jù)庫
del product:1001
setnx 如果插入的key一樣不會(huì)對(duì)數(shù)據(jù)有任何操作啊掏,如果第二次對(duì)庫存再進(jìn)行減對(duì)的話就返回錯(cuò)誤。
2拷恨、Hash(哈希)
定義: Hash是一個(gè)鍵值對(duì)集合脖律。他相當(dāng)于java中的雙重map谢肾。<key,<filed,value>>腕侄。
應(yīng)用場景: 購物車。
具體實(shí)現(xiàn):
購物車:
# 說明:
# 用戶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
# 獲取購物車所有商品:
hgetall cart:1001
3、List(列表)
定義: 列表是簡單的字符串列表薪捍,按照插入順序排序笼痹,可以添加一個(gè)元素在列表的頭部或者尾部配喳。
應(yī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 類型的無序集合。
應(yī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)過贊
sismember like:{消息ID} {用戶id}
# 獲取點(diǎn)贊的用戶列表
smembers like:{消息ID}
# 獲取點(diǎn)贊的用戶樹
scard like:{消息ID}
5、Zset(有序集合)
定義: zset和set一樣也是string類型元素的集合腰埂,且不允許重復(fù)的成員飒焦。不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)dobule類型的分?jǐn)?shù),redis正是通過分?jǐn)?shù)為集合成員進(jìn)行從小到大的排序屿笼,zset的成員是唯一的但是分?jǐn)?shù)可以重復(fù)牺荠。