亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

Redis中5種數據結構的使用場景

發布時間:2020-08-27 10:29:36 來源:億速云 閱讀:158 作者:小新 欄目:關系型數據庫

這篇文章給大家分享的是有關Redis中5種數據結構的使用場景的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

一、redis 數據結構使用場景

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

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

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

1.String——字符串

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

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

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

       

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

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

       

1.微博 TimeLine
2.消息隊列

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

       

1.共同好友、二度好友
2.利用唯一性,可以統計訪問網站的所有獨立 IP
3.好友推薦的時候,根據 tag 求交集,大于某個 threshold 就可以推薦

1.Sorted Set——有序集合

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

1.帶有權重的元素,比如一個游戲的用戶得分排行榜
2.比較復雜的數據結構,一般用到的場景不算太多

二、redis 其他功能使用場景

1.訂閱-發布系統

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

1.事務——Transactions

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

感謝各位的閱讀!關于Redis中5種數據結構的使用場景就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

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

AI

嘉禾县| 林口县| 汉川市| 乃东县| 苍南县| 汾西县| 饶河县| 峨边| 荥阳市| 迁西县| 从江县| 多伦县| 昭通市| 饶河县| 英德市| 泾阳县| 怀来县| 右玉县| 铅山县| 庐江县| 襄樊市| 周口市| 宜宾市| 潢川县| 封丘县| 阳高县| 卓资县| 阿合奇县| 柞水县| 巫山县| 蒙城县| 新昌县| 沙田区| 大新县| 榆社县| 南溪县| 克东县| 文昌市| 馆陶县| 丹寨县| 静宁县|