Redis中的連接命令與鍵命令操作詳解
一、連接命令
ping
通常用于測試與服務(wù)器的連接是否仍然生效,或者用于測量延遲值。
如果連接正常就返回一個PONG ,否則返回一個連接錯誤。
127.0.0.1:6379> ping PONG
echo m
打印一個特定的信息 m ,測試時使用。
127.0.0.1:6379> echo 'hello world' "hello world"
select i
切換到指定的數(shù)據(jù)庫,數(shù)據(jù)庫索引號 i 用數(shù)字值指定,以 0 作為起始索引值。默認使用 0號數(shù)據(jù)庫。
127.0.0.1:6379> select 1 OK 127.0.0.1:6379[1]>
案例:
在0號數(shù)據(jù)庫中設(shè)置鍵a為‘hello world’,在1號數(shù)據(jù)庫中調(diào)用
127.0.0.1:6379> set a 'hello world' OK 127.0.0.1:6379> select 1 OK 127.0.0.1:6379[1]> get a (nil)
auth pword
開啟了密碼保護,在每次連接 Redis 服務(wù)器之后,就要使用auth命令解鎖,解鎖之后才能使用其他 Redis 命令。密碼匹配時返回 OK
,否則返回一個錯誤。
設(shè)置密碼
127.0.0.1:6379> config set requirepass redis123456 OK #requirepass的值就是密碼 127.0.0.1:6379> quit
在次登錄
[root@localhost redis]# ./src/redis-cli 127.0.0.1:6379> ping (error) NOAUTH Authentication required. 127.0.0.1:6379> auth redis123456 OK 127.0.0.1:6379> ping PONG
清空密碼
127.0.0.1:6379> config set requirepass “” OK #requirepass的值就是密碼 127.0.0.1:6379> quit
quit
請求服務(wù)器關(guān)閉與當前客戶端的連接??偸欠祷?OK
(但是不會被打印顯示,因為當時 Redis-cli 已經(jīng)退出)。
127.0.0.1:6379[1]> quit [root@localhost redis]#
二、鍵命令
set key value
將字符串值 value關(guān)聯(lián)到 key 。
127.0.0.1:6379> set key1 1 #傳入的都是字符串 OK
get key
返回 key所關(guān)聯(lián)的字符串值。如果 key 不存在那么返回特殊值 nil 。
127.0.0.1:6379> get key1 "1"
del key1 [key2 … keyn]
刪除給定的一個或多個 key 。沒有的key忽略,返回被刪除 key 的數(shù)量。
127.0.0.1:6379> del key1 (integer) 1
案例:
聲明key1,key2,key3,刪除key1,key2,key4
127.0.0.1:6379> set key1 1 OK 127.0.0.1:6379> set key2 1 OK 127.0.0.1:6379> set key3 1 OK 127.0.0.1:6379> del key1 key2 key4 (integer) 2
exists key
檢查給定 key 是否存在。若 key 存在,返回 1 ,否則返回 0 。
127.0.0.1:6379> exists key3 (integer) 1
type key
返回 key 所儲存的值的類型。none (key不存在)、string (字符串)、list (列表)、set (集合)、zset (有序集)、hash (哈希表)
127.0.0.1:6379> type key1 string
expire key seconds
為給定 key 設(shè)置生存時間,以秒為單位,當 key 過期時(生存時間為 0 ),它會被自動刪除。設(shè)置成功返回 1 。其他為0。
127.0.0.1:6379> expire key3 30 (integer) 1 127.0.0.1:6379> ttl key3 #查看有效時間 (integer) 24 127.0.0.1:6379> exists key3 #驗證是否存在 (integer) 0
pexpire key mseconds
這個命令和 EXPIRE 命令的作用類似,但是它以毫秒為單位設(shè)置 key 的生存時間,而不像 EXPIRE 命令那樣,以秒為單位。設(shè)置成功,返回 1。key不存在或設(shè)置失敗,返回0
127.0.0.1:6379> set key1 abc OK 127.0.0.1:6379> pexpire key1 10000 (integer) 1 127.0.0.1:6379> ttl key1 (integer) 5 127.0.0.1:6379> pttl key1 (integer) 746
persist key
移除給定 key 的生存時間,將這個 key 從易失的轉(zhuǎn)換成持久的。當生存時間移除成功時,返回 1 .如果 key 不存在或 key 沒有設(shè)置生存時間,返回 0 。
127.0.0.1:6379> set zhangwu 1 OK 127.0.0.1:6379> persist zhangwu (integer) 0 127.0.0.1:6379> expire zhangwu 30 (integer) 1 127.0.0.1:6379> persist zhangwu (integer) 1 127.0.0.1:6379> ttl zhangwu (integer) -1
ttl key
以秒為單位,返回給定 key 的剩余生存時間(TTL, time to live)。當 key 不存在時,返回 -2 。當 key 存在但沒有設(shè)置剩余生存時間時,返回 -1 。
127.0.0.1:6379> set key1 helloworld OK 127.0.0.1:6379> ttl key1 (integer) -1 127.0.0.1:6379> expire key1 50 (integer) 1 127.0.0.1:6379> ttl key1 (integer) 44 127.0.0.1:6379> ttl key1 (integer) -2
pttl key
這個命令類似于 TTL 命令,但它以毫秒為單位返回 key 的剩余生存時間,而不是像 TTL 命令那樣,以秒為單位。當 key 不存在時,返回 -2 。當 key 存在但沒有設(shè)置剩余生存時間時,返回 -1 。
127.0.0.1:6379> pttl key1 (integer) -2 127.0.0.1:6379> set key1 abc OK 127.0.0.1:6379> pexpire key1 30000 (integer) 1 127.0.0.1:6379> pttl key1 (integer) 27345
keys pattern
查找所有符合給定模式 pattern 的 key 。符合給定模式的 key 列表。
通配符
* 表示多個字符 ? 表示一個字符 [] 表示只能是[]里面的字符 \ 表示指定特殊字符 127.0.0.1:6379> mset zhangsan 1 zhangsi 2 zhangwu 3 OK 127.0.0.1:6379> keys * 1) "zhangwu" 2) "zhangsan" 3) "zhangsi" 127.0.0.1:6379> keys ng* (empty list or set) 127.0.0.1:6379> keys *ng* 1) "zhangwu" 2) "zhangsan" 3) "zhangsi" 127.0.0.1:6379> keys zhang?? 1) "zhangwu" 2) "zhangsi" 127.0.0.1:6379> keys zha[ng]si (empty list or set) 127.0.0.1:6379> keys zhan[ng]si 1) "zhangsi"
move key db
將當前數(shù)據(jù)庫的 key 移動到給定的數(shù)據(jù)庫 db 當中。移動成功返回 1 ,失敗則返回 0 。
127.0.0.1:6379> keys * 1) "zhangwu" 2) "zhangsan" 3) "zhangsi" 127.0.0.1:6379> select 1 OK 127.0.0.1:6379[1]> keys * (empty list or set) 127.0.0.1:6379[1]> select 0 OK 127.0.0.1:6379> move zhangsan 1 (integer) 1 127.0.0.1:6379> select 1 OK 127.0.0.1:6379[1]> keys * 1) "zhangsan" 127.0.0.1:6379[1]> select 0 OK 127.0.0.1:6379> keys * 1) "zhangwu" 2) "zhangsi"
注意:
key不存在時,移動失敗
key移動到1庫時,1庫中出現(xiàn)同名的key,移動失敗
random key
從當前數(shù)據(jù)庫中隨機返回(不刪除)一個 key 。當數(shù)據(jù)庫不為空時,返回一個 key 。當數(shù)據(jù)庫為空時,返回 nil 。
127.0.0.1:6379> randomkey "zhangwu" 127.0.0.1:6379> randomkey "key" 127.0.0.1:6379> randomkey "key" 127.0.0.1:6379> randomkey "zhangwu"
rename key newkey
將 key 改名為 newkey 。改名成功時提示 OK ,失敗時候返回一個錯誤。
127.0.0.1:6379> rename key key1 OK 127.0.0.1:6379> keys * 1) "key1" 2) "zhangwu" 3) "zhangsi"
注意:
當 key 和 newkey 相同,或者 key 不存在時,返回一個錯誤。
當 newkey 已經(jīng)存在時, RENAME 命令將覆蓋舊值。
renamenx key newkey
當且僅當 newkey 不存在時,將 key 改名為 newkey 。修改成功時,返回 1 。如果 newkey 已經(jīng)存在,返回 0 。
127.0.0.1:6379> renamenx zhangsi zhangwu (integer) 0 127.0.0.1:6379> renamenx zhangsi zhangsan (integer) 1 127.0.0.1:6379> keys * 1) "zhangsan" 2) "key1" 3) "zhangwu"
以上就是Redis中的連接命令與鍵命令操作詳解的詳細內(nèi)容,更多關(guān)于Redis連接命令與鍵命令的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
解讀Redis秒殺優(yōu)化方案(阻塞隊列+基于Stream流的消息隊列)
該文章介紹了使用Redis的阻塞隊列和Stream流的消息隊列來優(yōu)化秒殺系統(tǒng)的方案,通過將秒殺流程拆分為兩條流水線,使用Redis緩存緩解數(shù)據(jù)庫壓力,并結(jié)合Lua腳本進行原子性判斷,使用阻塞隊列和消息隊列異步處理訂單,有效提高了系統(tǒng)的并發(fā)處理能力和可用性2025-02-02Redis+PHP實現(xiàn)用戶消息推送每天最多通知2次的功能
在開發(fā)應(yīng)用程序中,經(jīng)常需要向用戶推送消息通知,但是為了避免過多的打擾用戶,我們希望限制每天最多通知2次,本篇博文將介紹如何使用PHP和Redis實現(xiàn)這一功能,文中有詳細的代碼示例,需要的朋友可以參考下2023-10-10Satoken+Redis實現(xiàn)短信登錄、注冊、鑒權(quán)功能
這篇文章主要介紹了Satoken+Redis實現(xiàn)短信登錄、注冊、鑒權(quán)功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01基于Redis緩存數(shù)據(jù)常見的三種問題及解決
這篇文章主要介紹了基于Redis緩存數(shù)據(jù)常見的三種問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06