久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

Redis有哪些用途及優(yōu)缺點

180次閱讀
沒有評論

共計 1897 個字符,預計需要花費 5 分鐘才能閱讀完成。

自動寫代碼機器人,免費開通

這篇文章主要介紹 Redis 有哪些用途及優(yōu)缺點,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

1、Memcached 和 Redis 相比的劣勢

業(yè)界常用 MySQL+Memcached 這樣的存儲架構,但是隨著訪問量的不斷攀蛇,隨之而來的問題也有很多。

1、MySQL 需要不停的拆庫拆表,Memcached 也需要跟著不斷擴容;

2、Memcached 與 MySQL 之間存在著一定的數(shù)據(jù)不一致的現(xiàn)象;

3、如果 Memcached 容易命中率變低,直接穿透到 MySQL,導致數(shù)據(jù)庫無法支撐;

2、Redis 的特點

說起 Redis,很多開發(fā)者都只知道它和 Memcached 一樣是非關系型數(shù)據(jù)庫,可以直接存儲 K - V 形式的數(shù)據(jù),但是相比起 Memcached 來說,他也有很多不同的地方。

1、Redis 不僅僅只支持簡單的 K - V 形式的數(shù)據(jù)存儲,還支持 list、set、hash、zset 等等集合類數(shù)據(jù)的存儲;

2、Redis 支持實時的數(shù)據(jù)備份,及時宕機,也可以把數(shù)據(jù)恢復過來;

3、Redis 支持數(shù)據(jù)的持久化,可以存放在內(nèi)存 memory 中的數(shù)據(jù)直接保存在磁盤上;

3、Redis 常用的數(shù)據(jù)類型

String、Hash、Set、List、SortedSet、pub/sub、Transactions。

1、String:Strings 就是一個最最簡單的 Key-Value 形式存儲的變量。其中 Value 既可以是數(shù)字也可以是字符串。其實現(xiàn)方式是在 Redis 內(nèi)部默認存儲一個字符串,被 redisObject 引用,當檢測到數(shù)字操作如自增自減 incr、decr 等等命令時,自動轉化為數(shù)字進行計算,計算完畢后再轉化為 String 存儲起來。

2、Hash:Hash 存儲是鍵值對的 value。即 Key-Hash,而 Hash 又是一個 k - v 的結構,如果使用的 Memcached,則需要把整個 Hash 打包存儲在內(nèi)存中,如果需要查詢其中某個值,還要全部取出整個 Hash,再查找對應值。而 Redis 可以直接通過命令獲取到 Value,大大提高了性能。其實現(xiàn)原理:當成員較少時,Redis 為了節(jié)約內(nèi)存會采用類似一維數(shù)組的緊湊存儲,而當對象較多時,則直接轉為 HashMap 存儲。

3、Set:Set 是一個無序的天然去重的集合,即 Key-Set。此外還提供了交集、并集等一系列直接操作集合的方法,對于求共同好友、共同關注什么的功能實現(xiàn)特別方便。其底層是靠 HashMap 實現(xiàn)的,其中 value 為 null;

4、List:List 是一個有序可重復的集合,其遵循 FIFO 的原則,底層是依賴雙向鏈表實現(xiàn)的,因此支持正向、反向雙重查找。通過 List,我們可以很方面的獲得類似于最新回復這類的功能實現(xiàn)。

5、SortedSet:類似于 java 中的 TreeSet,是 Set 的可排序版。此外還支持優(yōu)先級排序,維護了一個 score 的參數(shù)來實現(xiàn)。其底層主要依賴 HashMap 來實現(xiàn)的,通過維持插入的數(shù)值和 Score 優(yōu)先級的映射來進行排序。

6、pub/sub:發(fā)布訂閱,類似于消息隊列 mq。可以選擇對某個 Key 進行訂閱,一旦這個 key 發(fā)布了一些消息,則所有訂閱了這個 Key 的對象就可以收到這個消息。主要可以用在實時消息系統(tǒng)上,例如聊天之類的。

7、Transactions:NoSQL 不支持事務,但是通過提供了打包執(zhí)行的功能,即這個包里面的所有命令必須要一起執(zhí)行,此外還可以鎖定某個 Key,在打包執(zhí)行命令時如果檢測到這個 Key 發(fā)生了變化,則直接回滾。

4、Redis 的常用應用場景

redis 使用內(nèi)存提供存儲,通過持久化功能保存數(shù)據(jù)。且針對 request 是單線程操作。這一系列特點使得 redis 具有十分神奇的功能。

1、查找最新的回復。

如果在傳統(tǒng)的關系型數(shù)據(jù)庫,這就需要使用 select * from table where name= order by time desc limit  100;這十分消耗數(shù)據(jù)庫性能,但是通過 Redis,就可以直接在 Redis 里面通過 Id 創(chuàng)建一個 List,指定長度 1w,當需要查找時,直接輸出該 list 的后 100 條記錄。

2、排行問題

常見的排行問題,例如最熱話題、游戲排名等等,這些都可以通過 Redis 來輕松實現(xiàn),直接使用 ZRank 即可得到。

3、刪除過期數(shù)據(jù)

Redis 不是真正意義上的可持久化數(shù)據(jù)庫,可以給數(shù)據(jù)加上一個有效時間,在有效時間超過時,Redis 會自動刪除對應數(shù)據(jù)。

以上是 Redis 有哪些用途及優(yōu)缺點的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注丸趣 TV 行業(yè)資訊頻道!

向 AI 問一下細節(jié)

丸趣 TV 網(wǎng) – 提供最優(yōu)質(zhì)的資源集合!

正文完
 
丸趣
版權聲明:本站原創(chuàng)文章,由 丸趣 2024-02-03發(fā)表,共計1897字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網(wǎng)絡搜集發(fā)布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 永春县| 佛坪县| 景谷| 阳原县| 屯昌县| 兴化市| 孝昌县| 金川县| 临颍县| 胶州市| 唐山市| 焦作市| 姜堰市| 双流县| 鄂尔多斯市| 大丰市| 丰宁| 安平县| 湖南省| 南郑县| 灵丘县| 定兴县| 广昌县| 当阳市| 阿拉善右旗| 五河县| 蓝山县| 邹平县| 齐河县| 晋州市| 海原县| 礼泉县| 平利县| 永川市| 永城市| 育儿| 通江县| 仙居县| 子洲县| 盘锦市| 德令哈市|