您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關如何在Java中使用RedisTemplate實現刪除key,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
Redis模糊匹配批量刪除操作,使用RedisTemplate操作:
public void deleteByPrex(String prex) { Set<String> keys = redisTemplate.keys(prex); if (CollectionUtils.isNotEmpty(keys)) { redisTemplate.delete(keys); } }
prex為迷糊匹配的key,如cache:user:*
這里需要判斷keys是否存在,如果一個都匹配不到會報錯:
ERR wrong number of arguments for 'del' command
當然,如果要直接在linux里面操作的話,在命令行執行以下命令:
redis-cli keys "keys" | xargs redis-cli del
keys 是要匹配的規則,和上面的prex一樣。
補充知識:Redis怎么用 - (一)基礎命令介紹、常見應用場景說明
最新穩定版本5.x
官方文檔:https://redis.io/documentation
登錄數據庫
遠程連接命令:redis-cli -h host -p port -n database -a password
示例: redis-cli -h xxx.com -p 8879 -n 14 -a pwd
-n表示登錄的數據庫索引號
默認端口號:6379
基本操作
命令 | 示例 | 用途 |
---|---|---|
get | get $key | 獲取某個緩存項的值 |
set | set $key $value | 為某個緩存項賦值 * 若該項已存在,新值會覆蓋原值 * 若該緩存項之前設置了生存時間,set命令執行后會清除之前設定的生存時間 |
expire | expire $key $seconds | 設置某個緩存項的生存時間(幾秒后過期) * 要設置ms,可使用pexpire |
ttl | ttl $key | 獲取某個緩存項的剩余生存時間(秒) * 要獲取ms,可使用pttl * 返回-1表示永久有效,-2表示已過期 |
setex | setex $key $seconds $value | 設置某個緩存項的值,并指定生存時間(秒) * 原子操作 * 可用于分布式鎖實現 * 等同于set + expire,但后者不是原子操作 |
setnx | setnx $key $value | setnx = set if not exist 當某個緩存項不存在時,設置其為指定值;若該緩存項已存在,則不做操作 * 原子操作 * 如果key不存在就執行set創建,并返回1;否則返回0 |
del | del $key | 刪除指定緩存項 |
原子計數
Redis提供了幾個對緩存值進行運算的命令、且這些命令底層是原子操作(類似Java的AtomicLong)、不需要擔心并發問題,因為該特性、原子技術在并發控制上有較多應用。
Redis數字值范圍為 64 位(bit)有符號數字,等同于signed long
計數命令實際上操作的是字符串,因為Redis沒有專用的整數類型,緩存值在執行計數命令時、會解釋為十進制64位有符號整數
命令 | 示例 | 用途 |
---|---|---|
set | set $key $integer | 使用set命令直接設置數字值 |
incr | incr $key | 將緩存項的值加1,并返回加1后的值 * 該項不存在,則先設為0、再加1 * 該項已存在、但值不是數字,返回錯誤 (error) ERR value is not an integer or out of range |
incrby | incrby $key $integer | 將緩存項的值加指定數字,并返回增加后的值。 其他特性與incr相同 |
decr | decr $key | 將緩存項的值減1,并返回減1后的值 其他特性與incr相同 |
decrby | decrby $key $integer | 將緩存項的值減指定數字,并返回減去后的值。 其他特性與incr相同 |
原子計數有兩種主要應用場景:
分布式鎖
incr $key返回1,認為是爭搶到鎖;其他值為失敗
未獲取鎖,或獲取鎖成功處理業務后,要decr;
可能遇到的問題:
decr未執行怎么辦?即使加了finally,也可能程序宕機或斷電,導致redis里值永遠不更新,所有線程都被鎖住
如果加了expires,如果任務還未完成緩存到期了,鎖就失效了
秒殺庫存控制
一直decr,小于0后表示未秒殺到;如果發生取消訂單、庫存通過incr增加
緩存減掉后,創建數據庫訂單扣減庫存報錯的話,緩存和數據庫數量不一致
因此異常處理時要記得調用incr
秒殺和分布式鎖相關還有很多要考慮,另行組織文章分享
批量操作
命令 | 示例 | 用途 |
---|---|---|
mget | mget $key1 $key2 . . . | 批量獲取緩存值 |
keys | keys rex | 按正則表達式過濾緩存鍵,列出匹配的緩存項 數據量大的時候性能很差 |
scan | scan ${cursor} match ${rex} count ${limit} eg. scan 0 match key99* count 1000 | 漸進式遍歷鍵 * 遍歷完成會返回游標0 |
del | del $key | 刪除指定緩存項 |
`` | `` | |
`` | `` |
批量刪需自行實現:
可用redis-cli+lua腳本實現批量模糊化刪除:redis-cli eval "redis.call('del', unpack(redis.call('keys','$pattern')))" 0
維護
flushdb:清除當前數據庫的所有Key
info:查看服務器情況
查看連接數:info clients
查看鏈接列表:CLIENT LIST
kill指定鏈接:CLIENT KILL ip:port
以上就是如何在Java中使用RedisTemplate實現刪除key,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。