這篇文章主要介紹“redis 5大數(shù)據(jù)結(jié)構(gòu)是什么”,在日常操作中,相信很多人在Redis 5大數(shù)據(jù)結(jié)構(gòu)是什么問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”Redis 5大數(shù)據(jù)結(jié)構(gòu)是什么”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)公司專(zhuān)注于察雅企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,成都做商城網(wǎng)站。察雅網(wǎng)站建設(shè)公司,為察雅等地區(qū)提供建站服務(wù)。全流程按需搭建網(wǎng)站,專(zhuān)業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專(zhuān)業(yè)和態(tài)度為您提供的服務(wù)
一、字符串
字符串類(lèi)型是redis最基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),首先鍵是字符串類(lèi)型,而且其他幾種結(jié)構(gòu)都是在字符串類(lèi)型基礎(chǔ)上構(gòu)建的,所以字符串類(lèi)型能為其他四種數(shù)據(jù)結(jié)構(gòu)的學(xué)習(xí)尊定基礎(chǔ)。字符串類(lèi)型實(shí)際上可以是字符串(簡(jiǎn)單的字符串、復(fù)雜的字符串(xml、json)、數(shù)字(整數(shù)、浮點(diǎn)數(shù))、二進(jìn)制(圖片、音頻、視頻)),但最大不能超過(guò)512M。
使用場(chǎng)景:
緩存功能:字符串最經(jīng)典的使用場(chǎng)景,redis最為緩存層,MySQL作為儲(chǔ)存層,絕大部分請(qǐng)求數(shù)據(jù)都是redis中獲取,由于redis具有支撐高并發(fā)特性,所以緩存通常能起到加速讀寫(xiě)和降低 后端壓力的作用。(redis為何具備支撐高并發(fā)的特性,下次文章講解)。
計(jì)數(shù)器:許多運(yùn)用都會(huì)使用redis作為計(jì)數(shù)的基礎(chǔ)工具,他可以實(shí)現(xiàn)快速計(jì)數(shù)、查詢(xún)緩存的功能,同時(shí)數(shù)據(jù)可以一步落地到其他的數(shù)據(jù)源。如:視頻播放數(shù)系統(tǒng)就是使用redis作為視頻播放數(shù)計(jì)數(shù)的基礎(chǔ)組件。
共享session:出于負(fù)載均衡的考慮,分布式服務(wù)會(huì)將用戶(hù)信息的訪問(wèn)均衡到不同服務(wù)器上,用戶(hù)刷新一次訪問(wèn)可能會(huì)需要重新登錄,為避免這個(gè)問(wèn)題可以用redis將用戶(hù)session集中管理,在這種模式下只要保證redis的高可用和擴(kuò)展性的,每次獲取用戶(hù)更新或查詢(xún)登錄信息都直接從redis中集中獲取。
限速:處于安全考慮,每次進(jìn)行登錄時(shí)讓用戶(hù)輸入手機(jī)驗(yàn)證碼,為了短信接口不被頻繁訪問(wèn),會(huì)限制用戶(hù)每分鐘獲取驗(yàn)證碼的頻率。
二、哈希
在redis中哈希類(lèi)型是指鍵本身又是一種鍵值對(duì)結(jié)構(gòu),如 value={{field1,value1},......fieldN,valueN}}
使用場(chǎng)景:哈希結(jié)構(gòu)相對(duì)于字符串序列化緩存信息更加直觀,并且在更新操作上更加便捷。所以常常用于用戶(hù)信息等管理,但是哈希類(lèi)型和關(guān)系型數(shù)據(jù)庫(kù)有所不同,哈希類(lèi)型是稀疏的,而關(guān)系型數(shù)據(jù)庫(kù)是完全結(jié)構(gòu)化的,關(guān)系型數(shù)據(jù)庫(kù)可以做復(fù)雜的關(guān)系查詢(xún),而redis去模擬關(guān)系型復(fù)雜查詢(xún),開(kāi)發(fā)困難,維護(hù)成本高。
三、列表
列表類(lèi)型是用來(lái)儲(chǔ)存多個(gè)有序的字符串,列表中的每個(gè)字符串成為元素(element),一個(gè)列表最多可以?xún)?chǔ)存2的32次方-1個(gè)元素,在redis中,可以隊(duì)列表兩端插入(pubsh)和彈出(pop),還可以獲取指定范圍的元素列表、獲取指定索引下表的元素等,列表是一種比較靈活的數(shù)據(jù)結(jié)構(gòu),它可以充當(dāng)棧和隊(duì)列的角色,在實(shí)際開(kāi)發(fā)中有很多應(yīng)用場(chǎng)景。
優(yōu)點(diǎn):
列表的元素是有序的,這就意味著可以通過(guò)索引下標(biāo)獲取某個(gè)或某個(gè)范圍內(nèi)的元素列表。
列表內(nèi)的元素是可以重復(fù)的。
使用場(chǎng)景:
消息隊(duì)列: redis的lpush+brpop
命令組合即可實(shí)現(xiàn)阻塞隊(duì)列,生產(chǎn)者客戶(hù)端是用lupsh從列表左側(cè)插入元素,多個(gè)消費(fèi)者客戶(hù)端使用brpop
命令阻塞時(shí)的“搶”列表尾部的元素,多個(gè)客戶(hù)端保證了消費(fèi)的負(fù)載均衡和高可用性clipboard.png消息隊(duì)列模型↑
文章列表:每個(gè)用戶(hù)都有屬于自己的文章列表,現(xiàn)在需要分頁(yè)展示文章列表,此時(shí)可以考慮使用列表,列表不但有序,同時(shí)支持按照索引范圍獲取元素。
四、集合
集合類(lèi)型也是用來(lái)保存多個(gè)字符串的元素,但和列表不同的是集合中不允許有重復(fù)的元素,并且集合中的元素是無(wú)序的,不能通過(guò)索引下標(biāo)獲取元素,redis除了支持集合內(nèi)的增刪改查,同時(shí)還支持多個(gè)集合取交集、并集、差集,并合理的使用好集合類(lèi)型,能在實(shí)際開(kāi)發(fā)中解決很多實(shí)際問(wèn)題。
使用場(chǎng)景:
標(biāo)簽(tag):集合類(lèi)型比較典型的使用場(chǎng)景,如一個(gè)用戶(hù)對(duì)娛樂(lè)、體育比較感興趣,另一個(gè)可能對(duì)新聞感興 趣,這些興趣就是標(biāo)簽,有了這些數(shù)據(jù)就可以得到同一標(biāo)簽的人,以及用戶(hù)的共同愛(ài)好的標(biāo)簽,這些數(shù)據(jù)對(duì)于用戶(hù)體驗(yàn)以及曾強(qiáng)用戶(hù)粘度比較重要。(用戶(hù)和標(biāo)簽的關(guān)系維護(hù)應(yīng)該放在一個(gè)事物內(nèi)執(zhí)行,防止部分命令失敗造成數(shù)據(jù)不一致)
五、有序集合
有序集合和集合有著必然的聯(lián)系,他保留了集合不能有重復(fù)成員的特性,但不同得是,有序集合中的元素是可以排序的,但是它和列表的使用索引下標(biāo)作為排序依據(jù)不同的是,它給每個(gè)元素設(shè)置一個(gè)分?jǐn)?shù),作為排序的依據(jù)。(有序集合中的元素不可以重復(fù),但是csore可以重復(fù),就和一個(gè)班里的同學(xué)學(xué)號(hào)不能重復(fù),但考試成績(jī)可以相同)。
到此,關(guān)于“Redis 5大數(shù)據(jù)結(jié)構(gòu)是什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
文章名稱(chēng):Redis5大數(shù)據(jù)結(jié)構(gòu)是什么
文章分享:http://jinyejixie.com/article46/pggshg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、微信公眾號(hào)、定制開(kāi)發(fā)、網(wǎng)站導(dǎo)航、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站營(yíng)銷(xiāo)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)