Redis常用命令集的使用
更新時間:2023年11月10日 15:07:08 作者:kerwin_code
作為一名Redis開發(fā)者或管理員,熟練掌握Redis的常用命令是必不可少的,本文主要介紹了Redis常用命令集的使用,具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
一、redis-cli連接redis服務
1.1 無密碼本地登錄
# 無密碼登錄 redis-cli # 如果需要驗證可以使用auth命令 127.0.0.1:6379> auth [password] # 例: 127.0.0.1:6379> auth 123456
1.2 指定參數(shù)登錄
這些參數(shù)都是可選的
# 語法 # -h [ip]:指定redis服務ip,不填默認為127.0.0.1 # -p [port]:指定redis服務端口,不填默認為6379 # -a [pwd]:指定redis服務登錄密碼 # -n [db_number]:指定redis庫下標,不填默認0 redis-cli -h [ip] -p [port] -a [pwd] -n [db_number] # 例: redis-cli -h 192.168.0.100 -p 6379 -a 123456 -n 9
1.3 使用shell連接操作redis
這里會直接使用shell腳本操作redis-cli來實現(xiàn)數(shù)據(jù)插入和獲取。
- 編寫shell腳本
#!/bin/bash # 插入數(shù)據(jù) echo '開始連接redis插入數(shù)據(jù)' redis-cli -h 127.0.0.1 -a 123456 -n 9 set name Kerwin # 獲取數(shù)據(jù) redis-cli -h 127.0.0.1 -a 123456 -n 9 get name
二、redis運維常用命令
2.1、查看redis版本信息
[root@kerwin /]# redis-server -v Redis server v=6.0.20 sha=00000000:0 malloc=jemalloc-5.1.0 bits=64 build=22b80d876b6e8f12
或者客戶端輸入:info server
127.0.0.1:6379> info server # Server redis_version:6.0.20 redis_git_sha1:00000000 redis_git_dirty:0 redis_build_id:22b80d876b6e8f12 redis_mode:standalone os:Linux 3.10.0-1160.88.1.el7.x86_64 x86_64 arch_bits:64 multiplexing_api:epoll atomicvar_api:atomic-builtin gcc_version:12.2.0 process_id:1 run_id:fbed0123d026af0f7094190c7ebe9baedfbb8b8e tcp_port:6379 uptime_in_seconds:3269 uptime_in_days:0 hz:10 configured_hz:10 lru_clock:2235721 executable:/data/redis-server config_file:/etc/redis/redis.conf io_threads_active:0
2.2、查看服務所有[部分]信息
使用info [section]查看
- 1、查看所有信息
127.0.0.1:6379> info
- 2、查看具體信息
# 服務器信息 127.0.0.1:6379> info server # 持久化信息 127.0.0.1:6379> info persistence
三、redis庫相關命令
# 切換到1號庫;redis有16個初始化庫,編號0到15,默認使用0號庫 127.0.0.1:6379> select 1 # 查看當前庫的key的數(shù)量 127.0.0.1:6379> dbsize # 刪除當前庫的全部數(shù)據(jù) 127.0.0.1:6379> flushdb # 刪除所有庫的全部數(shù)據(jù) 127.0.0.1:6379> flushall
四、redis key相關命令
# 查看當前庫的全部key keys * # 判斷某個key是否存在,存在返回1,不存在返回0 exists [key] # 查看某個key的類型,如果key不存在,則返回none type [key] # 刪除指定的key數(shù)據(jù),成功返回1,失敗返回0 del [key] # 根據(jù)value選擇非阻塞刪除,僅將keys從keyspace元數(shù)據(jù)中刪除,真正的刪除后在后續(xù)異步操作 unlink [key] # 查看某個key的過期時間,單位(秒),-1表示永不過期,-2表示已經(jīng)過期 ttl [key] # 給指定的key設置過期時間,單位(秒) expire [key] 10
五、redis 字符串相關命令
# 添加一條數(shù)據(jù) 例如set k1 v1,添加key為k1,值為v1的數(shù)據(jù) set <key> <value> # 得到某個key的數(shù)據(jù),例如get k1,得到key為k1的值 get <key> # 將給定的value,追加到某key的原值的末尾,返回追加后的字符長度 append <key> <value> # 查詢某key的值的長度 strlen <key> # 當key不存在的時候,才能添加成功,當key存在的時候,不能添加 setnx <key> <value> # 將某個key的值,數(shù)字增加1,僅僅對數(shù)字起作用,如果為空,新增值為1 incr <key> # 將某個key的值,數(shù)字減少1,僅僅對數(shù)字起作用,如果為空,新增值為-1 decr <key> # 將key中儲存的數(shù)字值增減,自定義步長 incrby/decrby <key> <步長> # 批量添加 mset <key1> <value1> <key2> <value2> # 批量取值 mget <key1> <key2> # 批量添加,當且僅當所有的key都不存在(因為原子性,一個失敗則都失?。? msetnx <key1> <value1> <key2> <value2> # 獲取某個key值的范圍,getrange k1 0 2,包含0位置的元素,和2位置的元素 getrange <key> <起始位置> <結束位置> # 設置鍵值的同時設置過期時間(單位秒) setex <key> <過期時間> <value>: # 設置新值,并返回舊值 getset <key> <value>
六、redis 列表相關命令
# 從左邊,或者右邊添加數(shù)據(jù) lpush/rpush <key> <value1> <value2> <value3> # 從左邊,或者右邊取出一個值,列表里這個值就不存在了 lpop/rpop <key> # 從key1的右邊取一個值,添加在key2的左邊 rpoplpush <key1> <key2> # 按照索引下角標得到元素(從左往右),當結束為值為-1時,代表得到多有,這個值還在列表中 lrange <key> <起始位置> <結束位置> # 按照索引,從左往右獲得對應的值 lindex <key> <index> # 獲得列表長度 llen <key> # 在某個key下的某個值的前面/后面添加一個新的值 linsert <key> before/after <value> <newVlaue> # 刪除某個key下,刪除n個值為value的數(shù)據(jù) lrem <key> <n> <value> # 將某個key下的某個下角標的值換成給定的值 lset <key> <index> <value>
七、redis set集合相關命令
# 添加數(shù)據(jù),如果值已經(jīng)存在,忽略該值 sadd <key> <value1> <value2> <value3> # 獲取集合中元素數(shù)量 scard <key> # 得到集合中所有的值 smembers <key> # 判斷某個key中是否存在value,存在返回1,不存在返回0 scard <key>:返回集合的元素個數(shù) sismember <key> <value> # 刪除某個key中的某些元素 srem <key> <value1> <value2> # 從key中隨機取出一個值,如果值沒了,那么key就不在了 spop <key> # 從某個key中,取出n個值,不會從集合中刪除 srandmember <key> <n> # 把集合中的一個值移動到另一個集合 smove <key1> <key2> <value> # 取兩個集合的交集 sinter <key1> <key2> # 取兩個集合的并集 sunion <key1> <key2> # 取兩個集合的差集(在key1中的,不在key2中的) sdiff <key1> <key2>
八、redis hash相關命令
# 給某個key哈希表中的field鍵復制為value hset <key> <field> <value> # 得到某個key哈希表中某個field的值 hget <key> <field> # 查看key總數(shù) hlen <key> # 批量加數(shù)據(jù) hmset <key> <field1> <value1> <field2> <value2> # 某個key哈希表中某個field是否存在 hexists <key> <field1> # 查看某個key哈希表中的全部field hkeys <key> # 查看某個key哈希表中的全部value hvals <key> # 查看某個key哈希表中全部的key和value hgetall <key> # 為某個key的哈希表中的某個field鍵的值加上響應的增量 hincrby <key> <field> <increment> # 某個key哈希表中的field鍵復制為value,當且僅當key不存在的時候成功 hsetnx <key> <field> <value> # 刪除key中某個field hdel <key> <field>
九、redis 有序集合(Zset)相關命令
# 添加以一個過著多個元素,score為評分,集合按照從低到高及進行排序,評分可以重復 zadd <key> <score1> <value1> <score2> <value2> # 獲取有序集合中成員的數(shù)量 zcard <key> # 統(tǒng)計score評分在某個范圍內的數(shù)據(jù)的數(shù)量 zcount <key> <min> <max> # 查一定范圍的元素,end為-1時,查詢所有,按照分數(shù)從小到大排序,withscores加上他,連著評分一起查出 zrange <key> <start> <end> [LIMIT offset count] [withscores] # 查一定范圍的元素,end為-1時,查詢所有,按照分數(shù)從大到小排序,withscores加上他,連著評分一起查出 zrevrange <key> <start> <end> [LIMIT offset count] [withscores] # 查詢score評分在某個范圍內的數(shù)據(jù),從小到大排序,withscores加上他,連著評分一起查出 zrangebyscore <key> <min> <max> [withscores] # 查詢score評分在某個范圍內的數(shù)據(jù),從大到小排序,withscores加上他,連著評分一起查出 zrevrangebyscore <key> <max> <min> [withscores] # 為元素的score加上指定的增量 zincrby <key> <increment> <value> # 刪除數(shù)據(jù) zrem <key> <value1> <value2> # 返回集合中value的排名,排序從0開始 zrank <key> <value>
到此這篇關于Redis常用命令集的使用的文章就介紹到這了,更多相關Redis 命令集內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
CentOS系統(tǒng)中Redis數(shù)據(jù)庫的安裝配置指南
Redis是一個基于主存存儲的數(shù)據(jù)庫,性能很強,這里我們就來看一下CentOS系統(tǒng)中Redis數(shù)據(jù)庫的安裝配置指南,包括將Redis作為系統(tǒng)服務運行的技巧等,需要的朋友可以參考下2016-06-06基于Redis實現(xiàn)延時隊列的優(yōu)化方案小結
本文主要介紹了基于Redis實現(xiàn)延時隊列的優(yōu)化方案小結,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07