久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

一起來聊聊Redis有什么優勢和特點

本篇文章給大家帶來了關于Redis的相關知識,其中主要介紹了關于redis的一些優勢和特點,Redis 是一個開源的使用ANSI C語言編寫、遵守 BSD 協議、支持網絡、可基于內存、分布式存儲數據庫,下面一起來看一下,希望對大家有幫助。

一起來聊聊Redis有什么優勢和特點

推薦學習:Redis視頻教程

什么是redis

Remote DIctionary Server(Redis) 是一個由 Salvatore Sanfilippo 寫的 key-value 存儲系統,是跨平臺的非關系型數據庫。

Redis 是一個開源的使用 ANSI C 語言編寫、遵守 BSD 協議、支持網絡、可基于內存、分布式、可選持久性的鍵值對(Key-Value)存儲數據庫,并提供多種語言的 API。

Redis 通常被稱為數據結構服務器,因為值(value)可以是字符串(String)、哈希(Hash)、列表(list)、集合(sets)和有序集合(sorted sets)等類型。

Redis的特點:

  • 內存數據庫,速度快,也支持數據的持久化,可以將內存中的數據保存在磁盤中,重啟的時候可以再次加載進行使用。
  • Redis不僅僅支持簡單的key-value類型的數據,同時還提供list,set,zset,hash等數據結構的存儲。
  • Redis支持數據的備份,即master-slave模式的數據備份。
  • 支持事務

Redis的優勢:

  • 性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 。
  • 豐富的數據類型 – Redis支持二進制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數據類型操作。
  • 原子 – Redis的所有操作都是原子性的,同時Redis還支持對幾個操作合并后的原子性執行。(事務)
  • 豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過期等等特性。

Redis與其他key-value存儲有什么不同?

  • Redis有著更為復雜的數據結構并且提供對他們的原子性操作,這是一個不同于其他數據庫的進化路徑。Redis的數據類型都是基于基本數據結構的同時對程序員透明,無需進行額外的抽象。
  • Redis運行在內存中但是可以持久化到磁盤,所以在對不同數據集進行高速讀寫時需要權衡內存,因為數據量不能大于硬件內存。在內存數據庫方面的另一個優點是,相比在磁盤上相同的復雜的數據結構,在內存中操作起來非常簡單,這樣Redis可以做很多內部復雜性很強的事情。同時,在磁盤格式方面他們是緊湊的以追加的方式產生的,因為他們并不需要進行隨機訪問。

Memcache與Redis的區別都有哪些

  1. 存儲方式 Memecache把數據全部存在內存之中,斷電后會掛掉,數據不能超過內存大小。 Redis有部份存在硬盤上,redis可以持久化其數據
  2. 數據支持類型 memcached所有的值均是簡單的字符串,redis作為其替代者,支持更為豐富的數據類型 ,提供list,set,zset,hash等數據結構的存儲
  3. 使用底層模型不同 它們之間底層實現方式 以及與客戶端之間通信的應用協議不一樣。 Redis直接自己構建了VM 機制 ,因為一般的系統調用系統函數的話,會浪費一定的時間去移動和請求。
  4. value 值大小不同:Redis 最大可以達到 512M;memcache 只有 1mb。
  5. redis的速度比memcached快很多
  6. Redis支持數據的備份,即master-slave模式的數據備份。

Redis為什么這么快

1、完全基于內存,絕大部分請求是純粹的內存操作,非??焖?。數據存在內存中,類似于HashMap,HashMap的優勢就是查找和操作的時間復雜度都是O(1);

2、數據結構簡單,對數據操作也簡單,Redis中的數據結構是專門進行設計的;

3、采用單線程,避免了不必要的上下文切換和競爭條件,也不存在多進程或者多線程導致的切換而消耗 CPU,不用去考慮各種鎖的問題,不存在加鎖釋放鎖操作,沒有因為可能出現死鎖而導致的性能消耗;

4、使用多路I/O復用模型,非阻塞IO;

5、使用底層模型不同,它們之間底層實現方式以及與客戶端之間通信的應用協議不一樣,Redis直接自己構建了VM 機制 ,因為一般的系統調用系統函數的話,會浪費一定的時間去移動和請求;

6.多路 I/O 復用模型

多路I/O復用模型是利用 select、poll、epoll 可以同時監察多個流的 I/O 事件的能力,在空閑的時候,會把當前線程阻塞掉,當有一個或多個流有 I/O 事件時,就從阻塞態中喚醒,于是程序就會輪詢一遍所有的流(epoll 是只輪詢那些真正發出了事件的流),并且只依次順序的處理就緒的流,這種做法就避免了大量的無用操作。

**這里“多路”指的是多個網絡連接,“復用”指的是復用同一個線程。**采用多路 I/O 復用技術可以讓單個線程高效的處理多個連接請求(盡量減少網絡 IO 的時間消耗),且 Redis 在內存中操作數據的速度非常快,也就是說內存內的操作不會成為影響Redis性能的瓶頸,主要由以上幾點造就了 Redis 具有很高的吞吐量。

那么為什么Redis是單線程的

我們首先要明白,上邊的種種分析,都是為了營造一個Redis很快的氛圍!官方FAQ表示,因為Redis是基于內存的操作,CPU不是Redis的瓶頸,Redis的瓶頸最有可能是機器內存的大小或者網絡帶寬。既然單線程容易實現,而且CPU不會成為瓶頸,那就順理成章地采用單線程的方案了(畢竟采用多線程會有很多麻煩?。?。

Redis 數據類型及命令

一起來聊聊Redis有什么優勢和特點

1.字符串(String)

redis 127.0.0.1:6379> SET rediskey redis OK redis 127.0.0.1:6379> GET rediskey "redis"

2. 哈希(Hash)

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

Redis 中每個 hash 可以存儲 232 – 1 鍵值對(40多億)

3. 列表(List)

Redis列表是簡單的字符串列表,按照插入順序排序。你可以添加一個元素到列表的頭部(左邊)或者尾部(右邊)

一個列表最多可以包含 232 – 1 個元素 (4294967295, 每個列表超過40億個元素)。

redis 127.0.0.1:6379> LPUSH rediskey redis (integer) 1 redis 127.0.0.1:6379> LPUSH rediskey mongodb (integer) 2 redis 127.0.0.1:6379> LPUSH rediskey mysql (integer) 3 redis 127.0.0.1:6379> LRANGE rediskey 0 10  1) "mysql" 2) "mongodb" 3) "redis"

4. 集合(Set)

Redis 的 Set 是 String 類型的無序集合。集合成員是唯一的,這就意味著集合中不能出現重復的數據。

集合對象的編碼可以是 intset 或者 hashtable。

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

集合中最大的成員數為 232 – 1 (4294967295, 每個集合可存儲40多億個成員)。

redis 127.0.0.1:6379> SADD rediskey redis (integer) 1 redis 127.0.0.1:6379> SADD rediskey mongodb (integer) 1 redis 127.0.0.1:6379> SADD rediskey mysql (integer) 1 redis 127.0.0.1:6379> SADD rediskey mysql (integer) 0 redis 127.0.0.1:6379> SMEMBERS rediskey  1) "mysql" 2) "mongodb" 3) "redis"

5. 有序集合(sorted set)

Redis 有序集合和集合一樣也是 string 類型元素的集合,且不允許重復的成員。

不同的是每個元素都會關聯一個 double 類型的分數。redis 正是通過分數來為集合中的成員進行從小到大的排序。

有序集合的成員是唯一的,但分數(score)卻可以重復。

集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是 O(1)。 集合中最大的成員數為 232 – 1 (4294967295, 每個集合可存儲40多億個成員)。

6. HyperLogLog

Redis 在 2.8.9 版本添加了 HyperLogLog 結構。

Redis HyperLogLog 是用來做基數統計的算法,HyperLogLog 的優點是,在輸入元素的數量或者體積非常非常大時,計算基數所需的空間總是固定 的、并且是很小的。

在 Redis 里面,每個 HyperLogLog 鍵只需要花費 12 KB 內存,就可以計算接近 2^64 個不同元素的基 數。這和計算基數時,元素越多耗費內存就越多的集合形成鮮明對比。

但是,因為 HyperLogLog 只會根據輸入元素來計算基數,而不會儲存輸入元素本身,所以 HyperLogLog 不能像集合那樣,返回輸入的各個元素。

什么是基數?

比如數據集 {1, 3, 5, 7, 5, 7, 8}, 那么這個數據集的基數集為 {1, 3, 5 ,7, 8}, 基數(不重復元素)為5。 基數估計就是在誤差可接受的范圍內,快速計算基數。

實例

以下實例演示了 HyperLogLog 的工作過程:

//添加指定元素到 HyperLogLog 中。 redis 127.0.0.1:6379> PFADD rediskey "redis"   1) (integer) 1  redis 127.0.0.1:6379> PFADD rediskey "mongodb"  1) (integer) 1  redis 127.0.0.1:6379> PFADD rediskey "mysql"  1) (integer) 1 //添加指定元素到 HyperLogLog 中。 redis 127.0.0.1:6379> PFCOUNT rediskey  (integer) 3

7. 發布訂閱

Redis 發布訂閱 (pub/sub) 是一種消息通信模式:發送者 (pub) 發送消息,訂閱者 (sub) 接收消息。

Redis 客戶端可以訂閱任意數量的頻道。

下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關系:

一起來聊聊Redis有什么優勢和特點一起來聊聊Redis有什么優勢和特點

實例

以下實例演示了發布訂閱是如何工作的,需要開啟兩個 redis-cli 客戶端。

在我們實例中我們創建了訂閱頻道名為 runoobChat:

第一個 redis-cli 客戶端

redis 127.0.0.1:6379> SUBSCRIBE runoobChat  Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "runoobChat" 3) (integer) 1

現在,我們先重新開啟個 redis 客戶端,然后在同一個頻道 runoobChat 發布兩次消息,訂閱者就能接收到消息。

第二個 redis-cli 客戶端

redis 127.0.0.1:6379> PUBLISH runoobChat "Redis PUBLISH test" (integer) 1  redis 127.0.0.1:6379> PUBLISH runoobChat "Learn redis by runoob.com" (integer) 1  # 訂閱者的客戶端會顯示如下消息  1) "message" 2) "runoobChat" 3) "Redis PUBLISH test"  1) "message" 2) "runoobChat" 3) "Learn redis by runoob.com"

gif 演示如下:

  • 開啟本地 Redis 服務,開啟兩個 redis-cli 客戶端。
  • 第一個 redis-cli 客戶端輸入 SUBSCRIBE runoobChat,意思是訂閱 runoobChat 頻道。
  • 第二個 redis-cli 客戶端輸入 PUBLISH runoobChat “Redis PUBLISH test” 往 runoobChat 頻道發送消息,這個時候在第一個 redis-cli 客戶端就會看到由第二個 redis-cli 客戶端發送的測試消息。

一起來聊聊Redis有什么優勢和特點

8. 事務

Redis 事務可以一次執行多個命令, 并且帶有以下三個重要的保證:

  • 批量操作在發送 EXEC 命令前被放入隊列緩存。
  • 收到 EXEC 命令后進入事務執行,事務中任意命令執行失敗,其余的命令依然被執行。
  • 在事務執行過程,其他客戶端提交的命令請求不會插入到事務執行命令序列中。

一個事務從開始到執行會經歷以下三個階段:

  • 開始事務。
  • 命令入隊。
  • 執行事務。

實例

以下是一個事務的例子, 它先以 MULTI 開始一個事務, 然后將多個命令入隊到事務中, 最后由 EXEC 命令觸發事務, 一并執行事務中的所有命令:

redis 127.0.0.1:6379> MULTI OK  redis 127.0.0.1:6379> SET book-name "Mastering C++ in 21 days" QUEUED  redis 127.0.0.1:6379> GET book-name QUEUED  redis 127.0.0.1:6379> SADD tag "C++" "Programming" "Mastering Series" QUEUED  redis 127.0.0.1:6379> SMEMBERS tag QUEUED  redis 127.0.0.1:6379> EXEC 1) OK 2) "Mastering C++ in 21 days" 3) (integer) 3 4) 1) "Mastering Series"    2) "C++"    3) "Programming"

單個 Redis 命令的執行是原子性的,但 Redis 沒有在事務上增加任何維持原子性的機制,所以 Redis 事務的執行并不是原子性的。

事務可以理解為一個打包的批量執行腳本,但批量指令并非原子化的操作,中間某條指令的失敗不會導致前面已做指令的回滾,也不會造成后續的指令不做。

這是官網上的說明 From redis docs on transactions:

It’s important to note that even when a command fails, all the other commands in the queue are processed – Redis will not stop the processing of commands.

比如:

redis 127.0.0.1:7000> multi OK redis 127.0.0.1:7000> set a aaa QUEUED redis 127.0.0.1:7000> set b bbb QUEUED redis 127.0.0.1:7000> set c ccc QUEUED redis 127.0.0.1:7000> exec 1) OK 2) OK 3) OK

如果在 set b bbb 處失敗,set a 已成功不會回滾,set c 還會繼續執行。

9. 腳本

Redis 腳本使用 Lua 解釋器來執行腳本。 Redis 2.6 版本通過內嵌支持 Lua 環境。執行腳本的常用命令為 EVAL。

redis 127.0.0.1:6379> EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second  1) "key1" 2) "key2" 3) "first" 4) "second"

10 GEO

Redis GEO 主要用于存儲地理位置信息,并對存儲的信息進行操作,該功能在 Redis 3.2 版本新增。

Redis GEO 操作方法有:

  • geoadd:添加地理位置的坐標。
  • geopos:獲取地理位置的坐標。
  • geodist:計算兩個位置之間的距離。
  • georadius:根據用戶給定的經緯度坐標來獲取指定范圍內的地理位置集合。
  • georadiusbymember:根據儲存在位置集合里面的某個地點獲取指定范圍內的地理位置集合。
  • geohash:返回一個或多個位置對象的 geohash 值。
redis> GEOADD Sicily 13.361389 38.115556 "Palermo" 15.087269 37.502669 "Catania" (integer) 2 redis> GEODIST Sicily Palermo Catania "166274.1516" redis> GEORADIUS Sicily 15 37 100 km 1) "Catania" redis> GEORADIUS Sicily 15 37 200 km 1) "Palermo" 2) "Catania" redis>

11 Redis Stream

Redis Stream 是 Redis 5.0 版本新增加的數據結構。

Redis Stream 主要用于消息隊列(MQ,Message Queue),Redis 本身是有一個 Redis 發布訂閱 (pub/sub) 來實現消息隊列的功能,但它有個缺點就是消息無法持久化,如果出現網絡斷開、Redis 宕機等,消息就會被丟棄。

簡單來說發布訂閱 (pub/sub) 可以分發消息,但無法記錄歷史消息。

而 Redis Stream 提供了消息的持久化和主備復制功能,可以讓任何客戶端訪問任何時刻的數據,并且能記住每一個客戶端的訪問位置,還能保證消息不丟失。

Redis Stream 的結構如下所示,它有一個消息鏈表,將所有加入的消息都串起來,每個消息都有一個唯一的 ID 和對應的內容:

一起來聊聊Redis有什么優勢和特點

每個 Stream 都有唯一的名稱,它就是 Redis 的 key,在我們首次使用 xadd 指令追加消息時自動創建。

上圖解析:

  • Consumer Group :消費組,使用 XGROUP CREATE 命令創建,一個消費組有多個消費者(Consumer)。
  • last_delivered_id :游標,每個消費組會有個游標 last_delivered_id,任意一個消費者讀取了消息都會使游標 last_delivered_id 往前移動。
  • pending_ids :消費者(Consumer)的狀態變量,作用是維護消費者的未確認的 id。 pending_ids 記錄了當前已經被客戶端讀取的消息,但是還沒有 ack (Acknowledge character:確認字符)。

Redis 管道技術

Redis是一種基于客戶端-服務端模型以及請求/響應協議的TCP服務。這意味著通常情況下一個請求會遵循以下步驟:

  • 客戶端向服務端發送一個查詢請求,并監聽Socket返回,通常是以阻塞模式,等待服務端響應。
  • 服務端處理命令,并將結果返回給客戶端。

Redis 管道技術

Redis 管道技術可以在服務端未響應時,客戶端可以繼續向服務端發送請求,并最終一次性讀取所有服務端的響應。

推薦學習:Redis視頻教程

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
欧美亚洲人成在线| 91免费精品国偷自产在线在线| 精品一二三区| 高清不卡亚洲| 日韩在线短视频| 自由日本语亚洲人高潮| 免费看欧美美女黄的网站| 日韩一区免费| 成人亚洲精品| 国产99精品| 日本一区中文字幕| 精品国产美女a久久9999| 国产精品久久久久av电视剧| 激情综合在线| 日韩黄色av| 日本午夜精品| 肉色欧美久久久久久久免费看 | 久久久精品五月天| 久久高清免费观看| 欧美日韩一区二区三区四区在线观看 | 最新国产精品视频| 国产日韩精品视频一区二区三区| 久久99国产精品视频| 欧美网站在线| 国产日韩欧美在线播放不卡| 成人羞羞在线观看网站| 深夜日韩欧美| 国产麻豆久久| 欧美在线黄色| 999久久久91| 97久久精品| 亚洲婷婷在线| 久久av资源| 亚洲欧美日韩国产综合精品二区| 国产欧美日韩| 欧美精品激情| 超级白嫩亚洲国产第一| 亚洲精品人人| 99久久精品国产亚洲精品| 青青国产精品| 蜜桃成人av| 91精品国产自产精品男人的天堂| 久久天堂精品| 久久久久黄色| 日韩中文字幕无砖| 欧美日韩国产一区二区三区不卡 | 欧美成人一二区| 午夜在线视频一区二区区别| 久久夜夜操妹子| 国产精品一区二区三区av麻| 欧美美女一区| 午夜久久中文| 国产三级一区| 综合亚洲自拍| 在线日韩视频| 亚洲综合电影| 久久精品国产在热久久| 婷婷综合电影| 蜜臀精品久久久久久蜜臀 | 久久中文字幕一区二区| 日av在线不卡| 欧美福利一区| 日韩免费福利视频| 精品精品99| 国产精品视频一区二区三区四蜜臂| 亚洲综合国产| 国产综合激情| 午夜精品成人av| 福利精品在线| 精品久久亚洲| 久久伊人国产| 国产精品99久久久久久董美香| 亚洲精品九九| 亚洲精品一级二级三级| 欧美va天堂在线| 欧美天堂视频| 91精品国产成人观看| 国产成人精品福利| 精品三级av| 精品一区二区三区四区五区| 国产日韩欧美中文在线| 青草久久视频| 日本欧美一区二区在线观看| 亚洲精品乱码| 日韩va欧美va亚洲va久久| 亚洲精品欧洲| 色8久久久久| 日本亚洲欧美天堂免费| 日本一区二区三区中文字幕| 久久高清免费观看| 蜜桃一区二区三区在线| 亚洲色图国产| 日韩三级精品| 国产欧美在线观看免费| 国产精品欧美在线观看| 欧美国产专区| 成人污污视频| 久久国产免费| 午夜宅男久久久| 中文字幕一区二区三区四区久久| 亚洲欧美日本国产专区一区| 中文字幕亚洲在线观看| 97久久亚洲| 麻豆91小视频| 国产精品久久久久久久免费观看 | 91久久在线| 亚洲免费专区| 国产精品v日韩精品v欧美精品网站 | 欧美日韩精品一区二区三区视频 | 99国产精品久久久久久久| 亚洲一区日韩在线| 亚洲一区二区三区四区电影| 日韩欧乱色一区二区三区在线| 国产精品一区二区精品| 中文一区一区三区高中清不卡免费| 日韩久久一区二区三区| 日韩视频免费| 日韩和欧美一区二区| 久久精品国产精品亚洲毛片| 日韩毛片视频| 久久xxxx精品视频| 日韩超碰人人爽人人做人人添| 国产精品任我爽爆在线播放 | 天堂va欧美ⅴa亚洲va一国产| 91成人精品在线| 国产福利91精品一区二区| 91精品一区二区三区综合| 日韩专区欧美专区| 国产日韩中文在线中文字幕 | 亚洲精品观看| 丁香婷婷久久| 亚洲一区欧美二区| 国产欧美日韩综合一区在线播放| 精品美女在线视频| 黄色日韩精品| 欧美成人精品午夜一区二区| 亚洲小说欧美另类婷婷| 日韩av成人高清| 日韩精品欧美| 国产精品一卡| 国产午夜久久| 韩国一区二区三区视频| 视频在线观看一区二区三区| 卡一卡二国产精品| 视频一区二区中文字幕| 国产成人精品免费视| 男女男精品视频网| 裤袜国产欧美精品一区| 蜜臀av国产精品久久久久 | 精品亚洲二区| 日韩精品一二三四| 超碰在线99| 日韩福利视频导航| 欧美一区二区性| 国产精品qvod| 蜜桃91丨九色丨蝌蚪91桃色| 日本久久黄色| 日韩精品成人| 亚洲性色视频| 国产v日韩v欧美v| 欧美视频一区| 国产精品chinese| 久久精品青草| 国产精品一区二区美女视频免费看| 国产一区日韩一区| 美女视频黄久久| 视频一区二区三区入口| 青青青免费在线视频| 久久国产免费看| 免费视频久久| 日本在线精品| 精品久久久中文字幕| 日韩欧美久久| 欧美一区=区| 久久一区二区三区电影| 欧美1区2区3| 久久免费黄色| 久久一区视频| 欧美一区影院| 日韩中文av| 午夜在线精品| 久久在线免费| 日韩成人综合| 国产一区二区三区国产精品| 国产欧美一区二区三区国产幕精品| 午夜在线一区| 蜜桃tv一区二区三区| 美女av在线免费看| 久久精品九色| 国产精品色在线网站| av亚洲在线观看| 日韩高清不卡| 久久精品xxxxx| 首页国产欧美久久| 午夜av一区| 美女毛片一区二区三区四区| 亚洲精品国产嫩草在线观看 | 欧美亚洲一级| 欧美亚洲自偷自偷| 欧美精品中文|