什么是redis
Redis 是完全開源的览妖,遵守 BSD 協(xié)議,是一個(gè)高性能的 key-value 數(shù)據(jù)庫挥下。
Redis 與其他 key - value 緩存產(chǎn)品有以下三個(gè)特點(diǎn):
- Redis支持?jǐn)?shù)據(jù)的持久化揍魂,可以將內(nèi)存中的數(shù)據(jù)保存在磁盤中,重啟的時(shí)候可以再次加載進(jìn)行使用棚瘟。
- Redis不僅僅支持簡單的key-value類型的數(shù)據(jù)愉烙,同時(shí)還提供list,set解取,zset步责,hash等數(shù)據(jù)結(jié)構(gòu)的存儲(chǔ)。
- Redis支持?jǐn)?shù)據(jù)的備份禀苦,即master-slave模式的數(shù)據(jù)備份蔓肯。
redis的優(yōu)點(diǎn)
- 性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 。
- 豐富的數(shù)據(jù)類型 – Redis支持二進(jìn)制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數(shù)據(jù)類型操作振乏。
- 原子 – Redis的所有操作都是原子性的蔗包,意思就是要么成功執(zhí)行要么失敗完全不執(zhí)行。單個(gè)操作是原子性的慧邮。多個(gè)操作也支持事務(wù)调限,即原子性舟陆,通過MULTI和EXEC指令包起來。
- 豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過期等等特性耻矮。
如何使用redis
- redis使用前先安裝秦躯,Mac可以使用brew install redis直接安裝(pre-condtion:安裝過Homebrew)
- 啟動(dòng)redis:redis-server
- 連接客戶端:redis-cli(需要啟動(dòng)一個(gè)新的cmd/terminal窗口,不要關(guān)閉上一個(gè)啟動(dòng)了server的窗口)
- 關(guān)閉redis:pkill redis-server
- 關(guān)閉客戶端:redis-cli shutdown
redis的配置
- 查看配置項(xiàng):CONFIG GET * -->獲得所有配置項(xiàng)裆装,如果將*號(hào)改為配置項(xiàng)名稱踱承,就可以查指定配置項(xiàng)的值,例如CONFIG GET loglevel
- 設(shè)置配置項(xiàng):CONFIG SET {CONFIG_SETTING_NAME} {NEW_CONFIG_VALUE}
- 各種配置項(xiàng)的的說明:Redis配置項(xiàng)參數(shù)說明
redis存儲(chǔ)鍵值對(duì)
數(shù)據(jù)類型:string哨免,hash茎活,list,set琢唾,zset(有序集合)
String 字符串
最基本的數(shù)據(jù)類型载荔,一個(gè)鍵最大存貯512MB
- 添加鍵值對(duì):SET {Key} {Value}, 例如SET runoob "Hello"
- 獲取指定鍵對(duì)值:GET {Key}
- 刪除用過的key:DEL {Key}
Hash 哈希
hash是鍵值對(duì)的集合,Redis hash 是一個(gè) string 類型的 field 和 value 的映射表采桃,hash 特別適合用于存儲(chǔ)對(duì)象身辨。每個(gè) hash 可以存儲(chǔ) 2的32次方-1個(gè)鍵值對(duì)(40多億)
- 創(chuàng)建Hash類型的key: HMSET {Key} {字段1} {Value1} {字段2} {Value2}
例如HMSET runoob1 field1 "value1" field2 "value2" - 打印Hash的鍵里的指定字段的值:HGET {Key} {field_name}
例如HGET runoob1 field1
List 列表 (String的有序集合)
list是簡單的字符串列表,按照插入順序排列排序芍碧,可以添加一個(gè)元素到頭部或者尾部煌珊。列表最多可以存儲(chǔ)2的32次方-1個(gè)元素(40多億)
redis 127.0.0.1:6379> DEL runoob
redis 127.0.0.1:6379> lpush runoob redis
(integer) 1 此處是返回的索引號(hào)碼
redis 127.0.0.1:6379> lpush runoob mongodb
(integer) 2
redis 127.0.0.1:6379> lpush runoob rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange runoob 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"
Set(String的無序集合)
Redis 的 Set 是 string 類型的無序集合。
集合是通過哈希表實(shí)現(xiàn)的泌豆,所以添加定庵,刪除,查找的復(fù)雜度都是 O(1)踪危。
- 添加一個(gè)元素到set中:sadd {key} {member}
redis 127.0.0.1:6379> DEL runoob
redis 127.0.0.1:6379> sadd runoob redis
(integer) 1 返回1代表添加成功
redis 127.0.0.1:6379> sadd runoob mongodb
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers runoob
1) "redis"
2) "rabitmq"
3) "mongodb"
注意:以上實(shí)例中 rabitmq 添加了兩次蔬浙,但根據(jù)集合內(nèi)元素的唯一性,第二次插入的元素將被忽略贞远。
集合中最大的成員數(shù)為 232 - 1(4294967295, 每個(gè)集合可存儲(chǔ)40多億個(gè)成員)畴博。
zset 有序集合
Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復(fù)的成員。
不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)double類型的分?jǐn)?shù)蓝仲。redis正是通過分?jǐn)?shù)來為集合中的成員進(jìn)行從小到大的排序俱病。
zset的成員是唯一的,但分?jǐn)?shù)(score)卻可以重復(fù)。
- 添加元素: zadd key score member
redis 127.0.0.1:6379> zadd runoob 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE runoob 0 1000
1) "mongodb"
2) "rabitmq"
3) "redis"