青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 200, comments - 8, trackbacks - 0, articles - 0

Redis系統性介紹

Posted on 2013-04-05 14:46 鑫龍 閱讀(517) 評論(0)  編輯 收藏 引用 所屬分類: redis

雖然Redis已經很火了,相信還是有很多同學對Redis只是有所聽聞或者了解并不全面,下面是一個比較系統的Redis介紹,對Redis的特性及各種數據類型及操作進行了介紹。是一個很不錯的Redis入門教程。

1.介紹

1.1 Redis是什么

REmote DIctionary Server(Redis) 是一個由Salvatore Sanfilippo寫的key-value存儲系統。Redis提供了一些豐富的數據結構,包括 lists, sets, ordered sets 以及 hashes ,當然還有和Memcached一樣的 strings結構.Redis當然還包括了對這些數據結構的豐富操作。

1.2 Redis的優點

  • 性能極高 – Redis能支持超過 100K+ 每秒的讀寫頻率。
  • 豐富的數據類型 – Redis支持二進制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數據類型操作。
  • 原子 – Redis的所有操作都是原子性的,同時Redis還支持對幾個操作全并后的原子性執行。
  • 豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過期等等特性。

2.數據類型

2.1 String類型

Redis能存儲二進制安全的字符串,最大長度為1GB

redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 
127.0.0.1:6379> GET name
"John Doe"
String類型還支持批量的讀寫操作
redis 127.0.0.1:6379> MSET age 30 sex "male"
OK
redis 
127.0.0.1:6379> MGET age sex
1"30"
2"male"
String類型其實也可以用來存儲數字,并支持對數字的加減操作。
redis 127.0.0.1:6379> INCR age
(integer) 
31
redis 
127.0.0.1:6379> INCRBY age 4
(integer) 
35
redis 
127.0.0.1:6379> GET age
"35"
redis 
127.0.0.1:6379> DECR age
(integer) 
34
redis 
127.0.0.1:6379> DECRBY age 4
(integer) 
30
redis 
127.0.0.1:6379> GET age
"30"
String類型還支持對其部分的修改和獲取操作
redis 127.0.0.1:6379> APPEND name " Mr."
(integer) 
12
redis 
127.0.0.1:6379> GET name
"John Doe Mr."
redis 
127.0.0.1:6379> STRLEN name
(integer) 
12
redis 
127.0.0.1:6379> SUBSTR name 0 3
"John"

2.2 List類型

Redis能夠將數據存儲成一個鏈表,并能對這個鏈表進行豐富的操作

redis 127.0.0.1:6379> LPUSH students "John Doe"
(integer) 
1
redis 
127.0.0.1:6379> LPUSH students "Captain Kirk"
(integer) 
2
redis 
127.0.0.1:6379> LPUSH students "Sheldon Cooper"
(integer) 
3
redis 
127.0.0.1:6379> LLEN students
(integer) 
3
redis 
127.0.0.1:6379> LRANGE students 0 2
1"Sheldon Cooper"
2"Captain Kirk"
3"John Doe"
redis 
127.0.0.1:6379> LPOP students
"Sheldon Cooper"
redis 
127.0.0.1:6379> LLEN students
(integer) 
2
redis 
127.0.0.1:6379> LRANGE students 0 1
1"Captain Kirk"
2"John Doe"
redis 
127.0.0.1:6379> LREM students 1 "John Doe"
(integer) 
1
redis 
127.0.0.1:6379> LLEN students
(integer) 
1
redis 
127.0.0.1:6379> LRANGE students 0 0
1"Captain Kirk"
Redis也支持很多修改操作
redis 127.0.0.1:6379> LINSERT students BEFORE "Captain Kirk" "Dexter Morgan"
(integer) 
3
redis 
127.0.0.1:6379> LRANGE students 0 2
1"Dexter Morgan"
2"Captain Kirk"
3"John Doe"
redis 
127.0.0.1:6379> LPUSH students "Peter Parker"
(integer) 
4
redis 
127.0.0.1:6379> LRANGE students 0 3
1"Peter Parker"
2"Dexter Morgan"
3"Captain Kirk"
4"John Doe"
redis 
127.0.0.1:6379> LTRIM students 1 3
OK
redis 
127.0.0.1:6379> LLEN students
(integer) 
3
redis 
127.0.0.1:6379> LRANGE students 0 2
1"Dexter Morgan"
2"Captain Kirk"
3"John Doe"
redis 
127.0.0.1:6379> LREM students 1 "John Doe"
(integer) 
1
redis 
127.0.0.1:6379> LLEN students
(integer) 
1
redis 
127.0.0.1:6379> LRANGE students 0 1
1"Captain Kirk"

2.3 集合(Sets)類型

Redis能夠將一系列不重復的值存儲成一個集合

redis 127.0.0.1:6379> SADD birds crow
(integer) 
1
redis 
127.0.0.1:6379> SADD birds pigeon
(integer) 
1
redis 
127.0.0.1:6379> SADD birds bat
(integer) 
1
redis 
127.0.0.1:6379> SADD mammals dog
(integer) 
1
redis 
127.0.0.1:6379> SADD mammals cat
(integer) 
1
redis 
127.0.0.1:6379> SADD mammals bat
(integer) 
1
redis 
127.0.0.1:6379> SMEMBERS birds
1"bat"
2"crow"
3"pigeon"
redis 
127.0.0.1:6379> SMEMBERS mammals
1"bat"
2"cat"
3"dog"
Sets結構也支持相應的修改操作
redis 127.0.0.1:6379> SREM mammals cat
(integer) 
1
redis 
127.0.0.1:6379> SMEMBERS mammals
1"bat"
2"dog"
redis 
127.0.0.1:6379> SADD mammals human
(integer) 
1
redis 
127.0.0.1:6379> SMEMBERS mammals
1"bat"
2"human"
3"dog"
Redis還支持對集合的子交并補等操作
redis 127.0.0.1:6379> SINTER birds mammals
1"bat"
redis 
127.0.0.1:6379> SUNION birds mammals
1"crow"
2"bat"
3"human"
4"pigeon"
5"dog"
redis 
127.0.0.1:6379> SDIFF birds mammals
1"crow"
2"pigeon"

2.4 有序集合(Sorted Sets)類型

Sorted Sets和Sets結構相似,不同的是存在Sorted Sets中的數據會有一個score屬性,并會在寫入時就按這個score排好序。

redis 127.0.0.1:6379> ZADD days 0 mon
(integer) 
1
redis 
127.0.0.1:6379> ZADD days 1 tue
(integer) 
1
redis 
127.0.0.1:6379> ZADD days 2 wed
(integer) 
1
redis 
127.0.0.1:6379> ZADD days 3 thu
(integer) 
1
redis 
127.0.0.1:6379> ZADD days 4 fri
(integer) 
1
redis 
127.0.0.1:6379> ZADD days 5 sat
(integer) 
1
redis 
127.0.0.1:6379> ZADD days 6 sun
(integer) 
1
redis 
127.0.0.1:6379> ZCARD days
(integer) 
7
redis 
127.0.0.1:6379> ZRANGE days 0 6
1"mon"
2"tue"
3"wed"
4"thu"
5"fri"
6"sat"
7"sun"
redis 
127.0.0.1:6379> ZSCORE days sat
"5"
redis 
127.0.0.1:6379> ZCOUNT days 3 6
(integer) 
4
redis 
127.0.0.1:6379> ZRANGEBYSCORE days 3 6
1"thu"
2"fri"
3"sat"
4"sun"

2.5 Hash類型

Redis能夠存儲key對多個屬性的數據(比如user1.uname user1.passwd)

redis 127.0.0.1:6379> HKEYS student
1"name"
2"age"
3"sex"
redis 
127.0.0.1:6379> HVALS student
1"Ganesh"
2"30"
3"Male"
redis 
127.0.0.1:6379> HGETALL student
1"name"
2"Ganesh"
3"age"
4"30"
5"sex"
6"Male"
redis 
127.0.0.1:6379> HDEL student sex
(integer) 
1
redis 
127.0.0.1:6379> HGETALL student
1"name"
2"Ganesh"
3"age"
4"30"
Hash數據結構能夠批量修改和獲取
redis 127.0.0.1:6379> HMSET kid name Akshi age 2 sex Female
OK
redis 
127.0.0.1:6379> HMGET kid name age sex
1"Akshi"
2"2"
3"Female"

3.Publish/Subscribe

Redis支持這樣一種特性,你可以將數據推到某個信息管道中,然后其它人可以通過訂閱這些管道來獲取推送過來的信息。

3.1 訂閱信息管道

用一個客戶端訂閱管道

redis 127.0.0.1:6379> SUBSCRIBE channelone
Reading messages (press Ctrl
-C to quit)
1"subscribe"
2"channelone"
3) (integer) 1
另一個客戶端往這個管道推送信息
redis 127.0.0.1:6379> PUBLISH channelone hello
(integer) 
1
redis 
127.0.0.1:6379> PUBLISH channelone world
(integer) 
1
然后第一個客戶端就能獲取到推送的信息
redis 127.0.0.1:6379> SUBSCRIBE channelone
Reading messages (press Ctrl
-C to quit)
1"subscribe"
2"channelone"
3) (integer) 1
1"message"
2"channelone"
3"hello"
1"message"
2"channelone"
3"world"

3.2 按一定模式批量訂閱

用下面的命令訂閱所有channel開頭的信息通道

redis 127.0.0.1:6379> PSUBSCRIBE channel*
Reading messages (press Ctrl
-C to quit)
1"psubscribe"
2"channel*"
3) (integer) 1
在另一個客戶端對兩個推送信息
redis 127.0.0.1:6379> PUBLISH channelone hello
(integer) 
1
redis 
127.0.0.1:6379> PUBLISH channeltwo world
(integer) 
1
然后在第一個客戶端就能收到推送的信息
redis 127.0.0.1:6379> PSUBSCRIBE channel*
Reading messages (press Ctrl
-C to quit)
1"psubscribe"
2"channel*"
3) (integer) 1
1"pmessage"
2"channel*"
3"channelone"
4"hello"
1"pmessage"
2"channel*"
3"channeltwo"
4"world"

4.數據過期設置

Redis支持按key設置過期時間,過期后值將被刪除(在客戶端看來是補刪除了的)

用TTL命令可以獲取某個key值的過期時間(-1表示永不過期)

redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 
127.0.0.1:6379> TTL name
(integer) 
-1
下面命令先用EXISTS命令查看key值是否存在,然后設置了5秒的過期時間
redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 
127.0.0.1:6379> EXISTS name
(integer) 
1
redis 
127.0.0.1:6379> EXPIRE name 5
(integer) 
1
5秒后再查看
redis 127.0.0.1:6379> EXISTS name
(integer) 
0
redis 
127.0.0.1:6379> GET name
(nil)

這個值已經沒有了。

上在是直接設置多少秒后過期,你也可以設置在某個時間點過期,下面例子是設置2011-09-24 00:40:00過期。

redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 
127.0.0.1:6379> EXPIREAT name 1316805000
(integer) 
1
redis 
127.0.0.1:6379> EXISTS name
(integer) 
0

5.事務性

Redis本身支持一些簡單的組合型的命令,比如以NX結尾命令都是判斷在這個值沒有時才進行某個命令。

redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 
127.0.0.1:6379> SETNX name "Dexter Morgan"
(integer) 
0
redis 
127.0.0.1:6379> GET name
"John Doe"
redis 
127.0.0.1:6379> GETSET name "Dexter Morgan"
"John Doe"
redis 
127.0.0.1:6379> GET name
"Dexter Morgan"
當然,Redis還支持自定義的命令組合,通過MULTI和EXEC,將幾個命令組合起來執行
redis 127.0.0.1:6379> SET counter 0
OK
redis 
127.0.0.1:6379> MULTI
OK
redis 
127.0.0.1:6379> INCR counter
QUEUED
redis 
127.0.0.1:6379> INCR counter
QUEUED
redis 
127.0.0.1:6379> INCR counter
QUEUED
redis 
127.0.0.1:6379> EXEC
1) (integer) 1
2) (integer) 2
3) (integer) 3
redis 
127.0.0.1:6379> GET counter
"3"
你還可以用DICARD命令來中斷執行中的命令序列
redis 127.0.0.1:6379> SET newcounter 0
OK
redis 
127.0.0.1:6379> MULTI
OK
redis 
127.0.0.1:6379> INCR newcounter
QUEUED
redis 
127.0.0.1:6379> INCR newcounter
QUEUED
redis 
127.0.0.1:6379> INCR newcounter
QUEUED
redis 
127.0.0.1:6379> DISCARD
OK
redis 
127.0.0.1:6379> GET newcounter
"0"

6.持久化

Redis的所有數據都存儲在內存中,但是他也提供對這些數據的持久化。

6.1 數據快照

數據快照的原理是將整個Redis中存的所有數據遍歷一遍存到一個擴展名為rdb的數據文件中。通過SAVE命令可以調用這個過程。

redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 
127.0.0.1:6379> SAVE
OK
redis 
127.0.0.1:6379> SET name "Sheldon Cooper"
OK
redis 
127.0.0.1:6379> BGSAVE
Background saving started
如果你是使用的brew在Mac OSX上安全的Redis,那么rdb文件會存在如下路徑
/usr/local/var/db/redis/dump.rdb

6.2 Append-Only File(追加式的操作日志記錄)

Redis還支持一種追加式的操作日志記錄,叫append only file,其日志文件以aof結局,我們一般各為aof文件。要開啟aof日志的記錄,你需要在配置文件中進行如下設置:

appendonly yes
這時候你所有的操作都會記錄在aof日志文件中
redis 127.0.0.1:6379> GET name
(nil)
redis 127.0.0.1:6379> SET name "Ganesh Gunasegaran"
OK
redis 127.0.0.1:6379> EXIT

→ cat /usr/local/var/db/redis/appendonly.aof
*2
$6
SELECT
$1
0
*3
$3
SET
$4
name
$18
Ganesh Gunasegaran

7.管理命令

Redis支持多個DB,默認是16個,你可以設置將數據存在哪一個DB中,不同DB間的數據具有隔離性。也可以在多個DB間移動數據。

redis 127.0.0.1:6379> SELECT 0
OK
redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 127.0.0.1:6379> SELECT 1
OK
redis 127.0.0.1:6379[1]> GET name
(nil)
redis 127.0.0.1:6379[1]> SELECT 0
OK
redis 127.0.0.1:6379> MOVE name 1
(integer) 1
redis 127.0.0.1:6379> SELECT 1
OK
redis 127.0.0.1:6379[1]> GET name
"John Doe"

Redis還能進行一些如下操作,獲取一些運行信息
redis 127.0.0.1:6379[1]> DBSIZE
(integer) 1
redis 127.0.0.1:6379[1]> INFO
redis_version:2.2.13
redis_git_sha1:00000000
redis_git_dirty:0
arch_bits:64
multiplexing_api:kqueue
Redis還支持對某個DB數據進行清除(當然清空所有數據的操作也是支持的)
redis 127.0.0.1:6379> SET name "John Doe"
OK
redis 127.0.0.1:6379> DBSIZE
(integer) 1
redis 127.0.0.1:6379> SELECT 1
OK
redis 127.0.0.1:6379[1]> SET name "Sheldon Cooper"
OK
redis 127.0.0.1:6379[1]> DBSIZE
(integer) 1
redis 127.0.0.1:6379[1]> SELECT 0
OK
redis 127.0.0.1:6379> FLUSHDB
OK
redis 127.0.0.1:6379> DBSIZE
(integer) 0
redis 127.0.0.1:6379> SELECT 1
OK
redis 127.0.0.1:6379[1]> DBSIZE
(integer) 1
redis 127.0.0.1:6379[1]> FLUSHALL
OK
redis 127.0.0.1:6379[1]> DBSIZE
(integer) 0

8.客戶端

Redis的客戶端很豐富,幾乎所有流行的語言都有其客戶端,這里就不再贅述,有興趣的同學可以上Redis的Clients頁面去查找。

9.資料引用

10.總結



轉自:http://blog.nosqlfan.com/html/3139.html?ref=rediszt

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲私人影院| 国内外成人免费视频| 午夜精品久久久久久久蜜桃app| 欧美在线看片a免费观看| 欧美日韩免费观看一区二区三区| 韩日视频一区| 久久精品一区蜜桃臀影院| 一本色道久久综合狠狠躁篇的优点| 久久久噜噜噜久噜久久| 国产亚洲视频在线| 99精品国产热久久91蜜凸| 蜜臀va亚洲va欧美va天堂| 午夜日本精品| 国产情人节一区| 欧美在线视频不卡| 亚洲男女自偷自拍| 亚洲一级在线观看| 麻豆亚洲精品| 亚洲国产成人av好男人在线观看| 欧美综合国产| 性一交一乱一区二区洋洋av| 国产精品入口夜色视频大尺度 | 欧美激情一区二区三区在线| 亚洲第一视频网站| 亚洲高清精品中出| 久久精品99久久香蕉国产色戒| 国产精品无人区| 久久精品99| 国产精品入口麻豆原神| 欧美日韩成人免费| 亚洲精品视频一区| 亚洲国产欧美一区二区三区久久 | 欧美人成网站| 一区二区三区四区五区在线| av成人毛片| 国产欧美精品一区二区色综合 | 亚洲精品中文字幕在线| 亚洲国产aⅴ天堂久久| 欧美大片免费| 亚洲欧美日韩综合一区| 性一交一乱一区二区洋洋av| 136国产福利精品导航网址| 亚洲第一主播视频| 欧美精品18| 欧美一区二视频| 久久久亚洲国产天美传媒修理工 | 欧美精品v日韩精品v韩国精品v| 99国产精品久久久久久久成人热| 亚洲精品日韩综合观看成人91| 国产精品一区一区三区| 欧美激情aⅴ一区二区三区| 亚洲欧美成人| 久久一二三四| 午夜在线成人av| 麻豆91精品| 亚洲男人第一av网站| 久久综合九色综合欧美狠狠| 亚洲伊人久久综合| 老司机一区二区三区| 午夜精品美女久久久久av福利| 美女主播一区| 久久亚洲一区二区| 国产精品一区二区三区成人| 亚洲娇小video精品| 国产综合网站| 亚洲欧美一区二区三区极速播放| 日韩午夜三级在线| 久久亚洲私人国产精品va| 午夜精品久久久久99热蜜桃导演| 免费一级欧美片在线播放| 欧美一区二区精品| 欧美日韩国产区| 欧美大片va欧美在线播放| 国产一区二区精品久久99| 在线综合亚洲| 中文亚洲视频在线| 欧美激情精品久久久六区热门| 美女精品网站| 狠狠干综合网| 欧美亚洲网站| 欧美在线免费视屏| 国产精品久久久99| 日韩一级精品| 亚洲午夜一区二区三区| 欧美精品导航| 亚洲精品社区| 亚洲精品无人区| 欧美成人激情在线| 欧美大片免费看| 亚洲全黄一级网站| 欧美风情在线观看| 欧美激情国产日韩| 亚洲国产综合91精品麻豆| 久久精品国产精品 | 麻豆精品视频| 欧美高清视频在线| 亚洲第一视频| 日韩视频一区二区三区在线播放| 久久精品网址| 欧美影院精品一区| 国产麻豆精品theporn| 亚洲女ⅴideoshd黑人| 亚洲欧美日韩国产中文在线| 欧美香蕉大胸在线视频观看| 亚洲精选中文字幕| 亚洲午夜性刺激影院| 欧美日韩亚洲激情| 中文久久精品| 久久久久久网| 最新国产成人av网站网址麻豆 | 久久av一区二区三区| 久久久久久有精品国产| 国产综合色在线视频区| 久久综合激情| 亚洲精品欧洲精品| 亚洲欧美在线高清| 国产色婷婷国产综合在线理论片a| 新67194成人永久网站| 久久嫩草精品久久久精品| 亚洲丁香婷深爱综合| 欧美精品手机在线| 亚洲天堂视频在线观看| 久久久水蜜桃| 亚洲免费成人av电影| 欧美日韩综合视频| 午夜精品久久久久久久99黑人| 久久精品国产视频| 亚洲黄色免费电影| 国产精品久久久亚洲一区| 欧美一级在线播放| 欧美激情一区二区三区在线 | 亚洲一本大道在线| 久久综合综合久久综合| 亚洲激情一区二区| 欧美性猛交xxxx乱大交退制版| 欧美影院视频| a4yy欧美一区二区三区| 久久精品女人| 99精品国产在热久久下载| 国产精品午夜在线观看| 免费日韩成人| 午夜日韩视频| 亚洲日本成人网| 久久性天堂网| 亚洲欧美日韩区| 亚洲国产精品第一区二区| 国产精品普通话对白| 欧美国产高清| 毛片基地黄久久久久久天堂| 亚洲自拍偷拍福利| 欧美黄色影院| 久久久久久噜噜噜久久久精品 | 欧美88av| 性视频1819p久久| 99在线|亚洲一区二区| 亚洲成人资源| 国产精品午夜视频| 欧美婷婷在线| 欧美激情无毛| 久久一综合视频| 欧美在线一二三| 嫩模写真一区二区三区三州| 国产精品免费久久久久久| 免费成人av在线| 久久综合福利| 午夜宅男久久久| 亚洲一区二区三区视频播放| 在线播放豆国产99亚洲| 国产视频久久久久| 国产精品实拍| 欧美三级乱码| 欧美国产国产综合| 欧美激情第三页| 免费在线看一区| 欧美韩国日本一区| 欧美黄色成人网| 欧美电影资源| 久久综合给合久久狠狠狠97色69| 久久成人综合视频| 欧美在线不卡视频| 欧美一区二区三区视频免费| 一本色道久久综合狠狠躁篇的优点| 亚洲免费观看在线观看| 一区二区三区免费看| 亚洲砖区区免费| 欧美88av| 欧美激情无毛| 亚洲精品欧美激情| 一本大道久久a久久精二百| 亚洲二区在线| 一区二区三区免费在线观看| 巨乳诱惑日韩免费av| 久久久精品一区| 久久天天狠狠| 免费欧美网站| 欧美精品在线播放| 欧美久久久久久| 欧美日韩中文另类| 亚洲你懂的在线视频| 欧美一区二区视频在线观看|