一、字符串
setnx
設(shè)置成功時返回1,設(shè)置失敗返回0朵你,只可以進(jìn)行設(shè)置崭添,不可以進(jìn)行修改
可以實現(xiàn)分布式鎖:
setnx key value
問題:
(1)死鎖。
獲取鎖吭历,超時了堕仔,引出了另一個命令 expire 設(shè)置鎖的過期時間,后續(xù)執(zhí)行完后晌区,進(jìn)行鎖的釋放摩骨,del。
但是朗若,setnx 設(shè)置鎖和expire設(shè)置鎖的過期時間并不是一個原子性的操作恼五,執(zhí)行過程中可能出現(xiàn)異常情況,導(dǎo)致expire在設(shè)置鎖的過期時間失敗哭懈。從而無法保證無死鎖的原子發(fā)生灾馒。
解決方式:使用 set命令 set stock ex 10 nx,保證了redis分布式鎖的無死鎖的原子性操作完成了遣总。
(2)使用set ex nx 保證了redis分布式鎖無死鎖的原子性操作睬罗,一般也會存在如下問題轨功。
情景:
A拿到了redis的鎖,設(shè)置了10秒的過期時間容达,但是A的業(yè)務(wù)執(zhí)行了20秒才完成古涧。而B不斷的嘗試進(jìn)行獲取鎖,到10秒的時候發(fā)現(xiàn)A原理獲取的鎖釋放了花盐,從而B也獲得了鎖羡滑,B也執(zhí)行B的業(yè)務(wù),等到20秒的時候算芯,A的業(yè)務(wù)執(zhí)行完成柒昏,執(zhí)行了del刪除鎖的命令。
原因:業(yè)務(wù)的執(zhí)行時間大于鎖的時間也祠,沒有滿足鎖的互斥性昙楚。
解決方式:
(1)充分的預(yù)估業(yè)務(wù)的執(zhí)行時間;
(2) 鎖塊到期了诈嘿,業(yè)務(wù)沒有執(zhí)行完成堪旧,(可以開守護(hù)線程,將鎖重新進(jìn)行續(xù)時操作奖亚,確保鎖的時間大于業(yè)務(wù)的執(zhí)行時間)淳梦,如果業(yè)務(wù)的確執(zhí)行超時了,不能無限制的進(jìn)行重試?yán)m(xù)時昔字。保障重試次數(shù)爆袍。
(3)在刪除鎖的時候出現(xiàn)誤刪的情況,需要判斷是不是自己的鎖作郭。
set命令
set key value [ex seconds][nx]
場景:網(wǎng)站618限流陨囊。IP訪問網(wǎng)站50次,禁止訪問了夹攒,明天可以訪問蜘醋。
incr 自增
expire 有效期定義到24點
incrby
ID生成器--集成環(huán)境下,ABC三臺redis集群咏尝,A機(jī)器從1開始压语,B機(jī)器從2開始,C機(jī)器從3開始编检,每次增長長度為3
二胎食、hash*
hset 設(shè)置單個,hmset設(shè)置多個
存儲的是結(jié)構(gòu)化的存儲方案允懂。
三厕怜、list
簡單場景:簡單的消息隊列。。
左進(jìn)右出粥航,先進(jìn)先出舵揭。
延時隊列。躁锡。
四、集合
集合中不能存在重復(fù)值置侍。集合中的值無序且唯一
場景1:年會抽獎映之。
sadd choujiang xrj wzs fjf
srandmember
smembers choujiang 集合元素
spop choujiang 1 集合中彈出1個元素
場景2:點贊、收藏蜡坊、轉(zhuǎn)發(fā)
sadd like:520 xrj fjf wzs #喜歡520這篇文章的人
srem like:520 xrj #某個用戶取消點贊
smembers like:520 #查看誰點贊了
scard liek:520 #統(tǒng)計這篇文章一共多少人點贊
sismember like:520 xrj #查看某個元素是否在指定的集合中
場景3:set運算
sinter key #返回一共集合的全部成員杠输,該集合是所有給定集合的交集
sunion key #并集
sdiff key #差集
五、zset有序集合
場景:有兩個門店賣水果秕衙,統(tǒng)計水果的銷售量
今天那個水果賣的好蠢甲。
zadd meidian1 10 pingguo 20 juzi 30 putao #門店1賣了10斤的蘋果,20斤的橘子据忘,30斤的葡萄
zadd meidian1 15 boluo #忘記了統(tǒng)計菠蘿
zrange mendian1 0 -1 #查看門店1中的所有數(shù)據(jù)
zrange mendian1 0 -1 withscore #查看門店1中的所有數(shù)據(jù)鹦牛,帶權(quán)重值
zadd meidian2 30 lizhi 20 xigua 15 shanzhu #門店1賣了30斤的荔枝,20斤西瓜勇吊,15斤山竹
兩個門店一共統(tǒng)計
zunionstore mendianall 2 mendian1 mendian2 #zunionstore將兩個集合進(jìn)行合并曼追,合并后的集合為mendianall,一共有2個門店汉规,分別為mendian1和門店2
zrange mendian1ll 0 -1 #查詢所有的數(shù)據(jù)礼殊,從小到大
zrange mendianall 0 -1 withscore #查看門店中的所有數(shù)據(jù),帶權(quán)重值
zrevrange mendianall 0 -1 withscore #查看門店中的所有數(shù)據(jù)针史,帶權(quán)重值晶伦,進(jìn)行倒敘,從大到小
六啄枕、bitmaps
bitmaps在string的基礎(chǔ)上延伸出來的婚陪,單個key的存儲大小為512M,如果超出了512M,會有什么情況射亏?
防止大value近忙,kv大小大于10Kb的稱為大value,如果大value的存在智润,要進(jìn)行value拆分米母。
情景:
統(tǒng)計一下喳钟,今年有多少用戶登錄了網(wǎng)站?
統(tǒng)計一下,連續(xù)上課3天的同學(xué)工扎?
統(tǒng)計用戶學(xué)習(xí)一年達(dá)到200天澳淑,贈送一門?
對于以上情景,就是2種狀態(tài)拙友,非1即0
setbit ke 10010 1 #用戶10010來上課了
setbit ke 10011 1 #用戶10011來上課了
setbit ke 10012 1 #用戶10012來上課了
getbit ke 10010 #看看10010上不是上課了
strlen ke #查看這個key占用多大空間
setbit lianxu0610 10010 1 #連續(xù)上課的時間6月10號
setbit lianxu0610 10011 1 #連續(xù)上課的時間6月11號
setbit lianxu0610 10012 1 #連續(xù)上課的時間6月12號
setbit lianxu0611 10010 1 #連續(xù)上課的時間6月10號
setbit lianxu0611 10011 1 #連續(xù)上課的時間6月11號
setbit lianxu0612 10010 1 #連續(xù)上課的時間6月10號
bitop and lianxu lianxu0610 lianxu0611 lianxu0612 #連續(xù)三天上課的用戶
bitcount ke 0 -1 #總共上課次數(shù)