redis提供了5中資料結構(string,hash,list,set,zset),下面我們來講解一下5種資料型別以及應用場景
講解:使用場景:
快取功能:
字串最經典的使用場景,redis最為快取層,mysql作為儲存層,絕大部分請求資料都是redis中獲取,由於redis具有支撐高併發特性,所以快取通常能起到加速讀寫和降低 後端壓力的作用。
計數器:共享session:
出於負載均衡的考慮,分布式服務會將使用者資訊的訪問均衡到不同伺服器上,使用者重新整理一次訪問可能會需要重新登入,為避免這個問題可以用redis將使用者session集中管理,在這種模式下只要保證redis的高可用和擴充套件性的,每次獲取使用者更新或查詢登入資訊都直接從redis中集中獲取。
限速:
處於安全考慮,每次進行登入時讓使用者輸入手機驗證碼,為了簡訊介面不被頻繁訪問,會限制使用者每分鐘獲取驗證碼的頻率。
講解:在redis中雜湊型別是指鍵本身又是一種鍵值對結構,如 value=,…}
使用場景:
雜湊結構相對於字串序列化快取資訊更加直觀,並且在更新操作上更加便捷。
所以常常用於使用者資訊等管理,但是雜湊型別和關係型資料庫有所不同,雜湊型別是稀疏的,而關係型資料庫是完全結構化的,關係型資料庫可以做複雜的關係查詢,而redis去模擬關係型複雜查詢開發困難,維護成本高。
列表型別是用來儲存多個有序的字串,列表中的每個字串成為元素(element),乙個列表最多可以儲存
2的32次方-1個元素,在redis中,可以隊列表兩端插入(pubsh)和彈出(pop),還可以獲取指定範圍的元素
列表、獲取指定索引下表的元素等,列表是一種比較靈活的資料結構,它可以充當棧和佇列的角色,
在實際開發中有很多應用場景。
優點:
1.列表的元素是有序的,這就意味著可以通過索引下標獲取某個或某個範圍內的元素列表。
2.列表內的元素是可以重複的。
使用場景:
訊息佇列:
redis的lpush+brpop命令組合即可實現阻塞佇列,生產者客戶端是用lupsh從列表左側插入元素,多個消費者客戶端使用brpop命令阻塞時的「搶」列表尾部的元素,多個客戶端保證了消費的負載均衡和高可用性
每個使用者都有屬於自己的文章列表,現在需要分頁展示文章列表,此時可以考慮使用列表,列表不但有序
同時支援按照索引範圍獲取元素。
使用列表技巧:講解:
集合型別也是用來儲存多個字串的元素,但和列表不同的是集合中不允許有重複的元素,並且集合中的元素是
無序的,不能通過索引下標獲取元素,redis除了支援集合內的增刪改查,同時還支援多個集合取交集、並集、
差集,並合理的使用好集合型別,能在實際開發中解決很多實際問題。
使用場景:
標籤(tag):
集合型別比較典型的使用場景,如乙個使用者對娛樂、體育比較感興趣,另乙個可能對新聞感興趣,這些興趣就是標籤,有了這些資料就可以得到同一標籤的人,以及使用者的共同愛好的標籤,這些資料對於使用者體驗以及曾強使用者粘度比較重要。
(使用者和標籤的關係維護應該放在乙個事物內執行,防止部分命令失敗造成資料不一致)
sadd=tagging(標籤)
spop/srandmember=random item(生成隨機數,比如**)
sadd+sinter=social graph(社交需求)
講解:有序集合和集合有著必然的聯絡,他保留了集合不能有重複成員的特性,但不同得是,有序集合中的元素是可以排序的,但是它和列表的使用索引下標作為排序依據不同的是,它給每個元素設定乙個分數,作為排序的依據。(有序集合中的元素不可以重複,但是csore可以重複,就和乙個班裡的同學學號不能重複,但考試成績可以相同)。
使用場景:
Redis資料型別及應用場景
1 redis 是一種鍵值 key value 資料庫。相對於關係型資料庫 比如 mysql redis 也被叫作非關係型資料庫。除此之外,redis 主要是作為記憶體資料庫來使用,也就是說,資料是儲存在記憶體中的。儘管它經常被用作記憶體資料庫,但是,它也支援將資料持久化到硬碟中。2 redis的每...
Redis 資料型別及應用場景
通常我們都把資料存到關係型資料庫中,但為了提公升應用的效能,我們應該把訪頻率高且不會經常變動的資料快取到記憶體中。redis 沒有像 mysql 這類關係型資料庫那樣強大的查詢功能,需要考慮如何把關係型資料庫中的資料,合理的對應到快取的 key value 資料結構中。分段設計法 使用冒號把 key...
redis的資料型別及應用場景
redis主要有以下資料型別 string hash list set sorted set。string 這是最基本的型別,就是最普通的set及get,做簡單的key value快取。hash 這個是類似於map的一種結構,一般就是可以將結構化的資料,比如乙個物件 前提是這個物件沒有巢狀其他物件 ...