Redis
REmote DIctionary Server(Redis) 是一個(gè)由Salvatore Sanfilippo寫的key-value存儲(chǔ)系統(tǒng)。
Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫孕豹、遵守BSD協(xié)議鹊碍、支持網(wǎng)絡(luò)击儡、可基于內(nèi)存亦可持久化的日志型袄秩、Key-Value數(shù)據(jù)庫(kù)现柠,并提供多種語(yǔ)言的API苹享。
它通常被稱為數(shù)據(jù)結(jié)構(gòu)服務(wù)器双絮,因?yàn)橹担╲alue)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等類型浴麻。
Redis簡(jiǎn)介
Redis 是完全開(kāi)源免費(fèi)的,遵守BSD協(xié)議囤攀,是一個(gè)高性能的key-value數(shù)據(jù)庫(kù)软免。
Redis 與其他 key - value 緩存產(chǎn)品有以下三個(gè)特點(diǎn):
- Redis支持?jǐn)?shù)據(jù)的持久化,可以將內(nèi)存中的數(shù)據(jù)保存在磁盤中焚挠,重啟的時(shí)候可以再次加載進(jìn)行使用膏萧。
- Redis不僅僅支持簡(jiǎn)單的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)勢(shì)
- 性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 剃允。
- 豐富的數(shù)據(jù)類型 – Redis支持二進(jìn)制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數(shù)據(jù)類型操作沛简。
- 原子 – Redis的所有操作都是原子性的,意思就是要么成功執(zhí)行要么失敗完全不執(zhí)行硅急。單個(gè)操作是原子性的覆享。多個(gè)操作也支持事務(wù),即原子性营袜,通過(guò)MULTI和EXEC指令包起來(lái)撒顿。
- 豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過(guò)期等等特性。
Redis與其他key-value存儲(chǔ)有什么不同荚板?
- Redis有著更為復(fù)雜的數(shù)據(jù)結(jié)構(gòu)并且提供對(duì)他們的原子性操作凤壁,這是一個(gè)不同于其他數(shù)據(jù)庫(kù)的進(jìn)化路徑。Redis的數(shù)據(jù)類型都是基于基本數(shù)據(jù)結(jié)構(gòu)的同時(shí)對(duì)程序員透明跪另,無(wú)需進(jìn)行額外的抽象拧抖。
- Redis運(yùn)行在內(nèi)存中但是可以持久化到磁盤,所以在對(duì)不同數(shù)據(jù)集進(jìn)行高速讀寫時(shí)需要權(quán)衡內(nèi)存免绿,因?yàn)閿?shù)據(jù)量不能大于硬件內(nèi)存唧席。在內(nèi)存數(shù)據(jù)庫(kù)方面的另一個(gè)優(yōu)點(diǎn)是,相比在磁盤上相同的復(fù)雜的數(shù)據(jù)結(jié)構(gòu)嘲驾,在內(nèi)存中操作起來(lái)非常簡(jiǎn)單淌哟,這樣Redis可以做很多內(nèi)部復(fù)雜性很強(qiáng)的事情。同時(shí)辽故,在磁盤格式方面他們是緊湊的以追加的方式產(chǎn)生的徒仓,因?yàn)樗麄儾⒉恍枰M(jìn)行隨機(jī)訪問(wèn)。
Redis數(shù)據(jù)類型
Redis支持五種數(shù)據(jù)類型:string(字符串)誊垢,hash(哈希)掉弛,list(列表)症见,set(集合)及zset(sorted set:有序集合)。
String(字符串)
string是redis最基本的類型殃饿,你可以理解成與Memcached一模一樣的類型谋作,一個(gè)key對(duì)應(yīng)一個(gè)value。
string類型是二進(jìn)制安全的壁晒。意思是redis的string可以包含任何數(shù)據(jù)瓷们。比如jpg圖片或者序列化的對(duì)象 。
string類型是Redis最基本的數(shù)據(jù)類型秒咐,一個(gè)鍵最大能存儲(chǔ)512MB。
實(shí)例
redis 127.0.0.1:6379> SET name "runoob"
OK
redis 127.0.0.1:6379> GET name
"runoob"
在以上實(shí)例中我們使用了 Redis 的 SET 和 GET 命令碘裕。鍵為 name携取,對(duì)應(yīng)的值為 runoob。
注意:一個(gè)鍵最大能存儲(chǔ)512MB帮孔。
Hash(哈希)
Redis hash 是一個(gè)鍵值(key=>value)對(duì)集合雷滋。
Redis hash是一個(gè)string類型的field和value的映射表,hash特別適合用于存儲(chǔ)對(duì)象文兢。
實(shí)例
redis> HMSET myhash field1 "Hello" field2 "World"
"OK"
redis> HGET myhash field1
"Hello"
redis> HGET myhash field2
"World"
以上實(shí)例中 hash 數(shù)據(jù)類型存儲(chǔ)了包含用戶腳本信息的用戶對(duì)象晤斩。 實(shí)例中我們使用了 Redis HMSET, HGETALL 命令,user:1為鍵值姆坚。
每個(gè) hash 可以存儲(chǔ) 232-1 鍵值對(duì)(40多億)澳泵。
List(列表)
Redis 列表是簡(jiǎn)單的字符串列表,按照插入順序排序兼呵。你可以添加一個(gè)元素到列表的頭部(左邊)或者尾部(右邊)兔辅。
實(shí)例
redis 127.0.0.1:6379> lpush runoob redis
(integer) 1
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"
redis 127.0.0.1:6379>
列表最多可存儲(chǔ) 232 - 1 元素 (4294967295, 每個(gè)列表可存儲(chǔ)40多億)。