欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解鎖redis鎖的正確姿勢(shì)

 更新時(shí)間:2017年03月22日 10:59:41   作者:葉劍峰  
這篇文章主要為大家詳細(xì)介紹了解鎖redis鎖的正確姿勢(shì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

解鎖redis鎖的正確姿勢(shì)

redis是php的好朋友,在php寫業(yè)務(wù)過程中,有時(shí)候會(huì)使用到鎖的概念,同時(shí)只能有一個(gè)人可以操作某個(gè)行為。這個(gè)時(shí)候我們就要用到鎖。鎖的方式有好幾種,php不能在內(nèi)存中用鎖,不能使用zookeeper加鎖,使用數(shù)據(jù)庫(kù)做鎖又消耗比較大,這個(gè)時(shí)候我們一般會(huì)選用redis做鎖機(jī)制。

setnx

鎖在redis中最簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu)就是string。最早的時(shí)候,上鎖的操作一般使用setnx,這個(gè)命令是當(dāng):lock不存在的時(shí)候set一個(gè)val,或許你還會(huì)記得使用expire來(lái)增加鎖的過期,解鎖操作就是使用del命令,偽代碼如下:

if (Redis::setnx("my:lock", 1)) {
  Redis::expire("my:lock", 10);
  // ... do something

  Redis::del("my:lock")
}

這里其實(shí)是有問題的,問題就在于setnx和expire中間如果遇到crash等行為,可能這個(gè)lock就不會(huì)被釋放了。于是進(jìn)一步的優(yōu)化方案可能是在lock中存儲(chǔ)timestamp。判斷timestamp的長(zhǎng)短。

set

現(xiàn)在官方建議直接使用set來(lái)實(shí)現(xiàn)鎖。我們可以使用set命令來(lái)替代setnx,就是下面這個(gè)樣子

if (Redis::set("my:lock", 1, "nx", "ex", 10)) {
  ... do something

  Redis::del("my:lock")
}

上面的代碼把my:lock設(shè)置為1,當(dāng)且僅當(dāng)這個(gè)lock不存在的時(shí)候,設(shè)置完成之后設(shè)置過期時(shí)間為10。

獲取鎖的機(jī)制是對(duì)了,但是刪除鎖的機(jī)制直接使用del是不對(duì)的。因?yàn)橛锌赡軐?dǎo)致誤刪別人的鎖的情況。

比如,這個(gè)鎖我上了10s,但是我處理的時(shí)間比10s更長(zhǎng),到了10s,這個(gè)鎖自動(dòng)過期了,被別人取走了,并且對(duì)它重新上鎖了。那么這個(gè)時(shí)候,我再調(diào)用Redis::del就是刪除別人建立的鎖了。

官方對(duì)解鎖的命令也有建議,建議使用lua腳本,先進(jìn)行g(shù)et,再進(jìn)行del

程序變成:

$token = rand(1, 100000);

function lock() {
  return Redis::set("my:lock", $token, "nx", "ex", 10);
}

function unlock() {
  $script = `
if redis.call("get",KEYS[1]) == ARGV[1]
then
  return redis.call("del",KEYS[1])
else
  return 0
end  
  `
  return Redis::eval($script, "my:lock", $token)
}

if (lock()) {
  // do something

  unlock();
}

這里的token是一個(gè)隨機(jī)數(shù),當(dāng)lock的時(shí)候,往redis的my:lock中存的是這個(gè)token,unlock的時(shí)候,先get一下lock中的token,如果和我要?jiǎng)h除的token是一致的,說(shuō)明這個(gè)鎖是之前我set的,否則的話,說(shuō)明這個(gè)鎖已經(jīng)過期,是別人set的,我就不應(yīng)該對(duì)它進(jìn)行任何操作。

所以:不要再使用setnx,直接使用set進(jìn)行鎖實(shí)現(xiàn)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Redis Cluster 字段模糊匹配及刪除

    Redis Cluster 字段模糊匹配及刪除

    在數(shù)據(jù)庫(kù)內(nèi)我們可以通過like關(guān)鍵字、%、*或者REGEX關(guān)鍵字進(jìn)行模糊匹配。而在Redis內(nèi)我們?nèi)绾芜M(jìn)行模糊匹配呢?本文就來(lái)介紹一下
    2021-05-05
  • 一文帶你了解Redis的三種集群模式

    一文帶你了解Redis的三種集群模式

    Redis?的常用的集群方式主要有以下三種,分別是主從復(fù)制模式、哨兵模式、Redis-Cluster集群模式,那么下面我們就分別了解一下這三種集群模式的優(yōu)點(diǎn)與缺點(diǎn)
    2023-06-06
  • Redis實(shí)現(xiàn)訂單過期刪除的方法步驟

    Redis實(shí)現(xiàn)訂單過期刪除的方法步驟

    本文主要介紹了Redis實(shí)現(xiàn)訂單過期刪除的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Redis特殊數(shù)據(jù)類型HyperLogLog基數(shù)統(tǒng)計(jì)算法講解

    Redis特殊數(shù)據(jù)類型HyperLogLog基數(shù)統(tǒng)計(jì)算法講解

    這篇文章主要為大家介紹了Redis特殊數(shù)據(jù)類型HyperLogLog基數(shù)統(tǒng)計(jì)算法講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Redis分布式緩存的安裝

    Redis分布式緩存的安裝

    這篇文章主要介紹了Redis分布式緩存的安裝,Redis?是一個(gè)開源(BSD許可)的,內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)系統(tǒng),它可以用作數(shù)據(jù)庫(kù)、緩存和消息中間件,需要的朋友可以參考下
    2023-05-05
  • 壓縮Redis里的字符串大對(duì)象操作

    壓縮Redis里的字符串大對(duì)象操作

    這篇文章主要介紹了壓縮Redis里的字符串大對(duì)象操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Redis的11種Web應(yīng)用場(chǎng)景簡(jiǎn)介

    Redis的11種Web應(yīng)用場(chǎng)景簡(jiǎn)介

    一些Redis原語(yǔ)命令比如LPUSH、LTRIM和 LREM等等能夠用來(lái)幫助開發(fā)者完成需要的任務(wù)——這些任務(wù)在傳統(tǒng)的數(shù)據(jù)庫(kù)存儲(chǔ)中非常困難或緩慢。這是一篇非常有用并且實(shí)際的文章。那么要如何在你的框架中完成這些任務(wù)呢?
    2015-09-09
  • Redis操作相關(guān)命令之查看、停止、啟動(dòng)命令

    Redis操作相關(guān)命令之查看、停止、啟動(dòng)命令

    這篇文章主要介紹了Redis操作相關(guān)命令之查看、停止、啟動(dòng)命令,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Redis拓展之定時(shí)消息通知實(shí)現(xiàn)詳解

    Redis拓展之定時(shí)消息通知實(shí)現(xiàn)詳解

    這篇文章主要為大家介紹了Redis拓展之定時(shí)消息通知實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Springboot/Springcloud項(xiàng)目集成redis進(jìn)行存取的過程解析

    Springboot/Springcloud項(xiàng)目集成redis進(jìn)行存取的過程解析

    大家都知道Redis支持五種數(shù)據(jù)類型:string(字符串),hash(哈希),list(列表),set(集合),zset(sorted set:有序集合),本文重點(diǎn)給大家介紹Springboot/Springcloud項(xiàng)目集成redis進(jìn)行存取的過程,需要的朋友參考下吧
    2021-12-12

最新評(píng)論