Redis實戰(zhàn)場景設(shè)計

一、字符串

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ù)

Redis分布式鎖的正確操作方式

image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市歼郭,隨后出現(xiàn)的幾起案子遗契,更是在濱河造成了極大的恐慌,老刑警劉巖病曾,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牍蜂,死亡現(xiàn)場離奇詭異,居然都是意外死亡泰涂,警方通過查閱死者的電腦和手機(jī)鲫竞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來逼蒙,“玉大人从绘,你說我怎么就攤上這事∈抢危” “怎么了僵井?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長妖泄。 經(jīng)常有香客問我驹沿,道長,這世上最難降的妖魔是什么蹈胡? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任渊季,我火速辦了婚禮,結(jié)果婚禮上罚渐,老公的妹妹穿的比我還像新娘却汉。我一直安慰自己,他們只是感情好荷并,可當(dāng)我...
    茶點故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布合砂。 她就那樣靜靜地躺著,像睡著了一般源织。 火紅的嫁衣襯著肌膚如雪翩伪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天谈息,我揣著相機(jī)與錄音缘屹,去河邊找鬼。 笑死侠仇,一個胖子當(dāng)著我的面吹牛轻姿,可吹牛的內(nèi)容都是我干的犁珠。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼互亮,長吁一口氣:“原來是場噩夢啊……” “哼犁享!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起豹休,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤炊昆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后威根,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體窑眯,經(jīng)...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年医窿,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片炊林。...
    茶點故事閱讀 38,654評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡姥卢,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出渣聚,到底是詐尸還是另有隱情独榴,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布奕枝,位于F島的核電站棺榔,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏隘道。R本人自食惡果不足惜症歇,卻給世界環(huán)境...
    茶點故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望谭梗。 院中可真熱鬧忘晤,春花似錦、人聲如沸激捏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽远舅。三九已至闰蛔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間图柏,已是汗流浹背序六。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留爆办,地道東北人难咕。 一個月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親余佃。 傳聞我的和親對象是個殘疾皇子暮刃,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,543評論 2 349

推薦閱讀更多精彩內(nèi)容