摘要:總結(jié)上面的這些所謂鎖,也就是利用了,還有自帶的來(lái)進(jìn)行操作的一定保證,也就間接的實(shí)現(xiàn)鎖的操作,這也是基于對(duì)的底層原理理解。
redis鎖
redis的鎖分別有INCR、SETNX、SET,那么我們就開(kāi)始來(lái)談?wù)勊麄兊挠梅ê蛨?chǎng)景吧!
1.INCR:(計(jì)時(shí)器,+1操作)
????a) 語(yǔ)法:INCR key
????b) 場(chǎng)景:
????????1)控制api 1秒內(nèi)的多次訪問(wèn) ;
????????2)記錄用戶每天訪問(wèn)網(wǎng)站的登錄次數(shù) ;
????c) 為何我們說(shuō)這個(gè)怎么能算鎖呢,當(dāng)然,多帶帶它肯定是算不了鎖的,因?yàn)樗旧砭筒粩嗟?1 +1,那我們?cè)趺崔k呢,來(lái)看下面的:
????????1) 我們?nèi)绾螌?shí)現(xiàn)場(chǎng)景1) 呢?
FUNCTION LIMIT_API_CALL(ip) ts = CURRENT_UNIX_TIME() keyname = ip+":"+ts current = GET(keyname) IF current != NULL AND current > 10 THEN ERROR "too many requests per second" ELSE MULTI INCR(keyname,1) EXPIRE(keyname,1) EXEC PERFORM_API_CALL() END
????????2) 我們?nèi)绾螌?shí)現(xiàn)場(chǎng)景2) 呢?
INCR key
????????然后我們?cè)谑褂肐NCR的時(shí)候,一般都是要借助EXPIRE這個(gè)命令來(lái)結(jié)合使用:(我始終覺(jué)得這種使用的場(chǎng)景太局限了,也就一秒,而且也只能+1,在增 1 就會(huì)不行,實(shí)際上我們也就控制數(shù)量為 1 而已了,保證只能為 1)
$redis->incr($key); $redis->expire($key, $outtime); //設(shè)置生成時(shí)間為1秒
2.SETNX: 這個(gè)我就不講了,因?yàn)樵趓edis 2.6.12版本就會(huì)被拋棄的了
3.SET:
????a) 語(yǔ)法:SET KEY VALUE [EX seconds] [PX milliseconds] [NX|XX]
????b) 場(chǎng)景:
????????1) set最大可以接受512M的長(zhǎng)度,所以緩存放這里也是沒(méi)問(wèn)題噠;
????????2) 來(lái)對(duì)數(shù)據(jù)進(jìn)行添加,比如要添加某個(gè)用戶,如果存在,則不給予操作。
????c) 其實(shí)這個(gè)鎖的實(shí)現(xiàn)也就是利用了set的NX ,因?yàn)镹X是如果存在,則不進(jìn)行添加或修改,然后同時(shí)SET也是有expires的過(guò)期時(shí)間來(lái)釋放鎖的。
總結(jié):
????上面的這些所謂鎖,也就是利用了expire,還有自帶的NX來(lái)進(jìn)行操作的一定保證,也就間接的實(shí)現(xiàn)鎖的操作,這也是基于對(duì)redis的底層原理理解。
關(guān)注回復(fù) wxq ,驗(yàn)證后即加入php微信群,即將在公眾號(hào)深度剖析redis的事務(wù)鎖 + 分布式鎖
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/29120.html
摘要:總結(jié)上面的這些所謂鎖,也就是利用了,還有自帶的來(lái)進(jìn)行操作的一定保證,也就間接的實(shí)現(xiàn)鎖的操作,這也是基于對(duì)的底層原理理解。 redis鎖 redis的鎖分別有INCR、SETNX、SET,那么我們就開(kāi)始來(lái)談?wù)勊麄兊挠梅ê蛨?chǎng)景吧! 1.INCR:(計(jì)時(shí)器,+1操作)????a) 語(yǔ)法:INCR key????b) 場(chǎng)景:????????1)控制api 1秒內(nèi)的多次訪問(wèn) ;????????2...
摘要:前段時(shí)間,有個(gè)人吐槽自己的同事是上古程序猿,一直堅(jiān)持反對(duì)使用。上古程序猿堅(jiān)決反對(duì)用,我該怎么說(shuō)服他分布式鎖如果你是一位后端工程師,面試時(shí)八成會(huì)被問(wèn)到,特別是大廠,不僅要求能簡(jiǎn)單使用,還要深入理解底層原理,具備解決常見(jiàn)問(wèn)題的能力。 前段時(shí)間,有個(gè)人吐槽自己的同事是上古程序猿,一直堅(jiān)持反對(duì)使用Redis。那位上古程序猿設(shè)計(jì)公司...
摘要:前段時(shí)間,有個(gè)人吐槽自己的同事是上古程序猿,一直堅(jiān)持反對(duì)使用。那位上古程序猿設(shè)計(jì)公司的業(yè)務(wù)系統(tǒng)時(shí)候,始終堅(jiān)持永遠(yuǎn)不要用緩存其他人想用,例如做個(gè)接口防重復(fù),一定要用數(shù)據(jù)庫(kù)來(lái)實(shí)現(xiàn),包括定期失效之類的功能。項(xiàng)目中使用,主要考慮性能和并發(fā)。 前段時(shí)間,有個(gè)人吐槽自己的同事是上古程序猿,一直堅(jiān)持反對(duì)使...
閱讀 2632·2021-11-19 09:56
閱讀 880·2021-09-24 10:25
閱讀 1650·2021-09-09 09:34
閱讀 2204·2021-09-09 09:33
閱讀 1063·2019-08-30 15:54
閱讀 550·2019-08-29 18:33
閱讀 1274·2019-08-29 17:19
閱讀 512·2019-08-29 14:19