您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Redis常見的數(shù)據(jù)類型有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Redis常見的數(shù)據(jù)類型有哪些”吧!
Redis所有的key(鍵)都是字符串。我們在談基礎數(shù)據(jù)結(jié)構(gòu)時,討論的是存儲值的數(shù)據(jù)類型,主要包括常見的5種數(shù)據(jù)類型,分別是:String、List、Set、Zset、Hash
Redis入門 - 數(shù)據(jù)類型:5種基礎數(shù)據(jù)類型詳解
String字符串
List列表
Set集合
Hash散列
Zset有序集合
Redis數(shù)據(jù)結(jié)構(gòu)簡介
基礎數(shù)據(jù)結(jié)構(gòu)詳解
參考文章
Redis基礎文章非常多,關于基礎數(shù)據(jù)結(jié)構(gòu)類型,我推薦你先看下官方網(wǎng)站內(nèi)容,然后再看下面的小結(jié)
首先對redis來說,所有的key(鍵)都是字符串。我們在談基礎數(shù)據(jù)結(jié)構(gòu)時,討論的是存儲值的數(shù)據(jù)類型,主要包括常見的5種數(shù)據(jù)類型,分別是:String、List、Set、Zset、Hash。
結(jié)構(gòu)類型 | 結(jié)構(gòu)存儲的值 | 結(jié)構(gòu)的讀寫能力 |
---|---|---|
String字符串 | 可以是字符串、整數(shù)或浮點數(shù) | 對整個字符串或字符串的一部分進行操作;對整數(shù)或浮點數(shù)進行自增或自減操作; |
List列表 | 一個鏈表,鏈表上的每個節(jié)點都包含一個字符串 | 對鏈表的兩端進行push和pop操作,讀取單個或多個元素;根據(jù)值查找或刪除元素; |
Set集合 | 包含字符串的無序集合 | 字符串的集合,包含基礎的方法有看是否存在添加、獲取、刪除;還包含計算交集、并集、差集等 |
Hash散列 | 包含鍵值對的無序散列表 | 包含方法有添加、獲取、刪除單個元素 |
Zset有序集合 | 和散列一樣,用于存儲鍵值對 | 字符串成員與浮點數(shù)分數(shù)之間的有序映射;元素的排列順序由分數(shù)的大小決定;包含方法有添加、獲取、刪除單個元素以及根據(jù)分值范圍或成員來獲取元素 |
內(nèi)容其實比較簡單,我覺得理解的重點在于這個結(jié)構(gòu)怎么用,能夠用來做什么?所以我在梳理時,圍繞圖例,命令,執(zhí)行和場景來闡述。@pdai
String是redis中最基本的數(shù)據(jù)類型,一個key對應一個value。
String類型是二進制安全的,意思是 redis 的 string 可以包含任何數(shù)據(jù)。如數(shù)字,字符串,jpg圖片或者序列化的對象。
圖例
下圖是一個String類型的實例,其中鍵為hello,值為world
命令使用
命令 | 簡述 | 使用 |
---|---|---|
GET | 獲取存儲在給定鍵中的值 | GET name |
SET | 設置存儲在給定鍵中的值 | SET name value |
DEL | 刪除存儲在給定鍵中的值 | DEL name |
INCR | 將鍵存儲的值加1 | INCR key |
DECR | 將鍵存儲的值減1 | DECR key |
INCRBY | 將鍵存儲的值加上整數(shù) | INCRBY key amount |
DECRBY | 將鍵存儲的值減去整數(shù) | DECRBY key amount |
命令執(zhí)行
127.0.0.1:6379> set hello world OK 127.0.0.1:6379> get hello "world" 127.0.0.1:6379> del hello (integer) 1 127.0.0.1:6379> get hello (nil) 127.0.0.1:6379> get counter "2" 127.0.0.1:6379> incr counter (integer) 3 127.0.0.1:6379> get counter "3" 127.0.0.1:6379> incrby counter 100 (integer) 103 127.0.0.1:6379> get counter "103" 127.0.0.1:6379> decr counter (integer) 102 127.0.0.1:6379> get counter "102"
實戰(zhàn)場景
緩存: 經(jīng)典使用場景,把常用信息,字符串,圖片或者視頻等信息放到redis中,redis作為緩存層,mysql做持久化層,降低mysql的讀寫壓力。
計數(shù)器:redis是單線程模型,一個命令執(zhí)行完才會執(zhí)行下一個,同時數(shù)據(jù)可以一步落地到其他的數(shù)據(jù)源。
session:常見方案spring session + redis實現(xiàn)session共享,
Redis中的List其實就是鏈表(Redis用雙端鏈表實現(xiàn)List)。
使用List結(jié)構(gòu),我們可以輕松地實現(xiàn)最新消息排隊功能(比如新浪微博的TimeLine)。List的另一個應用就是消息隊列,可以利用List的 PUSH 操作,將任務存放在List中,然后工作線程再用 POP 操作將任務取出進行執(zhí)行。
圖例
命令使用
命令 | 簡述 | 使用 |
---|---|---|
RPUSH | 將給定值推入到列表右端 | RPUSH key value |
LPUSH | 將給定值推入到列表左端 | LPUSH key value |
RPOP | 從列表的右端彈出一個值,并返回被彈出的值 | RPOP key |
LPOP | 從列表的左端彈出一個值,并返回被彈出的值 | LPOP key |
LRANGE | 獲取列表在給定范圍上的所有值 | LRANGE key 0 -1 |
LINDEX | 通過索引獲取列表中的元素。你也可以使用負數(shù)下標,以 -1 表示列表的最后一個元素, -2 表示列表的倒數(shù)第二個元素,以此類推。 | LINEX key index |
使用列表的技巧
lpush+lpop=Stack(棧)
lpush+rpop=Queue(隊列)
lpush+ltrim=Capped Collection(有限集合)
lpush+brpop=Message Queue(消息隊列)
命令執(zhí)行
127.0.0.1:6379> lpush mylist 1 2 ll ls mem (integer) 5 127.0.0.1:6379> lrange mylist 0 -1 1) "mem" 2) "ls" 3) "ll" 4) "2" 5) "1" 127.0.0.1:6379> lindex mylist -1 "1" 127.0.0.1:6379> lindex mylist 10 # index不在 mylist 的區(qū)間范圍內(nèi) (nil)
實戰(zhàn)場景
微博TimeLine: 有人發(fā)布微博,用lpush加入時間軸,展示新的列表信息。
消息隊列
Redis 的 Set 是 String 類型的無序集合。集合成員是唯一的,這就意味著集合中不能出現(xiàn)重復的數(shù)據(jù)。
Redis 中集合是通過哈希表實現(xiàn)的,所以添加,刪除,查找的復雜度都是 O(1)。
圖例
命令使用
命令 | 簡述 | 使用 |
---|---|---|
SADD | 向集合添加一個或多個成員 | SADD key value |
SCARD | 獲取集合的成員數(shù) | SCARD key |
SMEMBER | 返回集合中的所有成員 | SMEMBER key member |
SISMEMBER | 判斷 member 元素是否是集合 key 的成員 | SISMEMBER key member |
其它一些集合操作,請參考這里https://www.runoob.com/redis/redis-sets.html
命令執(zhí)行
127.0.0.1:6379> sadd myset hao hao1 xiaohao hao (integer) 3 127.0.0.1:6379> smember myset 1) "xiaohao" 2) "hao1" 3) "hao" 127.0.0.1:6379> sismember myset hao (integer) 1
實戰(zhàn)場景
標簽(tag),給用戶添加標簽,或者用戶給消息添加標簽,這樣有同一標簽或者類似標簽的可以給推薦關注的事或者關注的人。
點贊,或點踩,收藏等,可以放到set中實現(xiàn)
Redis hash 是一個 string 類型的 field(字段) 和 value(值) 的映射表,hash 特別適合用于存儲對象。
圖例
命令使用
命令 | 簡述 | 使用 |
---|---|---|
HSET | 添加鍵值對 | HSET hash-key sub-key1 value1 |
HGET | 獲取指定散列鍵的值 | HGET hash-key key1 |
HGETALL | 獲取散列中包含的所有鍵值對 | HGETALL hash-key |
HDEL | 如果給定鍵存在于散列中,那么就移除這個鍵 | HDEL hash-key sub-key1 |
命令執(zhí)行
127.0.0.1:6379> hset user name1 hao (integer) 1 127.0.0.1:6379> hset user email1 hao@163.com (integer) 1 127.0.0.1:6379> hgetall user 1) "name1" 2) "hao" 3) "email1" 4) "hao@163.com" 127.0.0.1:6379> hget user user (nil) 127.0.0.1:6379> hget user name1 "hao" 127.0.0.1:6379> hset user name2 xiaohao (integer) 1 127.0.0.1:6379> hset user email2 xiaohao@163.com (integer) 1 127.0.0.1:6379> hgetall user 1) "name1" 2) "hao" 3) "email1" 4) "hao@163.com" 5) "name2" 6) "xiaohao" 7) "email2" 8) "xiaohao@163.com"
實戰(zhàn)場景
緩存: 能直觀,相比string更節(jié)省空間,的維護緩存信息,如用戶信息,視頻信息等。
Redis 有序集合和集合一樣也是 string 類型元素的集合,且不允許重復的成員。不同的是每個元素都會關聯(lián)一個 double 類型的分數(shù)。redis 正是通過分數(shù)來為集合中的成員進行從小到大的排序。
有序集合的成員是唯一的,但分數(shù)(score)卻可以重復。集合是通過哈希表實現(xiàn)的,所以添加,刪除,查找的復雜度都是 O(1)。
圖例
命令使用
命令 | 簡述 | 使用 |
---|---|---|
ZADD | 將一個帶有給定分值的成員添加到哦有序集合里面 | ZADD zset-key 178 member1 |
ZRANGE | 根據(jù)元素在有序集合中所處的位置,從有序集合中獲取多個元素 | ZRANGE zset-key 0-1 withccores |
ZREM | 如果給定元素成員存在于有序集合中,那么就移除這個元素 | ZREM zset-key member1 |
更多命令請參考這里 https://www.runoob.com/redis/redis-sorted-sets.html
命令執(zhí)行
127.0.0.1:6379> zadd myscoreset 100 hao 90 xiaohao (integer) 2 127.0.0.1:6379> ZRANGE myscoreset 0 -1 1) "xiaohao" 2) "hao" 127.0.0.1:6379> ZSCORE myscoreset hao "100"
實戰(zhàn)場景
排行榜:有序集合經(jīng)典使用場景。例如小說視頻等網(wǎng)站需要對用戶上傳的小說視頻做排行榜,榜單可以按照用戶關注數(shù),更新時間,字數(shù)等打分,做排行。
http://ddrv.cn/a/260579
https://www.cnblogs.com/haoprogrammer/p/11065461.html
https://www.pianshen.com/article/6479421770/
https://www.runoob.com/redis/redis-sorted-sets.html
知識體系
相關文章
首先,我們通過學習Redis的概念基礎,了解它適用的場景。
Redis入門 - Redis概念和基礎
Redis是一種支持key-value等多種數(shù)據(jù)結(jié)構(gòu)的存儲系統(tǒng)??捎糜诰彺?,事件發(fā)布或訂閱,高速隊列等場景。支持網(wǎng)絡,提供字符串,哈希,列表,隊列,集合結(jié)構(gòu)直接存取,基于內(nèi)存,可持久化。
其次,這些適用場景都是基于Redis支持的數(shù)據(jù)類型的,所以我們需要學習它支持的數(shù)據(jù)類型;同時在redis優(yōu)化中還需要對底層數(shù)據(jù)結(jié)構(gòu)了解,所以也需要了解一些底層數(shù)據(jù)結(jié)構(gòu)的設計和實現(xiàn)。
Redis入門 - 數(shù)據(jù)類型:5種基礎數(shù)據(jù)類型詳解
Redis所有的key(鍵)都是字符串。我們在談基礎數(shù)據(jù)結(jié)構(gòu)時,討論的是存儲值的數(shù)據(jù)類型,主要包括常見的5種數(shù)據(jù)類型,分別是:String、List、Set、Zset、Hash
Redis入門 - 數(shù)據(jù)類型:3種特殊類型詳解
Redis除了上文中5種基礎數(shù)據(jù)類型,還有三種特殊的數(shù)據(jù)類型,分別是 HyperLogLogs(基數(shù)統(tǒng)計), Bitmaps (位圖) 和 geospatial (地理位置)
Redis入門 - 數(shù)據(jù)類型:Stream詳解
Redis5.0 中還增加了一個數(shù)據(jù)結(jié)構(gòu)Stream,它借鑒了Kafka的設計,是一個新的強大的支持多播的可持久化的消息隊列。
Redis進階 - 底層數(shù)據(jù)結(jié)構(gòu):對象機制詳解
我們在前文已經(jīng)闡述了Redis 5種基礎數(shù)據(jù)類型詳解,分別是字符串(string)、列表(list)、哈希(hash)、集合(set)、有序集合(zset),以及5.0版本中Redis Stream結(jié)構(gòu)詳解;那么這些基礎類型的底層是如何實現(xiàn)的呢?Redis的每種對象其實都由對象結(jié)構(gòu)(redisObject) 與 對應編碼的數(shù)據(jù)結(jié)構(gòu)組合而成, 本文主要介紹對象結(jié)構(gòu)(redisObject) 部分。。
Redis進階 - 底層數(shù)據(jù)結(jié)構(gòu):底層數(shù)據(jù)結(jié)構(gòu)詳解
前文是第一部分底層設計:對象機制詳解, 本文主要介紹底層數(shù)據(jù)結(jié)構(gòu) 部分。
Redis進階 - 底層數(shù)據(jù)結(jié)構(gòu):redis對象與編碼(底層結(jié)構(gòu))對應關系詳解
在學習完底層數(shù)據(jù)結(jié)構(gòu)之后,我們終于可以結(jié)合前文內(nèi)容闡述redis對象及編碼之間的關系了。
再者,需要學習Redis支持的核心功能,包括持久化,消息,事務,高可用;高可用方面包括,主從,哨兵等;高可拓展方面,比如 分片機制等。
Redis進階 - 持久化:RDB和AOF機制詳解
為了防止數(shù)據(jù)丟失以及服務重啟時能夠恢復數(shù)據(jù),Redis支持數(shù)據(jù)的持久化,主要分為兩種方式,分別是RDB和AOF; 當然實際場景下還會使用這兩種的混合模式。
Redis進階 - 消息傳遞:發(fā)布訂閱模式詳解
Redis 發(fā)布訂閱(pub/sub)是一種消息通信模式:發(fā)送者(pub)發(fā)送消息,訂閱者(sub)接收消息。
Redis進階 - 事件:Redis事件機制詳解
Redis 采用事件驅(qū)動機制來處理大量的網(wǎng)絡IO。它并沒有使用 libevent 或者 libev 這樣的成熟開源方案,而是自己實現(xiàn)一個非常簡潔的事件驅(qū)動庫 ae_event。
Redis進階 - 事務:Redis事務詳解
Redis 事務的本質(zhì)是一組命令的集合。事務支持一次執(zhí)行多個命令,一個事務中所有命令都會被序列化。在事務執(zhí)行過程,會按照順序串行化執(zhí)行隊列中的命令,其他客戶端提交的命令請求不會插入到事務執(zhí)行命令序列中。
Redis進階 - 高可用:主從復制詳解
我們知道要避免單點故障,即保證高可用,便需要冗余(副本)方式提供集群服務。而Redis 提供了主從庫模式,以保證數(shù)據(jù)副本的一致,主從庫之間采用的是讀寫分離的方式。本文主要闡述Redis的主從復制。
Redis進階 - 高可用:哨兵機制(Redis Sentinel)詳解
在上文主從復制的基礎上,如果注節(jié)點出現(xiàn)故障該怎么辦呢? 在 Redis 主從集群中,哨兵機制是實現(xiàn)主從庫自動切換的關鍵機制,它有效地解決了主從復制模式下故障轉(zhuǎn)移的問題。
Redis進階 - 高可拓展:分片技術(Redis Cluster)詳解
前面兩篇文章,主從復制和哨兵機制保障了高可用,就讀寫分離而言雖然slave節(jié)點來擴展主從的讀并發(fā)能力,但是寫能力和存儲能力是無法進行擴展的,就只能是master節(jié)點能夠承載的上限。如果面對海量數(shù)據(jù)那么必然需要構(gòu)建master(主節(jié)點分片)之間的集群,同時必然需要吸收高可用(主從復制和哨兵機制)能力,即每個master分片節(jié)點還需要有slave節(jié)點,這是分布式系統(tǒng)中典型的縱向擴展(集群的分片技術)的體現(xiàn);所以在Redis 3.0版本中對應的設計就是Redis Cluster。
最后,就是具體的實踐以及實踐中遇到的問題和解決方法了:在不同版本中有不同特性,所以還需要了解版本;以及性能優(yōu)化,大廠實踐等。
Redis進階 - 緩存問題:一致性, 穿擊, 穿透, 雪崩, 污染等
Redis最常用的一個場景就是作為緩存,本文主要探討作為緩存,在實踐中可能會有哪些問題?比如一致性, 穿擊, 穿透, 雪崩, 污染等
Redis進階 - 版本特性: Redis4.0、5.0、6.0特性整理
在學習Redis知識體系時,我們難免會需要查看版本實現(xiàn)之間的差異,本文主要整理Redis較為新的版本的特性。
Redis進階 - 運維監(jiān)控:Redis的監(jiān)控詳解
Redis實戰(zhàn)中包含開發(fā),集群 和 運維,Redis用的好不好,如何讓它更好,這是運維要做的;本文主要在 Redis自身狀態(tài)及命令,可視化監(jiān)控工具,以及Redis監(jiān)控體系等方面幫助你構(gòu)建對redis運維/監(jiān)控體系的認知,它是性能優(yōu)化的前提。
Redis進階 - 性能調(diào)優(yōu):Redis性能調(diào)優(yōu)詳解
Redis 的性能問題,涉及到的知識點非常廣,幾乎涵蓋了 CPU、內(nèi)存、網(wǎng)絡、甚至磁盤的方方面面;同時還需要對上文中一些基礎或底層有詳細的了解。針對Redis的性能調(diào)優(yōu),這里整理分享一篇水滴與銀彈(公眾號)的文章,這篇文章可以幫助你構(gòu)筑Redis性能調(diào)優(yōu)的知識體系。
Redis大廠經(jīng)驗 - 微博:萬億級日訪問量下,Redis在微博的9年優(yōu)化歷程
再分享一篇微博使用redis的經(jīng)驗的文章,因為Redis在微博內(nèi)部分布在各個應用場景,比如像現(xiàn)在春晚必爭的“紅包飛”活動,還有像粉絲數(shù)、用戶數(shù)、閱讀數(shù)、轉(zhuǎn)評贊、評論蓋樓、廣告推薦、負反饋、音樂榜單等等都有用到Redis;我們可以通過大廠使用redis的經(jīng)驗來強化對redis使用上的認知。
到此,相信大家對“Redis常見的數(shù)據(jù)類型有哪些”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關內(nèi)容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。