濮阳杆衣贸易有限公司

主頁 > 知識庫 > Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹

Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹

熱門標(biāo)簽:杭州400電話如何申請的 隨州營銷電話機(jī)器人怎么樣 天音通信電話機(jī)器人 江西南昌百應(yīng)電話機(jī)器人 高德地圖標(biāo)注商家在哪 機(jī)器人電話機(jī)創(chuàng)意繪畫 400電話申請?jiān)趺纯?/a> hbuilder地圖標(biāo)注 400電話從哪里申請濱州

一、redis 數(shù)據(jù)結(jié)構(gòu)使用場景

原來看過 redisbook 這本書,對 redis 的基本功能都已經(jīng)熟悉了,從上周開始看 redis 的源碼。目前目標(biāo)是吃透 redis 的數(shù)據(jù)結(jié)構(gòu)。我們都知道,在 redis 中一共有5種數(shù)據(jù)結(jié)構(gòu),那每種數(shù)據(jù)結(jié)構(gòu)的使用場景都是什么呢?

String——字符串
Hash——字典
List——列表
Set——集合
Sorted Set——有序集合

下面我們就來簡單說明一下它們各自的使用場景:

1. String——字符串

String 數(shù)據(jù)結(jié)構(gòu)是簡單的 key-value 類型,value 不僅可以是 String,也可以是數(shù)字(當(dāng)數(shù)字類型用 Long 可以表示的時候encoding 就是整型,其他都存儲在 sdshdr 當(dāng)做字符串)。使用 Strings 類型,可以完全實(shí)現(xiàn)目前 Memcached 的功能,并且效率更高。還可以享受 Redis 的定時持久化(可以選擇 RDB 模式或者 AOF 模式),操作日志及 Replication 等功能。除了提供與 Memcached 一樣的 get、set、incr、decr 等操作外,Redis 還提供了下面一些操作:

復(fù)制代碼 代碼如下:

1.LEN niushuai:O(1)獲取字符串長度
2.APPEND niushuai redis:往字符串 append 內(nèi)容,而且采用智能分配內(nèi)存(每次2倍)
3.設(shè)置和獲取字符串的某一段內(nèi)容
4.設(shè)置及獲取字符串的某一位(bit)
5.批量設(shè)置一系列字符串的內(nèi)容
6.原子計(jì)數(shù)器
7.GETSET 命令的妙用,請于清空舊值的同時設(shè)置一個新值,配合原子計(jì)數(shù)器使用

2. Hash——字典

在 Memcached 中,我們經(jīng)常將一些結(jié)構(gòu)化的信息打包成 hashmap,在客戶端序列化后存儲為一個字符串的值(一般是 JSON 格式),比如用戶的昵稱、年齡、性別、積分等。這時候在需要修改其中某一項(xiàng)時,通常需要將字符串(JSON)取出來,然后進(jìn)行反序列化,修改某一項(xiàng)的值,再序列化成字符串(JSON)存儲回去。簡單修改一個屬性就干這么多事情,消耗必定是很大的,也不適用于一些可能并發(fā)操作的場合(比如兩個并發(fā)的操作都需要修改積分)。而 Redis 的 Hash 結(jié)構(gòu)可以使你像在數(shù)據(jù)庫中 Update 一個屬性一樣只修改某一項(xiàng)屬性值。

復(fù)制代碼 代碼如下:

存儲、讀取、修改用戶屬性

3. List——列表

List 說白了就是鏈表(redis 使用雙端鏈表實(shí)現(xiàn)的 List),相信學(xué)過數(shù)據(jù)結(jié)構(gòu)知識的人都應(yīng)該能理解其結(jié)構(gòu)。使用 List 結(jié)構(gòu),我們可以輕松地實(shí)現(xiàn)最新消息排行等功能(比如新浪微博的 TimeLine )。List 的另一個應(yīng)用就是消息隊(duì)列,可以利用 List 的 *PUSH 操作,將任務(wù)存在 List 中,然后工作線程再用 POP 操作將任務(wù)取出進(jìn)行執(zhí)行。Redis 還提供了操作 List 中某一段元素的 API,你可以直接查詢,刪除 List 中某一段的元素。

復(fù)制代碼 代碼如下:

1.微博 TimeLine
2.消息隊(duì)列

4. Set——集合

Set 就是一個集合,集合的概念就是一堆不重復(fù)值的組合。利用 Redis 提供的 Set 數(shù)據(jù)結(jié)構(gòu),可以存儲一些集合性的數(shù)據(jù)。比如在微博應(yīng)用中,可以將一個用戶所有的關(guān)注人存在一個集合中,將其所有粉絲存在一個集合。因?yàn)?Redis 非常人性化的為集合提供了求交集、并集、差集等操作,那么就可以非常方便的實(shí)現(xiàn)如共同關(guān)注、共同喜好、二度好友等功能,對上面的所有集合操作,你還可以使用不同的命令選擇將結(jié)果返回給客戶端還是存集到一個新的集合中。

1.共同好友、二度好友
2.利用唯一性,可以統(tǒng)計(jì)訪問網(wǎng)站的所有獨(dú)立 IP
3.好友推薦的時候,根據(jù) tag 求交集,大于某個 threshold 就可以推薦

5. Sorted Set——有序集合

和Sets相比,Sorted Sets是將 Set 中的元素增加了一個權(quán)重參數(shù) score,使得集合中的元素能夠按 score 進(jìn)行有序排列,比如一個存儲全班同學(xué)成績的 Sorted Sets,其集合 value 可以是同學(xué)的學(xué)號,而 score 就可以是其考試得分,這樣在數(shù)據(jù)插入集合的時候,就已經(jīng)進(jìn)行了天然的排序。另外還可以用 Sorted Sets 來做帶權(quán)重的隊(duì)列,比如普通消息的 score 為1,重要消息的 score 為2,然后工作線程可以選擇按 score 的倒序來獲取工作任務(wù)。讓重要的任務(wù)優(yōu)先執(zhí)行。

1.帶有權(quán)重的元素,比如一個游戲的用戶得分排行榜
2.比較復(fù)雜的數(shù)據(jù)結(jié)構(gòu),一般用到的場景不算太多

二、redis 其他功能使用場景

1. 訂閱-發(fā)布系統(tǒng)

Pub/Sub 從字面上理解就是發(fā)布(Publish)與訂閱(Subscribe),在 Redis 中,你可以設(shè)定對某一個 key 值進(jìn)行消息發(fā)布及消息訂閱,當(dāng)一個 key 值上進(jìn)行了消息發(fā)布后,所有訂閱它的客戶端都會收到相應(yīng)的消息。這一功能最明顯的用法就是用作實(shí)時消息系統(tǒng),比如普通的即時聊天,群聊等功能。

2. 事務(wù)——Transactions

誰說 NoSQL 都不支持事務(wù),雖然 Redis 的 Transactions 提供的并不是嚴(yán)格的 ACID 的事務(wù)(比如一串用 EXEC 提交執(zhí)行的命令,在執(zhí)行中服務(wù)器宕機(jī),那么會有一部分命令執(zhí)行了,剩下的沒執(zhí)行),但是這個 Transactions 還是提供了基本的命令打包執(zhí)行的功能(在服務(wù)器不出問題的情況下,可以保證一連串的命令是順序在一起執(zhí)行的,中間有會有其它客戶端命令插進(jìn)來執(zhí)行)。Redis 還提供了一個 Watch 功能,你可以對一個 key 進(jìn)行 Watch,然后再執(zhí)行 Transactions,在這過程中,如果這個 Watched 的值進(jìn)行了修改,那么這個 Transactions 會發(fā)現(xiàn)并拒絕執(zhí)行。

您可能感興趣的文章:
  • Redis底層數(shù)據(jù)結(jié)構(gòu)詳解
  • 詳解Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表
  • redis中的數(shù)據(jù)結(jié)構(gòu)和編碼詳解
  • redis內(nèi)部數(shù)據(jù)結(jié)構(gòu)之SDS簡單動態(tài)字符串詳解
  • redis數(shù)據(jù)結(jié)構(gòu)之intset的實(shí)例詳解
  • 詳解redis數(shù)據(jù)結(jié)構(gòu)之sds
  • 詳解redis數(shù)據(jù)結(jié)構(gòu)之壓縮列表
  • Redis底層數(shù)據(jù)結(jié)構(gòu)之dict、ziplist、quicklist詳解

標(biāo)簽:沈陽 招商 石嘴山 保定 鶴崗 常德 昆明 葫蘆島

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹》,本文關(guān)鍵詞  Redis,中,5種,數(shù)據(jù)結(jié)構(gòu),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹》相關(guān)的同類信息!
  • 本頁收集關(guān)于Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    北碚区| 苗栗市| 庆城县| 牟定县| 敖汉旗| 东明县| 古丈县| 巫溪县| 儋州市| 漳州市| 云霄县| 萨迦县| 墨玉县| 古交市| 蒙阴县| 额敏县| 万年县| 固原市| 澄迈县| 营口市| 岳阳市| 徐州市| 辉县市| 阿图什市| 拉萨市| 故城县| 南郑县| 天祝| 余姚市| 安义县| 南京市| 台安县| 红桥区| 彭阳县| 彰化市| 乐至县| 新绛县| 宾川县| 莫力| 阿城市| 新宁县|