32.3. redis-cli - Command-line client to redis-server
32.3.1.?命令參數(shù)
32.3.1.1.?password
-a <password> Password to use when connecting to the server. [root@netkiller conf.d]# redis-cli -a hsM8NK8b71vFQKFOS55jbWJrA1TYgI4e32.3.1.2.?raw
--raw Use raw formatting for replies (default when STDOUT is not a tty).
有時(shí)顯示這樣的數(shù)據(jù)
[hadoop@netkiller ~]$ redis-cli 127.0.0.1:6379> ZREVRANGE FASTNEWS_DATA_STORE_KEY 0 1 1) "{\"title\":\"\xe4\xb8\x8a\xe8\xaf\x81\xe7\xbb\xbc\xe6\x8c\x87\xe5\x91\xa8\xe7\xba\xbf\xe4\xba\x94\xe8\xbf\x9e\xe9\x98\xb3\xef\xbc\x8c\xe5\x88\x9b\xe4\xb8\x9a\xe6\x9d\xbf\xe8\xbf\x9e\xe7\xbb\xad\xe4\xb8\xa4\xe5\x91\xa8\xe5\xa4\xa7\xe8\xb7\x8c\xef\xbc\x9b \xe4\xb8\x8a\xe8\xaf\x81\xe7\xbb\xbc\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe8\xb7\x8c0.23%\xef\xbc\x8c\xe4\xb8\x8b\xe8\xb7\x8c7.60\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa53237.98\xe7\x82\xb9\xef\xbc\x9b \xe6\xb7\xb1\xe8\xaf\x81\xe6\x88\x90\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe8\xb7\x8c0.03%\xef\xbc\x8c\xe4\xb8\x8b\xe8\xb7\x8c3.50\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa510363.48\xe7\x82\xb9\xef\xbc\x9b \xe6\xb2\xaa\xe6\xb7\xb1300\xe8\x82\xa1\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe8\xb7\x8c0.52%\xef\xbc\x8c\xe4\xb8\x8b\xe8\xb7\x8c19.49\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa53728.39\xe7\x82\xb9\xef\xbc\x9b \xe5\x88\x9b\xe4\xb8\x9a\xe6\x9d\xbf\xe6\x8c\x87\xe6\x95\xb0\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe6\xb6\xa80.08%\xef\xbc\x8c\xe4\xb8\x8a\xe6\xb6\xa81.31\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa51689.92\xe7\x82\xb9\\r\\n\"}" 2) "{\"title\":\"\xe4\xb8\x8a\xe8\xaf\x81\xe7\xbb\xbc\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe4\xb8\x8b\xe8\xb7\x8c0.21%\xef\xbc\x8c\xe6\x8a\xa53237.98\xe7\x82\xb9\xef\xbc\x9b\xe6\xb7\xb1\xe8\xaf\x81\xe6\x88\x90\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe5\xbe\xae\xe8\xb7\x8c0.02%\xef\xbc\x8c\xe6\x8a\xa510364.82\xe7\x82\xb9\xef\xbc\x9b\xe5\x88\x9b\xe4\xb8\x9a\xe6\x9d\xbf\xe6\x8c\x87\xe6\x95\xb0\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe5\xbe\xae\xe6\xb6\xa80.09%\xef\xbc\x8c\xe6\x8a\xa51690.15\xe7\x82\xb9\"}" 127.0.0.1:6379>加入 --raw 參數(shù)后可以顯示可以閱讀的數(shù)據(jù)
[hadoop@VM_3_2_centos ~]$ redis-cli --raw 127.0.0.1:6379> ZREVRANGE FASTNEWS_DATA_STORE_KEY 0 1 {"title":"上證綜指周線五連陽(yáng),創(chuàng)業(yè)板連續(xù)兩周大跌"} {"title":"上證綜指周五收盤(pán)下跌0.21%,報(bào)3237.98點(diǎn)"} 127.0.0.1:6379>32.3.2.?--latency Enter a special mode continuously sampling latency.
參數(shù)的功能是從客戶端發(fā)出一條命令到客戶端接受到該命令的反饋所用的最長(zhǎng)響應(yīng)時(shí)間
# redis-cli --latency -h 192.168.2.1 min: 1, max: 210, avg: 3.64 (13453 samples)32.3.3.?auth
認(rèn)證密碼
[root@netkiller ~]# redis-cli 127.0.0.1:6379> keys * (error) NOAUTH Authentication required. 127.0.0.1:6379> auth hsM8NKb71vjbWJrA1TYgI4 OK 127.0.0.1:6379> keys *1) "HK50(1605)"2) "GBPUSD"3) "USDCHF"4) "SP500(1609)"5) "NZDJPY"6) "AUDNZD"7) "EURGBP"8) "CLN6"9) "BU6"32.3.4.?MONITOR
$ redis-cli monitor32.3.5.?info
redis 127.0.0.1:6379> info redis_version:2.4.10 redis_git_sha1:00000000 redis_git_dirty:0 arch_bits:64 multiplexing_api:epoll gcc_version:4.4.6 process_id:29663 uptime_in_seconds:1189 uptime_in_days:0 lru_clock:1018411 used_cpu_sys:0.10 used_cpu_user:0.09 used_cpu_sys_children:0.01 used_cpu_user_children:0.00 connected_clients:1 connected_slaves:0 client_longest_output_list:0 client_biggest_input_buf:0 blocked_clients:0 used_memory:730664 used_memory_human:713.54K used_memory_rss:7225344 used_memory_peak:730720 used_memory_peak_human:713.59K mem_fragmentation_ratio:9.89 mem_allocator:jemalloc-2.2.5 loading:0 aof_enabled:0 changes_since_last_save:0 bgsave_in_progress:0 last_save_time:1373332622 bgrewriteaof_in_progress:0 total_connections_received:4 total_commands_processed:14 expired_keys:0 evicted_keys:0 keyspace_hits:3 keyspace_misses:0 pubsub_channels:0 pubsub_patterns:0 latest_fork_usec:744 vm_enabled:0 role:master db0:keys=4,expires=0 redis 127.0.0.1:6379>32.3.6.?save/bgsave/lastsave
save/bgsave 保存持久化將數(shù)據(jù),lastsave 查看相關(guān)信息
redis 127.0.0.1:6379> save OK redis 127.0.0.1:6379> bgsave Background saving started redis 127.0.0.1:6379> lastsave (integer) 137333575732.3.7.?config
CONFIG GET dir CONFIG GET dbfilenameconfig set stop-writes-on-bgsave-error yes CONFIG SET dir /tmp CONFIG SET dbfilename temp.rdb32.3.8.?keys
查詢(xún)所有key
172.18.52.15:6379> keys *1) "www.example.com:743f10d0f1dc569ed5893856e14c1fb7captcha"2) "www.example.com:d88e0b6c54a235763dd731bcc0914439captcha"3) "www.example.com:17f9091cb44f3cc5bb411eb801f07be8member_login"4) "www.example.com:10ff594fd42f4c81212020555cfb586amember_login_input"5) "www.example.com:a759ba5232ce324d0e6ae8da9290beaecaptcha"6) "www.example.com:37c78410af02d66a542d15b9707f215bcaptcha"7) "www.example.com:9f5070e217f4eac9a1d15f9b8dbe7148deposit_1_temp_var"8) "www.example.com:6c1a13c9396df2c35613043923bfe338captcha"9) "www.example.com:b611080c0627154871ea0e1498793238captcha" 10) "www.example.com:2792241f8d0f075528db2b50e0c9c684member_login"查詢(xún)指定key
172.18.50.15:6379> set name neo OK 172.18.50.15:6379> keys name 1) "name"32.3.9.?字符串操作
32.3.9.1.?set/get/del
172.18.52.15:6379> set name neo OK 172.18.52.15:6379> get name "neo" 172.18.52.15:6379> keys name 1) "name" 172.18.52.15:6379> del name (integer) 1 172.18.52.15:6379> get name (nil)32.3.9.2.?setnx
SETNX key value當(dāng) key 不存在時(shí)將 key 的值設(shè)為 value,若給定的 key 已經(jīng)存在,則 SETNX 不做任何動(dòng)作。SETNX 是(SET if Not eXists) (如果不存在,則 SET)的簡(jiǎn)寫(xiě)。
返回值:設(shè)置成功,返回 1設(shè)置失敗,返回 0redis> EXISTS neo # neo 不存在 (integer) 0redis> SETNX neo "chen" # neo 設(shè)置成功 (integer) 1redis> SETNX neo "netkiller" # 嘗試覆蓋 neo ,失敗 (integer) 0redis> GET neo # 沒(méi)有被覆蓋 "chen"32.3.10.?expire/ttl
EXPIRE 設(shè)置過(guò)期時(shí)間, TTL 可以查詢(xún)過(guò)期時(shí)間倒計(jì)時(shí)。
172.18.52.165:6379> set name neo OK 172.18.52.165:6379> ttl name (integer) -1 172.18.52.165:6379> expire name 30 (integer) 1 172.18.52.165:6379> ttl name (integer) 22 172.18.52.165:6379> ttl name (integer) 9 172.18.52.165:6379> ttl name (integer) -1 172.18.52.165:6379> get name (nil)注意ttl返回-1有兩種情況,一是沒(méi)有設(shè)置過(guò)期時(shí)間,另一種是該key已經(jīng)過(guò)期不存在。
32.3.11.?獲取 key 類(lèi)型
root@netkiller ~ % redis-cli 127.0.0.1:6379> TYPE "logstash:redis" list32.3.12.?LIST 數(shù)據(jù)類(lèi)型
獲取 list 列表長(zhǎng)度
127.0.0.1:6379> TYPE "logstash:redis" list 127.0.0.1:6379> LLEN "logstash:redis" (integer) 69 127.0.0.1:6379> lpop "logstash:redis" 127.0.0.1:6379> 127.0.0.1:6379> LLEN "logstash:redis" (integer) 68 1. LPUSH/LPUSHX/LRANGE: /> redis-cli #在Shell提示符下啟動(dòng)redis客戶端工具。 redis 127.0.0.1:6379> del queue:test (integer) 1 #queue:test鍵并不存在,該命令會(huì)創(chuàng)建該鍵及與其關(guān)聯(lián)的List,之后在將參數(shù)中的values從左到右依次插入。 redis 127.0.0.1:6379> lpush queue:test a b c d (integer) 4 #取從位置0開(kāi)始到位置2結(jié)束的3個(gè)元素。 redis 127.0.0.1:6379> lrange queue:test 0 2 1) "d" 2) "c" 3) "b" #取鏈表中的全部元素,其中0表示第一個(gè)元素,-1表示最后一個(gè)元素。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "d" 2) "c" 3) "b" 4) "a" #queue:test2鍵此時(shí)并不存在,因此該命令將不會(huì)進(jìn)行任何操作,其返回值為0。 redis 127.0.0.1:6379> lpushx queue:test2 e (integer) 0 #可以看到queue:test2沒(méi)有關(guān)聯(lián)任何List Value。 redis 127.0.0.1:6379> lrange queue:test2 0 -1 (empty list or set) #queue:test鍵此時(shí)已經(jīng)存在,所以該命令插入成功,并返回鏈表中當(dāng)前元素的數(shù)量。 redis 127.0.0.1:6379> lpushx queue:test e (integer) 5 #獲取該鍵的List Value的頭部元素。 redis 127.0.0.1:6379> lrange queue:test 0 0 1) "e"2. LPOP/LLEN: redis 127.0.0.1:6379> lpush queue:test a b c d (integer) 4 redis 127.0.0.1:6379> lpop queue:test "d" redis 127.0.0.1:6379> lpop queue:test "c" #在執(zhí)行l(wèi)pop命令兩次后,鏈表頭部的兩個(gè)元素已經(jīng)被彈出,此時(shí)鏈表中元素的數(shù)量是2 redis 127.0.0.1:6379> llen queue:test (integer) 23. LREM/LSET/LINDEX/LTRIM: #為后面的示例準(zhǔn)備測(cè)試數(shù)據(jù)。 redis 127.0.0.1:6379> lpush queue:test a b c d a c (integer) 6 #從頭部(left)向尾部(right)變量鏈表,刪除2個(gè)值等于a的元素,返回值為實(shí)際刪除的數(shù)量。 redis 127.0.0.1:6379> lrem queue:test 2 a (integer) 2 #看出刪除后鏈表中的全部元素。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "c" 2) "d" 3) "c" 4) "b" #獲取索引值為1(頭部的第二個(gè)元素)的元素值。 redis 127.0.0.1:6379> lindex queue:test 1 "d" #將索引值為1(頭部的第二個(gè)元素)的元素值設(shè)置為新值e。 redis 127.0.0.1:6379> lset queue:test 1 e OK #查看是否設(shè)置成功。 redis 127.0.0.1:6379> lindex queue:test 1 "e" #索引值6超過(guò)了鏈表中元素的數(shù)量,該命令返回nil。 redis 127.0.0.1:6379> lindex queue:test 6 (nil) #設(shè)置的索引值6超過(guò)了鏈表中元素的數(shù)量,設(shè)置失敗,該命令返回錯(cuò)誤信息。 redis 127.0.0.1:6379> lset queue:test 6 hh (error) ERR index out of range #僅保留索引值0到2之間的3個(gè)元素,注意第0個(gè)和第2個(gè)元素均被保留。 redis 127.0.0.1:6379> ltrim queue:test 0 2 OK #查看trim后的結(jié)果。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "c" 2) "e" 3) "c"4. LINSERT: #刪除該鍵便于后面的測(cè)試。 redis 127.0.0.1:6379> del queue:test (integer) 1 #為后面的示例準(zhǔn)備測(cè)試數(shù)據(jù)。 redis 127.0.0.1:6379> lpush queue:test a b c d e (integer) 5 #在a的前面插入新元素a1。 redis 127.0.0.1:6379> linsert queue:test before a a1 (integer) 6 #查看是否插入成功,從結(jié)果看已經(jīng)插入。注意lindex的index值是0-based。 redis 127.0.0.1:6379> lindex queue:test 0 "e" #在e的后面插入新元素e2,從返回結(jié)果看已經(jīng)插入成功。 redis 127.0.0.1:6379> linsert queue:test after e e2 (integer) 7 #再次查看是否插入成功。 redis 127.0.0.1:6379> lindex queue:test 1 "e2" #在不存在的元素之前或之后插入新元素,該命令操作失敗,并返回-1。 redis 127.0.0.1:6379> linsert queue:test after k a (integer) -1 #為不存在的Key插入新元素,該命令操作失敗,返回0。 redis 127.0.0.1:6379> linsert queue:test1 after a a2 (integer) 05. RPUSH/RPUSHX/RPOP/RPOPLPUSH: #刪除該鍵,以便于后面的測(cè)試。 redis 127.0.0.1:6379> del queue:test (integer) 1 #從鏈表的尾部插入?yún)?shù)中給出的values,插入順序是從左到右依次插入。 redis 127.0.0.1:6379> rpush queue:test a b c d (integer) 4 #通過(guò)lrange的可以獲悉rpush在插入多值時(shí)的插入順序。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "a" 2) "b" 3) "c" 4) "d" #該鍵已經(jīng)存在并且包含4個(gè)元素,rpushx命令將執(zhí)行成功,并將元素e插入到鏈表的尾部。 redis 127.0.0.1:6379> rpushx queue:test e (integer) 5 #通過(guò)lindex命令可以看出之前的rpushx命令確實(shí)執(zhí)行成功,因?yàn)樗饕禐?的元素已經(jīng)是新元素了。 redis 127.0.0.1:6379> lindex queue:test 4 "e" #由于queue:test2鍵并不存在,因此該命令不會(huì)插入數(shù)據(jù),其返回值為0。 redis 127.0.0.1:6379> rpushx queue:test2 e (integer) 0 #在執(zhí)行rpoplpush命令前,先看一下queue:test中鏈表的元素有哪些,注意他們的位置關(guān)系。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "a" 2) "b" 3) "c" 4) "d" 5) "e" #將queue:test的尾部元素e彈出,同時(shí)再插入到queue:test2的頭部(原子性的完成這兩步操作)。 redis 127.0.0.1:6379> rpoplpush queue:test queue:test2 "e" #通過(guò)lrange命令查看queue:test在彈出尾部元素后的結(jié)果。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "a" 2) "b" 3) "c" 4) "d" #通過(guò)lrange命令查看queue:test2在插入元素后的結(jié)果。 redis 127.0.0.1:6379> lrange queue:test2 0 -1 1) "e" #將source和destination設(shè)為同一鍵,將queue:test中的尾部元素移到其頭部。 redis 127.0.0.1:6379> rpoplpush queue:test queue:test "d" #查看移動(dòng)結(jié)果。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "d" 2) "a" 3) "b" 4) "c"32.3.13.?set 無(wú)序字符集合
Set和List類(lèi)型不同的是,Set集合中不允許出現(xiàn)重復(fù)的元素,和List類(lèi)型相比,Set類(lèi)型在功能上還存在著一個(gè)非常重要的特性,即在服務(wù)器端完成多個(gè)Sets之間的聚合計(jì)算操作,如unions、intersections和differences。由于這些操作均在服務(wù)端完成,因此效率極高,而且也節(jié)省了大量的網(wǎng)絡(luò)IO開(kāi)銷(xiāo)。
1. SADD/SMEMBERS/SCARD/SISMEMBER:
#插入測(cè)試數(shù)據(jù),由于該鍵set:test之前并不存在,因此參數(shù)中的三個(gè)成員都被正常插入。redis 127.0.0.1:6379> sadd set:test a b c(integer) 3#由于參數(shù)中的a在set:test中已經(jīng)存在,因此本次操作僅僅插入了d和e兩個(gè)新成員。redis 127.0.0.1:6379> sadd set:test a d e(integer) 2#判斷a是否已經(jīng)存在,返回值為1表示存在。redis 127.0.0.1:6379> sismember set:test a(integer) 1#判斷f是否已經(jīng)存在,返回值為0表示不存在。redis 127.0.0.1:6379> sismember set:test f(integer) 0#通過(guò)smembers命令查看插入的結(jié)果,從結(jié)果可以,輸出的順序和插入順序無(wú)關(guān)。redis 127.0.0.1:6379> smembers set:test1) "c"2) "d"3) "a"4) "b"5) "e"#獲取Set集合中元素的數(shù)量。redis 127.0.0.1:6379> scard set:test(integer) 52. SPOP/SREM/SRANDMEMBER/SMOVE:
#刪除該鍵,便于后面的測(cè)試。redis 127.0.0.1:6379> del set:test(integer) 1#為后面的示例準(zhǔn)備測(cè)試數(shù)據(jù)。redis 127.0.0.1:6379> sadd set:test a b c d(integer) 4#查看Set中成員的位置。redis 127.0.0.1:6379> smembers set:test1) "c"2) "d"3) "a"4) "b"#從結(jié)果可以看出,該命令確實(shí)是隨機(jī)的返回了某一成員。redis 127.0.0.1:6379> srandmember set:test"c"#Set中尾部的成員b被移出并返回,事實(shí)上b并不是之前插入的第一個(gè)或最后一個(gè)成員。redis 127.0.0.1:6379> spop set:test"b"#查看移出后Set的成員信息。redis 127.0.0.1:6379> smembers set:test1) "c"2) "d"3) "a"#從Set中移出a、d和f三個(gè)成員,其中f并不存在,因此只有a和d兩個(gè)成員被移出,返回為2。redis 127.0.0.1:6379> srem set:test a d f(integer) 2#查看移出后的輸出結(jié)果。redis 127.0.0.1:6379> smembers set:test1) "c"#為后面的smove命令準(zhǔn)備數(shù)據(jù)。redis 127.0.0.1:6379> sadd set:test a b(integer) 2redis 127.0.0.1:6379> sadd set:test2 c d(integer) 2#將a從set:test移到set:test2,從結(jié)果可以看出移動(dòng)成功。redis 127.0.0.1:6379> smove set:test set:test2 a(integer) 1#再次將a從set:test移到set:test2,由于此時(shí)a已經(jīng)不是set:test的成員了,因此移動(dòng)失敗并返回0。redis 127.0.0.1:6379> smove set:test set:test2 a(integer) 0#分別查看set:test和set:test2的成員,確認(rèn)移動(dòng)是否真的成功。redis 127.0.0.1:6379> smembers set:test1) "b"redis 127.0.0.1:6379> smembers set:test21) "c"2) "d"3) "a"3. SDIFF/SDIFFSTORE/SINTER/SINTERSTORE:
#為后面的命令準(zhǔn)備測(cè)試數(shù)據(jù)。redis 127.0.0.1:6379> sadd set:test a b c d(integer) 4redis 127.0.0.1:6379> sadd set:test2 c(integer) 1redis 127.0.0.1:6379> sadd set:test3 a c e(integer) 3#set:test和set:test2相比,a、b和d三個(gè)成員是兩者之間的差異成員。再用這個(gè)結(jié)果繼續(xù)和set:test3進(jìn)行差異比較,b和d是set:test3不存在的成員。redis 127.0.0.1:6379> sdiff set:test set:test2 set:test31) "d"2) "b"#將3個(gè)集合的差異成員存在在diffkey關(guān)聯(lián)的Set中,并返回插入的成員數(shù)量。redis 127.0.0.1:6379> sdiffstore diffkey set:test set:test2 set:test3(integer) 2#查看一下sdiffstore的操作結(jié)果。redis 127.0.0.1:6379> smembers diffkey1) "d"2) "b"#從之前準(zhǔn)備的數(shù)據(jù)就可以看出,這三個(gè)Set的成員交集只有c。redis 127.0.0.1:6379> sinter set:test set:test2 set:test31) "c"#將3個(gè)集合中的交集成員存儲(chǔ)到與interkey關(guān)聯(lián)的Set中,并返回交集成員的數(shù)量。redis 127.0.0.1:6379> sinterstore interkey set:test set:test2 set:test3(integer) 1#查看一下sinterstore的操作結(jié)果。redis 127.0.0.1:6379> smembers interkey1) "c"#獲取3個(gè)集合中的成員的并集。 redis 127.0.0.1:6379> sunion set:test set:test2 set:test31) "b"2) "c"3) "d"4) "e"5) "a"#將3個(gè)集合中成員的并集存儲(chǔ)到unionkey關(guān)聯(lián)的set中,并返回并集成員的數(shù)量。redis 127.0.0.1:6379> sunionstore unionkey set:test set:test2 set:test3(integer) 5#查看一下suiionstore的操作結(jié)果。redis 127.0.0.1:6379> smembers unionkey1) "b"2) "c"3) "d"4) "e"5) "a"32.3.14.?zset (有序集合)
添加到集合
root@netkiller ~ % redis-cli -n 16 127.0.0.1:6379[16]> zadd book 1 "Linux" 1 127.0.0.1:6379[16]> zadd book 2 "Java" 1 127.0.0.1:6379[16]> zadd book 3 "Python" 1 127.0.0.1:6379[16]> zadd book 4 "PHP" 1 127.0.0.1:6379[16]>zrange 查看集合內(nèi)容
127.0.0.1:6379[16]> zrange book 0 -1 withscores 1) "Linux" 2) "1" 3) "Java" 4) "2" 5) "Perl" 6) "5"指定開(kāi)始和結(jié)束范圍
127.0.0.1:6379[16]> zrange book 0 4 Linux Java Python PHP127.0.0.1:6379[16]> zrange book 1 4 Java Python PHP127.0.0.1:6379[16]> zrange book 2 3 Python PHPzrem 刪除集合成員
127.0.0.1:6379[16]> zadd book 5 "Rabby" 1 127.0.0.1:6379[16]> zrange book 4 5 Perl Rabby 127.0.0.1:6379[16]> zrem book Rabby 1 127.0.0.1:6379[16]> zrange book 4 5 Perl127.0.0.1:6379[16]> zrem book PHP Python 2zcard 返回成員數(shù)量
127.0.0.1:6379[16]> zcard book 332.3.15.?Pub/Sub 訂閱與發(fā)布
redis 提供基本的MQ 功能,下面我們做一個(gè)演示
開(kāi)啟第一個(gè)終端窗口,訂閱first second
$ redis-cli redis 127.0.0.1:6379> SUBSCRIBE first second Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "first" 3) (integer) 1 1) "subscribe" 2) "second" 3) (integer) 2開(kāi)啟第二個(gè)終端窗口,分別發(fā)送first second
$ redis-cli redis 127.0.0.1:6379> PUBLISH second Hello (integer) 1 redis 127.0.0.1:6379> PUBLISH first Helloworld!!! (integer) 1 redis 127.0.0.1:6379> quit現(xiàn)在切換到第一個(gè)終端窗口,應(yīng)該能夠看到發(fā)送過(guò)來(lái)的字符串
$ redis-cli redis 127.0.0.1:6379> SUBSCRIBE first second Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "first" 3) (integer) 1 1) "subscribe" 2) "second" 3) (integer) 21) "message" 2) "second" 3) "Hello"1) "message" 2) "first" 3) "Helloworld!!!"32.3.16.?flushdb 清空 Redis 數(shù)據(jù)
root@netkiller ~ % redis-cli 127.0.0.1:6379> flushdb OK 127.0.0.1:6379>
原文出處:Netkiller 系列 手札
本文作者:陳景峯
轉(zhuǎn)載請(qǐng)與作者聯(lián)系,同時(shí)請(qǐng)務(wù)必標(biāo)明文章原始出處和作者信息及本聲明。
總結(jié)
以上是生活随笔為你收集整理的32.3. redis-cli - Command-line client to redis-server的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Activity调用栈的分析
- 下一篇: 剪切板js