溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Redis常見的數(shù)據(jù)類型有哪些

發(fā)布時間:2021-10-14 09:31:51 來源:億速云 閱讀:193 作者:iii 欄目:編程語言

本篇內(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)簡介

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。

Redis常見的數(shù)據(jù)類型有哪些

結(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ù)分值范圍或成員來獲取元素

基礎數(shù)據(jù)結(jié)構(gòu)詳解

內(nèi)容其實比較簡單,我覺得理解的重點在于這個結(jié)構(gòu)怎么用,能夠用來做什么?所以我在梳理時,圍繞圖例,命令,執(zhí)行場景來闡述。@pdai

String字符串

String是redis中最基本的數(shù)據(jù)類型,一個key對應一個value。

String類型是二進制安全的,意思是 redis 的 string 可以包含任何數(shù)據(jù)。如數(shù)字,字符串,jpg圖片或者序列化的對象。

  • 圖例

下圖是一個String類型的實例,其中鍵為hello,值為world

Redis常見的數(shù)據(jù)類型有哪些

  • 命令使用

命令簡述使用
GET獲取存儲在給定鍵中的值GET name
SET設置存儲在給定鍵中的值SET name value
DEL刪除存儲在給定鍵中的值DEL name
INCR將鍵存儲的值加1INCR key
DECR將鍵存儲的值減1DECR 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共享,

List列表

Redis中的List其實就是鏈表(Redis用雙端鏈表實現(xiàn)List)。

使用List結(jié)構(gòu),我們可以輕松地實現(xiàn)最新消息排隊功能(比如新浪微博的TimeLine)。List的另一個應用就是消息隊列,可以利用List的 PUSH 操作,將任務存放在List中,然后工作線程再用 POP 操作將任務取出進行執(zhí)行。

  • 圖例

Redis常見的數(shù)據(jù)類型有哪些

  • 命令使用

命令簡述使用
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加入時間軸,展示新的列表信息。

    • 消息隊列

Set集合

Redis 的 Set 是 String 類型的無序集合。集合成員是唯一的,這就意味著集合中不能出現(xiàn)重復的數(shù)據(jù)。

Redis 中集合是通過哈希表實現(xiàn)的,所以添加,刪除,查找的復雜度都是 O(1)。

  • 圖例

Redis常見的數(shù)據(jù)類型有哪些

  • 命令使用

命令簡述使用
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)

Hash散列

Redis hash 是一個 string 類型的 field(字段) 和 value(值) 的映射表,hash 特別適合用于存儲對象。

  • 圖例

Redis常見的數(shù)據(jù)類型有哪些

  • 命令使用

命令簡述使用
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é)省空間,的維護緩存信息,如用戶信息,視頻信息等。

Zset有序集合

Redis 有序集合和集合一樣也是 string 類型元素的集合,且不允許重復的成員。不同的是每個元素都會關聯(lián)一個 double 類型的分數(shù)。redis 正是通過分數(shù)來為集合中的成員進行從小到大的排序。

有序集合的成員是唯一的,但分數(shù)(score)卻可以重復。集合是通過哈希表實現(xiàn)的,所以添加,刪除,查找的復雜度都是 O(1)。

  • 圖例

Redis常見的數(shù)據(jù)類型有哪些

  • 命令使用

命令簡述使用
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常見的數(shù)據(jù)類型有哪些

相關文章

首先,我們通過學習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ù)類型有哪些

  • 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ù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI