Redis中漸進(jìn)式遍歷Scan命令的使用
之前我們學(xué)習(xí)過遍歷命令keys,而keys *是一次性的把整個(gè)redis中所有的key都獲取到.在不知道當(dāng)前redis中有多少key的情況下,這個(gè)操作是非常危險(xiǎn)的,可能會(huì)一下子得到太多的key而阻塞redis服務(wù)器.從而使其他redis客戶端卡頓.
通過漸進(jìn)式遍歷,就可以做到,既可以獲取到所有的key,同時(shí)又不會(huì)阻塞服務(wù)器.
漸進(jìn)式遍歷,不是一個(gè)命令把所有的key都拿到,而是每執(zhí)行一次命令,只會(huì)獲取其中的一部分,要想得到所有的key就需要多次執(zhí)行漸進(jìn)式遍歷命令,進(jìn)行多次遍歷.
漸進(jìn)式命令其實(shí)是一組命令,這一組命令的使用方法是一樣的,其中的代表命令就是scan.
cursor:代表光標(biāo),指向了當(dāng)前遍歷的位置.
首次scan光標(biāo)是從0開始的,當(dāng)scan返回的下次光標(biāo)的位置是0的時(shí)候,就代表完成了一次完整的遍歷了.
注意此處的光標(biāo)不能理解為下標(biāo),光標(biāo)不是一個(gè)連續(xù)遞增的整數(shù),僅僅是一個(gè)"字符串",只有redis服務(wù)器知道這個(gè)光標(biāo)對(duì)應(yīng)的元素位置,redis客戶端和程序員是不知道的.
光標(biāo)設(shè)置成0,意味著這一次遍歷是從頭開始獲取的,返回值的前半部分表示下次遍歷,光標(biāo)應(yīng)該從哪里開始;后半部分則表示真正遍歷到的key的內(nèi)容.
pattern就和keys命令的里pattern一樣.指的是字符串匹配規(guī)則.
count表示此次遍歷要獲取多少個(gè)key.注意此處的count只是給redis服務(wù)器一個(gè)"建議",寫入的count和實(shí)際返回的key的個(gè)數(shù)不一定是一致的,可能會(huì)多幾個(gè),也可能會(huì)少幾個(gè),但是總體上不會(huì)相差太多.
type:指定要遍歷的key的value類型是什么,比如寫string就表示此次遍歷遍歷出的key對(duì)應(yīng)的value類型都是string.
count這里的數(shù)字不是說每次遍歷都得設(shè)置成一樣.
這里的漸進(jìn)式遍歷,在遍歷過程中,不會(huì)在服務(wù)器這里存儲(chǔ)任何的狀態(tài)信息,此處的遍歷時(shí)是隨時(shí)可以終止的,不會(huì)對(duì)服務(wù)器產(chǎn)生任何的副作用.
漸進(jìn)式遍歷scan雖然解決了阻塞的問題,但如果在遍歷期間key有所變化(增加或者刪除),可能導(dǎo)致遍歷時(shí)鍵的重復(fù)遍歷或者遺漏,這一點(diǎn)要特別注意!!!
redis中的數(shù)據(jù)庫管理
redis中也是有database這樣的概念的,只不過不像mysql那樣可以隨意的創(chuàng)建和刪除database,redis中的database都是現(xiàn)成的,用戶不能創(chuàng)建新的數(shù)據(jù)庫也不能刪除已有的數(shù)據(jù)庫.
默認(rèn)redis給用戶提供了16個(gè)數(shù)據(jù)庫(0-15),這16個(gè)數(shù)據(jù)庫中的數(shù)據(jù)是隔離的,相互之間不會(huì)有影響.
默認(rèn)情況下使用的數(shù)據(jù)庫都是0號(hào).
可以使用select dbIndex來切換數(shù)據(jù)庫.實(shí)際使用redis很少會(huì)關(guān)注到數(shù)據(jù)庫,一般都是默認(rèn)使用0號(hào)數(shù)據(jù)庫就可以了.
切換到0-15之外的會(huì)報(bào)錯(cuò).
flushdb是刪除當(dāng)前數(shù)據(jù)庫中所有的key,flushall刪除所有數(shù)據(jù)庫中的key.
時(shí)間復(fù)雜度都是O(N),flushdb中N指的是當(dāng)前數(shù)據(jù)庫中的key的個(gè)數(shù),flushall中的N是所有數(shù)據(jù)庫中key的個(gè)數(shù).
上述兩個(gè)命令在生產(chǎn)環(huán)境里要慎用!!!!!!!
dbsize用來查詢當(dāng)前數(shù)據(jù)庫中key的個(gè)數(shù).
到此這篇關(guān)于Redis中漸進(jìn)式遍歷Scan命令的使用的文章就介紹到這了,更多相關(guān)Redis Scan命令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis查看KEY的數(shù)據(jù)類型的方法和步驟
在Redis中,可以使用 TYPE 命令來查看指定key的數(shù)據(jù)類型,該命令會(huì)返回存儲(chǔ)在指定key中的值的數(shù)據(jù)類型,本文給大家介紹了具體的使用方法和步驟,感興趣的朋友可以參考下2024-04-04使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜的示例
為了實(shí)現(xiàn)一個(gè)實(shí)時(shí)排行榜系統(tǒng),我們可以使用Redis的有序集合,本文主要介紹了使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜的示例,具有一定的參考價(jià)值,感興趣的可以了解一下2025-04-04Redis密碼設(shè)置與訪問限制實(shí)現(xiàn)方法
這篇文章主要介紹了Redis密碼設(shè)置與訪問限制實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜功能
排行榜功能是一個(gè)很普遍的需求。使用 Redis 中有序集合的特性來實(shí)現(xiàn)排行榜是又好又快的選擇。接下來通過本文給大家介紹使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜功能,需要的朋友可以參考下2021-07-07