標籤:
Redis是一個開源,先進的key-value儲存,並用於構建高效能,可擴充的Web應用程式的完美解決方案。
Redis從它的許多競爭繼承來的三個主要特點:
Redis 優勢
異常快速:Redis的速度非常快,每秒能執行約11萬集合,每秒約81000+條記錄。
支援豐富的資料類型:Redis支援最大多數開發人員已經知道像列表,集合,有序集合,散列資料類型。這使得它非常容易解決各種各樣的問題,因為我們知道哪些問題是可以處理通過它的資料類型更好。
操作都是原子性:所有Redis操作是原子的,這保證了如果兩個用戶端同時訪問的Redis伺服器將獲得更新後的值。
多功能工具 + 生產力:Redis是一個多實用的工具,可以在多個用例如緩衝,訊息,隊列使用(Redis原生支援發布/訂閱),任何短暫的資料,應用程式,如Web應用程式工作階段,網頁命中計數等。
Redis - 環境
Ubuntu上安裝Redis,開啟終端,然後鍵入以下命令:
$sudo apt-get update$sudo apt-get install redis-server
這將在您的電腦上安裝Redis。
啟動 Redis
$redis-server
檢查Redis是否在工作?
$redis-cli
這將開啟一個Redis提示,如所示:
redis 127.0.0.1:6379>
上面的提示127.0.0.1是原生IP地址,6379為Redis伺服器啟動並執行連接埠。現在輸入PING命令,如所示。
redis 127.0.0.1:6379> pingPONG
這說明你已經成功地安裝Redis在您的機器上。
在Ubuntu上安裝Redis的案頭管理器
在Ubuntu上安裝Redis的案頭管理器,只需從 http://redisdesktop.com/download 開啟下載軟體包並安裝它。
Redis案頭管理器會給你使用者介面來管理Redis的Key和資料。
Redis - 資料類型
Redis支援5種類型的資料類型,它描述如下的:
字串
Redis字串是位元組序列。Redis字串是二進位安全的,這意味著他們有一個已知的長度沒有任何特殊字元終止,所以你可以儲存任何東西,512兆為上限。
例子
redis 127.0.0.1:6379> SET name "yiibai"OKredis 127.0.0.1:6379> GET name"yiibai"
上面是Redis的set和get命令的例子,Redis名稱為yiibai使用的key儲存在Redis的字串值。
雜湊
Redis的雜湊是索引值對的集合。 Redis的雜湊值是字串欄位和字串值之間的映射,因此它們被用來表示對象
例子
redis 127.0.0.1:6379> HMSET user:1 username yiibai password yiibai points 200OKredis 127.0.0.1:6379> HGETALL user:11) "username"2) "yiibai"3) "password"4) "yiibai"5) "points"6) "200"
在上面的例子中的雜湊資料類型,用於儲存其中包含的使用者的基本資料使用者的對象。這裡HMSET,HEGTALL使用者命令user:1是鍵。
列表
Redis的列表是簡單的字串列表,排序插入順序。您可以添加元素到Redis的列表的頭部或尾部。
例子
redis 127.0.0.1:6379> lpush tutoriallist redis(integer) 1redis 127.0.0.1:6379> lpush tutoriallist mongodb(integer) 2redis 127.0.0.1:6379> lpush tutoriallist rabitmq(integer) 3redis 127.0.0.1:6379> lrange tutoriallist 0 101) "rabitmq"2) "mongodb"3) "redis"
列表的最大長度為 232 - 1 元素(4294967295,每個列表中可容納超過4十億的元素)。
集合
Redis的集合是字串的無序集合。在Redis您可以添加,刪除和測試檔案是否存在,在成員O(1)的時間複雜度。
例子
redis 127.0.0.1:6379> sadd tutoriallist redis(integer) 1redis 127.0.0.1:6379> sadd tutoriallist mongodb(integer) 1redis 127.0.0.1:6379> sadd tutoriallist rabitmq(integer) 1redis 127.0.0.1:6379> sadd tutoriallist rabitmq(integer) 0redis 127.0.0.1:6379> smembers tutoriallist1) "rabitmq"2) "mongodb"3) "redis"
注意:在上面的例子中rabitmq集合添加加兩次,但由於集合元素具有唯一屬性。
集合中的元素最大數量為 232 - 1 (4294967295,可容納超過4十億元素)。
有序集合
Redis的有序集合類似於Redis的集合,字串不重複的集合。不同的是,一個有序集合的每個成員用分數,以便採取有序set命令,從最小的到最大的成員分數有關。雖然成員具有唯一性,但分數可能會重複。
例子
redis 127.0.0.1:6379> zadd tutoriallist 0 redis(integer) 1redis 127.0.0.1:6379> zadd tutoriallist 0 mongodb(integer) 1redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq(integer) 1redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq(integer) 0redis 127.0.0.1:6379> ZRANGEBYSCORE tutoriallist 0 10001) "redis"2) "mongodb"3) "rabitmq"
Redis - keys
Redis keys命令用於在Redis的管理鍵。Redis keys命令使用文法如下所示:
文法
redis 127.0.0.1:6379> COMMAND KEY_NAME
例子
redis 127.0.0.1:6379> SET yiibai redisOKredis 127.0.0.1:6379> DEL yiibai(integer) 1
在上面的例子中DEL是命令,而yiibai是key。如果key被刪除,那麼輸出該命令將是(整數)1,否則它會是(整數)0
Redis - Strings
Redis strings命令用於在Redis的管理字串值。Redis strings命令的使用文法,如下所示:
文法
redis 127.0.0.1:6379> COMMAND KEY_NAME
例子
redis 127.0.0.1:6379> SET yiibai redisOKredis 127.0.0.1:6379> GET yiibai"redis"
在上面的例子SET和GET是命令,而yiibai是key。
Redis - 雜湊
Redis的雜湊值是字串欄位和字串值之間的映射,所以他們是代表對象的完美資料類型
在Redis的雜湊值,最多可儲存超過400十億欄位 - 值對。
例子
redis 127.0.0.1:6379> HMSET yiibai name "redis tutorial" description "redis basic commands for caching" likes 20 visitors 23000OKredis 127.0.0.1:6379> HGETALL yiibai1) "name"2) "redis tutorial"3) "description"4) "redis basic commands for caching"5) "likes"6) "20"7) "visitors"8) "23000"
在上面的例子中,已經在雜湊命名yiibai的Redis集合名為tutorials(name, description, likes, visitors)
Redis - 列表
Redis的列表是簡單的字串列表,排序插入順序。您可以添加Redis元素在列表頭部或列表的尾部。
列表的最大長度為 232 - 1 個元素(每個列表元素個數超過4294967295)。
例子
redis 127.0.0.1:6379> LPUSH tutorials redis(integer) 1redis 127.0.0.1:6379> LPUSH tutorials mongodb(integer) 2redis 127.0.0.1:6379> LPUSH tutorials mysql(integer) 3redis 127.0.0.1:6379> LRANGE tutorials 0 101) "mysql"2) "mongodb"3) "redis"
在上述例子中的三個值被插入在redis列表名為LPUSH的命令教程。
Redis - 集合
Redis的集合是唯一的字串的無序集合。集合的唯一性不允許資料的重複的鍵。
在Redis的集合添加,刪除和測試檔案是否存在成員在O(1)(常數時間不管裡麵包含的元素集合的數量)。集合的最大長度為 232 - 1 個元素(每集合超過4294967295元素)。
例子
redis 127.0.0.1:6379> SADD tutorials redis(integer) 1redis 127.0.0.1:6379> SADD tutorials mongodb(integer) 1redis 127.0.0.1:6379> SADD tutorials mysql(integer) 1redis 127.0.0.1:6379> SADD tutorials mysql(integer) 0redis 127.0.0.1:6379> SMEMBERS tutorials1) "mysql"2) "mongodb"3) "redis"
在上述例子中的三個值被命令SADD插入redis的集合名稱tutorials。
Redis有序集
Redis的有序集合類似Redis的集合儲存在設定值具有唯一性。不同的是,一個有序集合的每個成員用分數,以便採取有序set命令,從最小的到最大的分數有關。
在Redis的有序set添加,刪除和測試存在成員O(1)(固定時間,無論裡麵包含集合元素的數量)。列表的最大長度為 232 - 1 個元素(每集合超過4294967295元素)。
例子
redis 127.0.0.1:6379> ZADD tutorials 1 redis(integer) 1redis 127.0.0.1:6379> ZADD tutorials 2 mongodb(integer) 1redis 127.0.0.1:6379> ZADD tutorials 3 mysql(integer) 1redis 127.0.0.1:6379> ZADD tutorials 3 mysql(integer) 0redis 127.0.0.1:6379> ZADD tutorials 4 mysql(integer) 0redis 127.0.0.1:6379> ZRANGE tutorials 0 10 WITHSCORES1) "redis"2) "1"3) "mongodb"4) "2"5) "mysql"6) "4"
在上述例子中的三個值被命令ZADD插入其得分在redis的有序集命名為tutorials。
Redis - HyperLogLog
Redis的HyperLogLog使用隨機化,以提供唯一的元素數目近似的集合只使用一個常數,並且體積小,少量記憶體的演算法。
HyperLogLog提供,即使每個使用了非常少量的記憶體(12KB),標準誤差為集合的基數非常近似,沒有限制的條目數,可以指定,除非接近 264個條目。
例子
下面的樣本說明Redis的HyperLogLog工作原理:
redis 127.0.0.1:6379> PFADD tutorials "redis"1) (integer) 1redis 127.0.0.1:6379> PFADD tutorials "mongodb"1) (integer) 1redis 127.0.0.1:6379> PFADD tutorials "mysql"1) (integer) 1redis 127.0.0.1:6379> PFCOUNT tutorials(integer) 3
Redis - 訂閱
Redis的訂閱實現了郵件系統,寄件者(在Redis的術語中被稱為發行者)發送的郵件,而接收器(使用者)接收它們。由該訊息傳送的鏈路被稱為通道。
在Redis用戶端可以訂閱任何數目的通道。
樣本
以下舉例說明如何發布使用者的概念工作。在下面的例子給出一個客訂閱一個通道名為redisChat
redis 127.0.0.1:6379> SUBSCRIBE redisChatReading messages... (press Ctrl-C to quit)1) "subscribe"2) "redisChat"3) (integer) 1
現在,兩個用戶端都發布在同一個命名通道redisChat訊息,並且以上訂閱用戶端接收訊息。
redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"(integer) 1redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by tutorials point"(integer) 11) "message"2) "redisChat"3) "Redis is a great caching technique"1) "message"2) "redisChat"3) "Learn redis by tutorials point"
Redis - 事務
Redis事務讓一組命令在單個步驟執行。事務中有兩個屬性,說明如下:
例子
Redis的事務由指令多重發起,然後需要傳遞在事務,而且整個事務是通過執行命令EXEC執行命令列表。
redis 127.0.0.1:6379> MULTIOKList of commands hereredis 127.0.0.1:6379> EXEC
例子
以下舉例說明Redis事務如何啟動並執行。
redis 127.0.0.1:6379> MULTIOKredis 127.0.0.1:6379> SET tutorial redisQUEUEDredis 127.0.0.1:6379> GET tutorialQUEUEDredis 127.0.0.1:6379> INCR visitorsQUEUEDredis 127.0.0.1:6379> EXEC1) OK2) "redis"3) (integer) 1
Redis - 指令碼
Redis指令碼使用Lua解釋指令碼用於評估計算。它內建的Redis,從2.6.0版本開始使用指令碼命令 eval。
文法
eval命令的基本文法如下:
redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]
例子
以下舉例說明Redis指令碼的工作原理:
redis 127.0.0.1:6379> EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second1) "key1"2) "key2"3) "first"4) "second"
Redis - 串連
Redis的串連命令基本上都是用於管理與Redis的伺服器用戶端串連。
Example
下面的例子說明了一個客戶如何通過Redis伺服器驗證自己,並檢查伺服器是否正在運行。
redis 127.0.0.1:6379> AUTH "password"OKredis 127.0.0.1:6379> PINGPONG
Redis - 備份
Redis SAVE命令用來建立當前的 Redis Database Backup。
文法
對Redis SAVE命令的基本文法如下所示:
127.0.0.1:6379> SAVE
例子
下面的樣本顯示了 Redis 當前資料庫如何建立備份。
127.0.0.1:6379> SAVEOK
這個命令將建立dump.rdb檔案在Redis目錄中。
還原Redis資料
要恢複Redis的資料只需移動 Redis 的備份檔案(dump.rdb)到 Redis 目錄,然後啟動伺服器。為了得到你的 Redis 目錄,使用配置命令如下所示:
127.0.0.1:6379> CONFIG get dir1) "dir"2) "/user/yiibai/redis-2.8.13/src"
在上述命令的輸出在 /user/yiibai/redis-2.8.13/src 目錄,在安裝redis的伺服器安裝位置。
Bgsave
要建立Redis的備份備用命令BGSAVE也可以。這個命令將開始執行備份過程,並在後台運行。
例子
127.0.0.1:6379> BGSAVEBackground saving started
Redis - 安全
可以Redis的資料庫更安全,所以相關的任何用戶端都需要在執行命令之前進行身分識別驗證。用戶端輸入密碼匹配需要使用Redis設定在設定檔中的密碼。
例子
下面給出的例子顯示的步驟,以確保您的Redis執行個體安全。
127.0.0.1:6379> CONFIG get requirepass1) "requirepass"2) ""
預設情況下,此屬性為空白,表示沒有設定密碼,此執行個體。您可以通過執行以下命令來更改這個屬性
127.0.0.1:6379> CONFIG set requirepass "yiibai"OK127.0.0.1:6379> CONFIG get requirepass1) "requirepass"2) "yiibai"
設定密碼,如果用戶端運行命令沒有驗證,會提示(錯誤)NOAUTH,需要通過驗證。錯誤將返回用戶端。因此,用戶端需要使用AUTHcommand進行認證。
文法
AUTH命令的基本文法如下所示:
127.0.0.1:6379> AUTH password
Redis - 基準
Redis基準是公用工具同時運行Ñ命令檢查Redis的效能。
文法
redis的基準的基本文法如下所示:
redis-benchmark [option] [option value]
例子
下面給出的例子檢查redis調用100000命令。
redis-benchmark -n 100000PING_INLINE: 141043.72 requests per secondPING_BULK: 142857.14 requests per secondSET: 141442.72 requests per secondGET: 145348.83 requests per secondINCR: 137362.64 requests per secondLPUSH: 145348.83 requests per secondLPOP: 146198.83 requests per secondSADD: 146198.83 requests per secondSPOP: 149253.73 requests per secondLPUSH (needed to benchmark LRANGE): 148588.42 requests per secondLRANGE_100 (first 100 elements): 58411.21 requests per secondLRANGE_300 (first 300 elements): 21195.42 requests per secondLRANGE_500 (first 450 elements): 14539.11 requests per secondLRANGE_600 (first 600 elements): 10504.20 requests per secondMSET (10 keys): 93283.58 requests per second
Redis - 用戶端串連
Redis接受配置監聽TCP連接埠和Unix通訊端用戶端的串連,如果啟用。當一個新的用戶端串連被接受以下操作進行:
用戶端通訊端置於非阻塞狀態,因為Redis使用複用和非阻塞I/O操作。
TCP_NODELAY選項設定是為了確保我們沒有在串連時延遲。
建立一個可讀的檔案時,這樣Redis能夠儘快收集用戶端的查詢作為新的資料可供讀取的通訊端。
用戶端的最大數量
在Redis的配置(redis.conf)屬性調用maxclients,它描述用戶端可以串連到Redis的最大數量。命令的基本文法是:
config get maxclients1) "maxclients"2) "10000"
預設情況下,此屬性設定為10000(這取決於作業系統的檔案描述符限制最大數量),但你可以改變這個屬性。
例子
在下面給出的例子中,在啟動伺服器我們設定用戶端的最大數量為10萬。
redis-server --maxclients 100000
Redis - 管道傳輸
Redis是一個TCP伺服器,並支援要求/響應協議。在redis一個請求完成下面的步驟:
管道傳輸的含義
管道的基本含義是,用戶端可以發送多個請求給伺服器,而無需等待回覆所有,並最後讀取在單個步驟中的回覆。
例子
要檢查redis的管道,只要啟動Redis執行個體,然後在終端鍵入以下命令。
$(echo -en "PING\r\n SET tutorial redis\r\nGET tutorial\r\nINCR visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379+PONG+OKredis:1:2:3
在上述例子中,我們必須使用PING命令檢查Redis的串連,之後,我們已經設定值的Redis字串命名tutorial ,之後拿到key的值和增量訪問量的三倍。在結果中,我們可以檢查所有的命令都一次提交給Redis,Redis是在一個步驟給出所有命令的輸出。
管道的好處
這種技術的好處是極大地改善協議的效能。通過管道將慢互連網連線速度從5倍的連線速度提高到localhost至少達到百過倍。
Redis - 分區
分區是一種將資料分成多個Redis的情況下,讓每一個執行個體將只包含你的鍵字的子集的過程。
分區的好處
分區的缺點
通常不支援涉及多個鍵的操作。例如,不能兩個集合之間執行交叉點,因為它們儲存在被映射到不同Redis執行個體中的鍵。
涉及多個鍵的Redis事務不能被使用。
分區粒度是關鍵,所以它是不可能分區資料集用一個碩大的鍵是一個非常大的有序集合。
當分區時,資料處理比較複雜,比如要處理多個RDB/AOF檔案,使資料備份需要從多個執行個體和主機聚集持久性檔案。
添加和刪除的能力可能很複雜。比如Redis的叢集支援有添加,並在運行時刪除節點不支援此功能的能力,但其他系統,如用戶端的分區和代理的資料大多是透明的重新平衡。但是有一個叫Presharding技術有助於在這方面。
分區的類型
redis的提供有兩種類型的分區。假設我們有四個Redis執行個體R0,R1,R2,R3和代表使用者很多鍵如:user:1, user:2, ... 等等
定界分割
定界分割被映射對象轉化為具體的Redis執行個體的範圍內實現。假定在本例中使用者ID0?ID10000將進入執行個體R0,而使用者形成ID10001至20000號將進入執行個體R1等等。
散列分區
在這種類型的分區,一個散列函數(例如,模數函數)被用於轉換鍵成數字,然後資料被儲存在不同redis的執行個體。
Redis快速入門