Redis是一個開源,先進的key-value存儲,並用於構建高性能,可擴展的Web應用程序的完美解決方案。 Redis從它的許多競爭繼承來的三個主要特色:mysql
Ubuntu上安裝Redis,打開終端,而後鍵入如下命令:redis
$sudo apt-get update $sudo apt-get install redis-server
這將在您的計算機上安裝Redis。算法
啓動 Redissql
$redis-server
檢查Redis是否在工做?mongodb
$redis-cli
這將打開一個Redis提示,以下圖所示:數據庫
redis 127.0.0.1:6379>
上面的提示127.0.0.1是本機的IP地址,6379爲Redis服務器運行的端口。如今輸入PING命令,以下圖所示。ubuntu
redis 127.0.0.1:6379> ping PONG
這說明你已經成功地安裝Redis在您的機器上。緩存
在Ubuntu上安裝Redis的桌面管理器,只需從 http://redisdesktop.com/download 打開下載軟件包並安裝它。安全
Redis桌面管理器會給你用戶界面來管理Redis的Key和數據。服務器
Redis支持5種類型的數據類型,它描述以下的:
Redis字符串是字節序列。Redis字符串是二進制安全的,這意味着他們有一個已知的長度沒有任何特殊字符終止,因此你能夠存儲任何東西,512兆爲上限。
redis 127.0.0.1:6379> SET name 「yiibai」 OK redis 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 200 OK redis 127.0.0.1:6379> HGETALL user:1 1) 「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) 1 redis 127.0.0.1:6379> lpush tutoriallist mongodb (integer) 2 redis 127.0.0.1:6379> lpush tutoriallist rabitmq (integer) 3 redis 127.0.0.1:6379> lrange tutoriallist 0 10 1) 「rabitmq」 2) 「mongodb」 3) 「redis」 列表的最大長度爲 232 – 1 元素(4294967295,每一個列表中可容納超過4十億的元素)。
Redis的集合是字符串的無序集合。在Redis您能夠添加,刪除和測試文件是否存在,在成員O(1)的時間複雜度。
redis 127.0.0.1:6379> sadd tutoriallist redis (integer) 1 redis 127.0.0.1:6379> sadd tutoriallist mongodb (integer) 1 redis 127.0.0.1:6379> sadd tutoriallist rabitmq (integer) 1 redis 127.0.0.1:6379> sadd tutoriallist rabitmq (integer) 0 redis 127.0.0.1:6379> smembers tutoriallist 1) 「rabitmq」 2) 「mongodb」 3) 「redis」
注意:在上面的例子中rabitmq集合添加加兩次,但因爲集合元素具備惟一屬性。
集合中的元素最大數量爲 232 – 1 (4294967295,可容納超過4十億元素)。
Redis的有序集合相似於Redis的集合,字符串不重複的集合。不一樣的是,一個有序集合的每一個成員用分數,以便採起有序set命令,從最小的到最大的成員分數有關。雖然成員具備惟一性,但分數可能會重複。
redis 127.0.0.1:6379> zadd tutoriallist 0 redis (integer) 1 redis 127.0.0.1:6379> zadd tutoriallist 0 mongodb (integer) 1 redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq (integer) 1 redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq (integer) 0 redis 127.0.0.1:6379> ZRANGEBYSCORE tutoriallist 0 1000 1) 「redis」 2) 「mongodb」 3) 「rabitmq」
Redis keys命令用於在Redis的管理鍵。Redis keys命令使用語法以下所示:
redis 127.0.0.1:6379> COMMAND KEY_NAME
redis 127.0.0.1:6379> SET yiibai redis OK redis 127.0.0.1:6379> DEL yiibai (integer) 1
在上面的例子中DEL是命令,而yiibai是key。若是key被刪除,那麼輸出該命令將是(整數)1,不然它會是(整數)0
Redis strings命令用於在Redis的管理字符串值。Redis strings命令的使用語法,以下所示:
redis 127.0.0.1:6379> COMMAND KEY_NAME
redis 127.0.0.1:6379> SET yiibai redis OK redis 127.0.0.1:6379> GET yiibai 「redis」
在上面的例子SET和GET是命令,而yiibai是key。
Redis的哈希值是字符串字段和字符串值之間的映射,因此他們是表明對象的完美數據類型
在Redis的哈希值,最多可存儲超過400十億字段 – 值對。
redis 127.0.0.1:6379> HMSET yiibai name 「redis tutorial」 description 「redis basic commands for caching」 likes 20 visitors 23000 OK redis 127.0.0.1:6379> HGETALL yiibai 1) 「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元素在列表頭部或列表的尾部。
列表的最大長度爲 232 – 1 個元素(每一個列表元素個數超過4294967295)。
redis 127.0.0.1:6379> LPUSH tutorials redis (integer) 1 redis 127.0.0.1:6379> LPUSH tutorials mongodb (integer) 2 redis 127.0.0.1:6379> LPUSH tutorials mysql (integer) 3 redis 127.0.0.1:6379> LRANGE tutorials 0 10 1) 「mysql」 2) 「mongodb」 3) 「redis」
在上述例子中的三個值被插入在redis列表名爲LPUSH的命令教程。
Redis的集合是惟一的字符串的無序集合。集合的惟一性不容許數據的重複的鍵。
在Redis的集合添加,刪除和測試文件是否存在成員在O(1)(常數時間無論裏面包含的元素集合的數量)。集合的最大長度爲 232 – 1 個元素(每集合超過4294967295元素)。
redis 127.0.0.1:6379> SADD tutorials redis (integer) 1 redis 127.0.0.1:6379> SADD tutorials mongodb (integer) 1 redis 127.0.0.1:6379> SADD tutorials mysql (integer) 1 redis 127.0.0.1:6379> SADD tutorials mysql (integer) 0 redis 127.0.0.1:6379> SMEMBERS tutorials 1) 「mysql」 2) 「mongodb」 3) 「redis」
在上述例子中的三個值被命令SADD插入redis的集合名稱tutorials。
Redis的有序集合相似Redis的集合存儲在設定值具備惟一性。不一樣的是,一個有序集合的每一個成員用分數,以便採起有序set命令,從最小的到最大的分數有關。
在Redis的有序set添加,刪除和測試存在成員O(1)(固定時間,不管裏面包含集合元素的數量)。列表的最大長度爲 232 – 1 個元素(每集合超過4294967295元素)。
redis 127.0.0.1:6379> ZADD tutorials 1 redis (integer) 1 redis 127.0.0.1:6379> ZADD tutorials 2 mongodb (integer) 1 redis 127.0.0.1:6379> ZADD tutorials 3 mysql (integer) 1 redis 127.0.0.1:6379> ZADD tutorials 3 mysql (integer) 0 redis 127.0.0.1:6379> ZADD tutorials 4 mysql (integer) 0 redis 127.0.0.1:6379> ZRANGE tutorials 0 10 WITHSCORES 1) 「redis」 2) 「1」 3) 「mongodb」 4) 「2」 5) 「mysql」 6) 「4」
在上述例子中的三個值被命令ZADD插入其得分在redis的有序集命名爲tutorials。
Redis的HyperLogLog使用隨機化,以提供惟一的元素數目近似的集合只使用一個常數,而且體積小,少許內存的算法。
HyperLogLog提供,即便每一個使用了很是少許的內存(12千字節),標準偏差爲集合的基數很是近似,沒有限制的條目數,能夠指定,除非接近 264個條目。
下面的示例說明Redis的HyperLogLog工做原理:
redis 127.0.0.1:6379> PFADD tutorials 「redis」 1) (integer) 1 redis 127.0.0.1:6379> PFADD tutorials 「mongodb」 1) (integer) 1 redis 127.0.0.1:6379> PFADD tutorials 「mysql」 1) (integer) 1 redis 127.0.0.1:6379> PFCOUNT tutorials (integer) 3
Redis的訂閱實現了郵件系統,發送者(在Redis的術語中被稱爲發佈者)發送的郵件,而接收器(用戶)接收它們。由該消息傳送的鏈路被稱爲通道。
在Redis客戶端能夠訂閱任何數目的通道。
如下舉例說明如何發佈用戶的概念工做。在下面的例子給出一個客戶端訂閱一個通道名爲redisChat
redis 127.0.0.1:6379> SUBSCRIBE redisChat Reading 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) 1 redis 127.0.0.1:6379> PUBLISH redisChat 「Learn redis by tutorials point」 (integer) 1 1) 「message」 2) 「redisChat」 3) 「Redis is a great caching technique」 1) 「message」 2) 「redisChat」 3) 「Learn redis by tutorials point」
Redis事務讓一組命令在單個步驟執行。事務中有兩個屬性,說明以下:
Redis的事務由指令多重發起,而後須要傳遞在事務,並且整個事務是經過執行命令EXEC執行命令列表。
redis 127.0.0.1:6379> MULTI OK List of commands here redis 127.0.0.1:6379> EXEC
如下舉例說明Redis事務如何啓動並執行。
redis 127.0.0.1:6379> MULTI OK redis 127.0.0.1:6379> SET tutorial redis QUEUED redis 127.0.0.1:6379> GET tutorial QUEUED redis 127.0.0.1:6379> INCR visitors QUEUED redis 127.0.0.1:6379> EXEC 1) OK 2) 「redis」 3) (integer) 1
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 second 1) 「key1″ 2) 「key2″ 3) 「first」 4) 「second」
Redis的鏈接命令基本上都是用於管理與Redis的服務器客戶端鏈接。
下面的例子說明了一個客戶如何經過Redis服務器驗證本身,並檢查服務器是否正在運行。
redis 127.0.0.1:6379> AUTH 「password」 OK redis 127.0.0.1:6379> PING PONG
Redis SAVE命令用來建立當前的 Redis 數據庫備份。
對Redis SAVE命令的基本語法以下所示:
127.0.0.1:6379> SAVE
下面的示例顯示了 Redis 當前數據庫如何建立備份。
127.0.0.1:6379> SAVE OK
這個命令將建立dump.rdb文件在Redis目錄中。
要恢復Redis的數據只需移動 Redis 的備份文件(dump.rdb)到 Redis 目錄,而後啓動服務器。爲了獲得你的 Redis 目錄,使用配置命令以下所示:
127.0.0.1:6379> CONFIG get dir 1) 「dir」 2) 「/user/yiibai/redis-2.8.13/src」
在上述命令的輸出在 /user/yiibai/redis-2.8.13/src 目錄,在安裝redis的服務器安裝位置。
要建立Redis的備份備用命令BGSAVE也能夠。這個命令將開始執行備份過程,並在後臺運行。
127.0.0.1:6379> BGSAVE Background saving started
能夠Redis的數據庫更安全,因此相關的任何客戶端都須要在執行命令以前進行身份驗證。客戶端輸入密碼匹配須要使用Redis設置在配置文件中的密碼。
下面給出的例子顯示的步驟,以確保您的Redis實例安全。
127.0.0.1:6379> CONFIG get requirepass 1) 「requirepass」 2) 「」
默認狀況下,此屬性爲空,表示沒有設置密碼,此實例。您能夠經過執行如下命令來更改這個屬性
127.0.0.1:6379> CONFIG set requirepass 「yiibai」 OK 127.0.0.1:6379> CONFIG get requirepass 1) 「requirepass」 2) 「yiibai」
設置密碼,若是客戶端運行命令沒有驗證,會提示(錯誤)NOAUTH,須要經過驗證。錯誤將返回客戶端。所以,客戶端須要使用AUTHcommand進行認證。
AUTH命令的基本語法以下所示:
127.0.0.1:6379> AUTH password
Redis基準是公用工具同時運行Ñ命令檢查Redis的性能。
redis的基準的基本語法以下所示:
redis-benchmark [option] [option value]
下面給出的例子檢查redis調用100000命令。
redis-benchmark -n 100000 PING_INLINE: 141043.72 requests per second PING_BULK: 142857.14 requests per second SET: 141442.72 requests per second GET: 145348.83 requests per second INCR: 137362.64 requests per second LPUSH: 145348.83 requests per second LPOP: 146198.83 requests per second SADD: 146198.83 requests per second SPOP: 149253.73 requests per second LPUSH (needed to benchmark LRANGE): 148588.42 requests per second LRANGE_100 (first 100 elements): 58411.21 requests per second LRANGE_300 (first 300 elements): 21195.42 requests per second LRANGE_500 (first 450 elements): 14539.11 requests per second LRANGE_600 (first 600 elements): 10504.20 requests per second MSET (10 keys): 93283.58 requests per second
Redis接受配置監聽TCP端口和Unix套接字客戶端的鏈接,若是啓用。當一個新的客戶端鏈接被接受如下操做進行:
在Redis的配置(redis.conf)屬性調用maxclients,它描述客戶端能夠鏈接到Redis的最大數量。命令的基本語法是:
config get maxclients 1) 「maxclients」 2) 「10000」
默認狀況下,此屬性設置爲10000(這取決於操做系統的文件描述符限制最大數量),但你能夠改變這個屬性。
在下面給出的例子中,在啓動服務器咱們設置客戶端的最大數量爲10萬。
redis-server –maxclients 100000
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 +OK redis :1 :2 :3
在上述例子中,咱們必須使用PING命令檢查Redis的鏈接,以後,咱們已經設定值的Redis字符串命名tutorial ,以後拿到key的值和增量訪問量的三倍。在結果中,咱們能夠檢查全部的命令都一次提交給Redis,Redis是在一個步驟給出全部命令的輸出。
這種技術的好處是極大地改善協議的性能。經過管道將慢互聯網鏈接速度從5倍的鏈接速度提升到localhost至少達到百過倍。
分區是一種將數據分紅多個Redis的狀況下,讓每個實例將只包含你的鍵字的子集的過程。
redis的提供有兩種類型的分區。假設咱們有四個Redis實例R0,R1,R2,R3和表明用戶不少鍵如:user:1, user:2, … 等等
範圍分區被映射對象轉化爲具體的Redis實例的範圍內實現。假定在本例中用戶ID0〜ID10000將進入實例R0,而用戶造成ID10001至20000號將進入實例R1等等。
在這種類型的分區,一個散列函數(例如,模數函數)被用於轉換鍵成數字,而後數據被存儲在不一樣redis的實例。
PS:若是您想和業內技術大牛交流的話,請加qq羣(521249302)或者關注微信公衆 號(AskHarries),謝謝!