新聞中心
Redis實(shí)現(xiàn)的并發(fā)訪問(wèn)控制

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序制作、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了青龍免費(fèi)建站歡迎大家使用!
Redis作為一個(gè)開(kāi)源的內(nèi)存數(shù)據(jù)庫(kù),可以使用C/C++開(kāi)發(fā),具有快速查找、內(nèi)存持久化等優(yōu)勢(shì),同時(shí)它也擁有一些有用的API,比如并發(fā)訪問(wèn)控制API,可以使用它來(lái)控制并發(fā)訪問(wèn)。
如果我們想對(duì)Redis進(jìn)行并發(fā)訪問(wèn)控制,我們可以使用Redis的WATCH命令,它可以監(jiān)視多個(gè)keys,當(dāng)監(jiān)視的keys被改變的時(shí)候,Redis會(huì)返回一個(gè)失敗的結(jié)果,告訴調(diào)用者key改變了。同時(shí),我們也可以使用Redis的MULTI和EXEC命令實(shí)現(xiàn)Redis的樂(lè)觀鎖,此處不做討論。
除此之外,如果需要實(shí)現(xiàn)復(fù)雜的控制,比如有限制的并發(fā)請(qǐng)求,我們需要使用Redis的腳本功能,寫(xiě)一個(gè)lua腳本,來(lái)控制指標(biāo)的請(qǐng)求。
一個(gè)簡(jiǎn)單的例子如下所示:
“`lua
local current_view_count = redis.call(“GET”, KEYS[1])
if current_view_count == nil then
redis.call(“SET”, KEYS[1], 1)
return 1
elseif tonumber(current_view_count) >= tonumber(ARGV[1]) then
return 0
else
redis.call(“INCR”, KEYS[1])
return 1
end
以上lua腳本中,我們定義了一個(gè)KEY,對(duì)應(yīng)的值可以記錄當(dāng)前訪問(wèn)量,同時(shí)傳入一個(gè)參數(shù)ARGV[1],表示最大訪問(wèn)量,當(dāng)current_view_count大于等于ARGV[1]時(shí),會(huì)返回0,否則返回1,表示可以正常訪問(wèn)。
除了上述腳本,我們還可以使用Redis的鎖功能來(lái)控制訪問(wèn),可以使用SETNX、EXPIRE和GETSET命令來(lái)實(shí)現(xiàn)。
在實(shí)現(xiàn)Redis的并發(fā)訪問(wèn)控制時(shí),需要注意兩點(diǎn),一是保證獲取到的信息是有效的,二是緩存預(yù)熱,確保緩存可用。
成都服務(wù)器租用選創(chuàng)新互聯(lián),先試用再開(kāi)通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)提供簡(jiǎn)單好用,價(jià)格厚道的香港/美國(guó)云服務(wù)器和獨(dú)立服務(wù)器。物理服務(wù)器托管租用:四川成都、綿陽(yáng)、重慶、貴陽(yáng)機(jī)房服務(wù)器托管租用。
分享文章:Redis實(shí)現(xiàn)的并發(fā)訪問(wèn)控制(redis防止并發(fā)設(shè)置)
文章出自:http://www.dlmjj.cn/article/djdeeej.html


咨詢
建站咨詢
