一、前言 Redis是一個開源的使用ANSI C語言編寫、遵守BSD協議、支持網路、可基於記憶體亦可持久化的日誌型、key-Value 的資料庫、並提供多種語言的API。 通常,Redis 將數據存儲於記憶體中,或被配置為使用虛擬記憶體。通過兩種方式可以實現數據持久化:使用截圖的方式,將記憶體中的數據不斷寫 ...
一、前言
Redis是一個開源的使用ANSI C語言編寫、遵守BSD協議、支持網路、可基於記憶體亦可持久化的日誌型、key-Value 的資料庫、並提供多種語言的API。
通常,Redis 將數據存儲於記憶體中,或被配置為使用虛擬記憶體。通過兩種方式可以實現數據持久化:使用截圖的方式,將記憶體中的數據不斷寫入磁碟;或使用類似 MySQL 的日誌方式,記錄每次更新的日誌。前者性能較高,但是可能會引起一定程度的數據丟失;後者相反。
解釋了為什麼選用6379作為預設埠,因為6379在手機按鍵上MERZ對應的號碼,而MERZ取自義大利歌女Alessia Merz的名字。
二、特點
- 支持數據的持久化,可以將記憶體中的數據保存到磁碟中,重啟的時候可以再次載入進行使用。
- 豐富的數據類型存儲:String、list、set、zset、hash。
- 支持數據的備份,即master-slave模式的數據的備份。
- 性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s。
- 所有的操作都是基於原子性的。
三、數據對象
- String
--redis的String可以包含任何數據,比如jpg圖片或者序列後的對象,一個key最大能存儲512MB。
- Hash
--hash 是一個String類型的field 和 value 的映射表,hash 特別適合用於存儲對象。每個hash可以存儲2^32-1鍵值對 。
- list
--Redis 列表是簡單的字元串列表,按照插入的順序可以在列表的頭部(左邊)或者尾部(右邊)添加元素。
- set
--Redis的Set是String類型的無序集合。集合是通過hash表實現的,所以。添加、刪除、查找的複雜度都是O(1)。
- zset
--zset 和 set一樣也是String的類型元素的集合,且不允許重覆的隊員,不同的是每個元素都會關聯一個double類型的score。redis正是通過score來為集合中的成員進行從小到大的排序。分數(score)可以重覆。
添加元素到集合,元素在集合中存在則對應更新相應的score。
四、安裝
1、Window
--服務端
1、window下載地址:https://github.com/MicrosoftArchive/redis/releases
2、打開一個 cmd 視窗 使用cd命令切換目錄 E:\redis 運行 redis-server.exe redis.windows.conf
--客戶端
1、打開一個 cmd 視窗 使用cd命令切換目錄 E:\redis 運行 redis-cli.exe -h 127.0.0.1 -p 6379 -a 'mypass'
2、set myKey abc / get myKey
2、Linux
--服務端
1、 wget http://download.redis.io/releases/redis-2.8.17.tar.gz
2、 tar -zxvf redis-2.8.17.tar.gz redis-2.8.17
3、 cd redis-2.8.17
4、 make
5、 cd src
6、 ./redis-server redis.conf
--客戶端
1、 cd src
2、 ./redis-cli
redis> set foo bar
OK
redis> get foo
"bar"
五、命令
1、String
-- set key value 保存key和value。
-- get key 根據key得到value。
2、Hash
-- hmset myhash key1 val1 key2 val2 存儲hash值
-- hget myhash key1 根據hash中的某個key得到value
-- hgetall myhash 得到hash中的所有值
-- HDEL key field1 [field2] 刪除一個或多個哈希欄位
-- HKEYS key 獲取所有哈希表中的欄位
-- HLEN key 獲取哈希欄位數
3、List
-- lpush key val 向列表左邊插入元素
-- lpop key 從列表左邊移出元素
-- rpush key val 向列表右邊插入元素
-- rpop key 從列表右邊移出元素
-- rpushx key value 為已存在的列表添加值
-- LRANGE key start stop 獲取列表指定範圍內的元素
-- lindex key index 通過索引獲取列表中的元素
4、Set
-- sadd key value 添加元素
-- smembers key 根據key獲得集合中的所有成員
-- scard key 獲取集合的成員數
-- sdiff key1 key2 返回給定所有集合的差集(key2的集合相對於key1集合的差集)
-- sunion 返回給定集合的並集
-- smove source des member 把member從source集合到des集合
-- sdiffstore des key1 key2 返回給定所有集合的差集,並存儲在des中
-- srandmember key count 返回集合中一個或多個隨機數
-- spop key1 移除並返回集合中的一個隨機元素
-- sismember key mem 判斷mem元素是否存在
5、Zset
-- zadd page 0 123
-- zadd page 1 234
-- zrangebyscore page 0 10
6、通用
-- 刪除key:DEL key
-- 查看所有的key:keys *
-- 序列化給定key,並返回被返回的值:DUMP key
-- 檢查給定key是否存在:EXISTS key
-- 為key設置過期時間:EXPIRE key seconds
-- 為key設置過期時間(時間戳):EXPIREAT key timestamp
-- 為key設過期時間(毫秒):PEXPIRE key milliseconds
-- 查找所有符合給定模式的key:KEYS pattern
-- 移除key的過期時間,key將持久保存:persist key
-- 以毫秒為單位返回key的剩餘過期時間:PTTL key
-- 返回key所存儲的值得類型:TYPE key
HyperLogLog:
-- 添加指定元素到HyperLogLog中:PFADD key element
-- 返回給定的HyperLogLog的基數估計值:PFCOUNT key
-- 將多個HyperLogLog 合併為一個HyperLogLog:PFMERGE destkey sourcekey
訂閱命令:
-- 訂閱一個或多個符合給定模式的頻道:psubscribe pattern
-- 退訂一個或多個符合給定模式的頻道:punsubscribe pattern
-- 查看訂閱與發佈系統狀態:pubsub subcommand
-- 將信息發佈到指定的頻道:publish channel message
-- 訂閱給定的一個或多個頻道的信息:subscribe channel
-- 退訂給定的頻道:unsubscribe channel