redis5种数据结构讲解及使用场景
生活随笔
收集整理的這篇文章主要介紹了
redis5种数据结构讲解及使用场景
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
轉(zhuǎn)載自??https://blog.csdn.net/qq_35568881/article/details/78779679
redis提供了5中數(shù)據(jù)結(jié)構(gòu),理解每種數(shù)據(jù)結(jié)構(gòu)的特點(diǎn)對于redis開發(fā)運(yùn)維非常重要。- 1
- 2
一、字符串
字符串類型是redis最基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),首先鍵是字符串類型,而且其他幾種結(jié)構(gòu)都是在字符串類型基礎(chǔ)上構(gòu)建的, 所以字符串類型能為其他四種數(shù)據(jù)結(jié)構(gòu)的學(xué)習(xí)尊定基礎(chǔ)。 字符串類型實(shí)際上可以是字符串 (簡單的字符串、復(fù)雜的字符串(xml、json)、數(shù)字(整數(shù)、浮點(diǎn)數(shù))、二進(jìn)制(圖片、音頻、視頻)), 但最大不能超過512M。- 1
- 2
- 3
- 4
- 5
- 6
使用場景:
緩存功能:字符串最經(jīng)典的使用場景,redis最為緩存層,Mysql作為儲(chǔ)存層,絕大部分請求數(shù)據(jù)都是redis中獲取,由于redis具有支撐高并發(fā)特性,所以緩存通常能起到加速讀寫和降低 后端壓力的作用。(redis為何具備支撐高并發(fā)的特性,下次文章講解)。 計(jì)數(shù)器:許多運(yùn)用都會(huì)使用redis作為計(jì)數(shù)的基礎(chǔ)工具,他可以實(shí)現(xiàn)快速計(jì)數(shù)、查詢緩存的功能,同時(shí)數(shù)據(jù)可以一步落地到其他的數(shù)據(jù)源。如:視頻播放數(shù)系統(tǒng)就是使用redis作為視頻播放數(shù)計(jì)數(shù)的基礎(chǔ)組件。 共享session:出于負(fù)載均衡的考慮,分布式服務(wù)會(huì)將用戶信息的訪問均衡到不同服務(wù)器上,用戶刷新一次訪問可能會(huì)需要重新登錄,為避免這個(gè)問題可以用redis將用戶session集中管理,在這種模式下只要保證redis的高可用和擴(kuò)展性的,每次獲取用戶更新或查詢登錄信息都直接從redis中集中獲取。 限速:處于安全考慮,每次進(jìn)行登錄時(shí)讓用戶輸入手機(jī)驗(yàn)證碼,為了短信接口不被頻繁訪問,會(huì)限制用戶每分鐘獲取驗(yàn)證碼的頻率。- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
二、哈希
在redis中哈希類型是指鍵本身又是一種鍵值對結(jié)構(gòu),如 value={{field1,value1},......{fieldN,valueN}}- 1
- 2
使用場景:
哈希結(jié)構(gòu)相對于字符串序列化緩存信息更加直觀,并且在更新操作上更加便捷。所以常常用于**用戶信息**等管理,但是哈希類型和關(guān)系型數(shù)據(jù)庫有所不同,哈希類型是稀疏的,而關(guān)系型數(shù)據(jù)庫是完全結(jié)構(gòu)化的,關(guān)系型數(shù)據(jù)庫可以做復(fù)雜的關(guān)系查詢,而redis去模擬關(guān)系型復(fù)雜查詢開發(fā)困難,維護(hù)成本高。- 1
- 2
- 3
- 4
- 5
三、列表
列表類型是用來儲(chǔ)存多個(gè)有序的字符串,列表中的每個(gè)字符串成為元素(element),一個(gè)列表最多可以儲(chǔ)存 2的32次方-1個(gè)元素,在redis中,可以隊(duì)列表兩端插入(pubsh)和彈出(pop),還可以獲取指定范圍的元素 列表、獲取指定索引下表的元素等,列表是一種比較靈活的數(shù)據(jù)結(jié)構(gòu),它可以充當(dāng)棧和隊(duì)列的角色, 在實(shí)際開發(fā)中有很多應(yīng)用場景。 優(yōu)點(diǎn):1.列表的元素是有序的,這就意味著可以通過索引下標(biāo)獲取某個(gè)或某個(gè)范圍內(nèi)的元素列表。2.列表內(nèi)的元素是可以重復(fù)的。使用場景:
消息隊(duì)列: redis的lpush+brpop命令組合即可實(shí)現(xiàn)阻塞隊(duì)列,生產(chǎn)者客戶端是用lupsh從列表左側(cè)插入元素,多個(gè)消費(fèi)者客戶端使用brpop命令阻塞時(shí)的“搶”列表尾部的元素,多個(gè)客戶端保證了消費(fèi)的負(fù)載均衡和高可用性?
消息隊(duì)列模型↑
使用列表技巧:?
lpush+lpop=Stack(棧)?
lpush+rpop=Queue(隊(duì)列)?
lpush+ltrim=Capped Collection(有限集合)?
lpush+brpop=Message Queue(消息隊(duì)列)
四、集合
集合類型也是用來保存多個(gè)字符串的元素,但和列表不同的是集合中不允許有重復(fù)的元素,并且集合中的元素是 無序的,不能通過索引下標(biāo)獲取元素,redis除了支持集合內(nèi)的增刪改查,同時(shí)還支持多個(gè)集合取交集、并集、 差集,并合理的使用好集合類型,能在實(shí)際開發(fā)中解決很多實(shí)際問題。使用場景:
標(biāo)簽(tag):集合類型比較典型的使用場景,如一個(gè)用戶對娛樂、體育比較感興趣,另一個(gè)可能對新聞感興趣,這些興趣就是標(biāo)簽,有了這些數(shù)據(jù)就可以得到同一標(biāo)簽的人,以及用戶的共同愛好的標(biāo)簽,這些數(shù)據(jù)對于用戶體驗(yàn)以及曾強(qiáng)用戶粘度比較重要。(用戶和標(biāo)簽的關(guān)系維護(hù)應(yīng)該放在一個(gè)事物內(nèi)執(zhí)行,防止部分命令失敗造成數(shù)據(jù)不一致)sadd=tagging(標(biāo)簽) spop/srandmember=random item(生成隨機(jī)數(shù),比如抽獎(jiǎng)) sadd+sinter=social Graph(社交需求)五、有序集合
有序集合和集合有著必然的聯(lián)系,他保留了集合不能有重復(fù)成員的特性,但不同得是,有序集合中的元素是可以 排序的,但是它和列表的使用索引下標(biāo)作為排序依據(jù)不同的是,它給每個(gè)元素設(shè)置一個(gè)分?jǐn)?shù),作為排序的依據(jù)。 (有序集合中的元素不可以重復(fù),但是csore可以重復(fù),就和一個(gè)班里的同學(xué)學(xué)號不能重復(fù),但考試成績可以相 同)。列表、集合、有序集合三者的異同點(diǎn)使用場景:
排行榜:有序集合經(jīng)典使用場景。例如視頻網(wǎng)站需要對用戶上傳的視頻做排行榜,榜單維護(hù)可能是多方面:按照時(shí)間、按照播放量、按照獲得的贊數(shù)等。總結(jié)
以上是生活随笔為你收集整理的redis5种数据结构讲解及使用场景的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: redis缓存雪崩和缓存穿透
- 下一篇: redis的五种数据结构