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是否存在,如果一個(gè)都匹配不到會(huì)報(bào)錯(cuò):
ERR wrong number of arguments for 'del' command
當(dāng)然,如果要直接在linux里面操作的話,在命令行執(zhí)行以下命令:
redis-cli keys "keys" | xargs redis-cli del
keys 是要匹配的規(guī)則,和上面的prex一樣。
補(bǔ)充知識(shí):Redis怎么用 - (一)基礎(chǔ)命令介紹、常見應(yīng)用場景說明
最新穩(wěn)定版本5.x
官方文檔:https://redis.io/documentation
登錄數(shù)據(jù)庫
遠(yuǎn)程連接命令:redis-cli -h host -p port -n database -a password
示例: redis-cli -h xxx.com -p 8879 -n 14 -a pwd
-n表示登錄的數(shù)據(jù)庫索引號(hào)
默認(rèn)端口號(hào):6379
基本操作
命令 | 示例 | 用途 |
---|---|---|
get | get $key | 獲取某個(gè)緩存項(xiàng)的值 |
set | set $key $value | 為某個(gè)緩存項(xiàng)賦值 * 若該項(xiàng)已存在,新值會(huì)覆蓋原值 * 若該緩存項(xiàng)之前設(shè)置了生存時(shí)間,set命令執(zhí)行后會(huì)清除之前設(shè)定的生存時(shí)間 |
expire | expire $key $seconds | 設(shè)置某個(gè)緩存項(xiàng)的生存時(shí)間(幾秒后過期) * 要設(shè)置ms,可使用pexpire |
ttl | ttl $key | 獲取某個(gè)緩存項(xiàng)的剩余生存時(shí)間(秒) * 要獲取ms,可使用pttl * 返回-1表示永久有效,-2表示已過期 |
setex | setex $key $seconds $value | 設(shè)置某個(gè)緩存項(xiàng)的值,并指定生存時(shí)間(秒) * 原子操作 * 可用于分布式鎖實(shí)現(xiàn) * 等同于set + expire,但后者不是原子操作 |
setnx | setnx $key $value | setnx = set if not exist 當(dāng)某個(gè)緩存項(xiàng)不存在時(shí),設(shè)置其為指定值;若該緩存項(xiàng)已存在,則不做操作 * 原子操作 * 如果key不存在就執(zhí)行set創(chuàng)建,并返回1;否則返回0 |
del | del $key | 刪除指定緩存項(xiàng) |
原子計(jì)數(shù)
Redis提供了幾個(gè)對緩存值進(jìn)行運(yùn)算的命令、且這些命令底層是原子操作(類似Java的AtomicLong)、不需要擔(dān)心并發(fā)問題,因?yàn)樵撎匦?、原子技術(shù)在并發(fā)控制上有較多應(yīng)用。
Redis數(shù)字值范圍為 64 位(bit)有符號(hào)數(shù)字,等同于signed long
計(jì)數(shù)命令實(shí)際上操作的是字符串,因?yàn)镽edis沒有專用的整數(shù)類型,緩存值在執(zhí)行計(jì)數(shù)命令時(shí)、會(huì)解釋為十進(jìn)制64位有符號(hào)整數(shù)
命令 | 示例 | 用途 |
---|---|---|
set | set $key $integer | 使用set命令直接設(shè)置數(shù)字值 |
incr | incr $key | 將緩存項(xiàng)的值加1,并返回加1后的值 * 該項(xiàng)不存在,則先設(shè)為0、再加1 * 該項(xiàng)已存在、但值不是數(shù)字,返回錯(cuò)誤 (error) ERR value is not an integer or out of range |
incrby | incrby $key $integer | 將緩存項(xiàng)的值加指定數(shù)字,并返回增加后的值。 其他特性與incr相同 |
decr | decr $key | 將緩存項(xiàng)的值減1,并返回減1后的值 其他特性與incr相同 |
decrby | decrby $key $integer | 將緩存項(xiàng)的值減指定數(shù)字,并返回減去后的值。 其他特性與incr相同 |
原子計(jì)數(shù)有兩種主要應(yīng)用場景:
分布式鎖
incr $key返回1,認(rèn)為是爭搶到鎖;其他值為失敗
未獲取鎖,或獲取鎖成功處理業(yè)務(wù)后,要decr;
可能遇到的問題:
decr未執(zhí)行怎么辦?即使加了finally,也可能程序宕機(jī)或斷電,導(dǎo)致redis里值永遠(yuǎn)不更新,所有線程都被鎖住
如果加了expires,如果任務(wù)還未完成緩存到期了,鎖就失效了
秒殺庫存控制
一直decr,小于0后表示未秒殺到;如果發(fā)生取消訂單、庫存通過incr增加
緩存減掉后,創(chuàng)建數(shù)據(jù)庫訂單扣減庫存報(bào)錯(cuò)的話,緩存和數(shù)據(jù)庫數(shù)量不一致
因此異常處理時(shí)要記得調(diào)用incr
秒殺和分布式鎖相關(guān)還有很多要考慮,另行組織文章分享
批量操作
命令 | 示例 | 用途 |
---|---|---|
mget | mget $key1 $key2 . . . | 批量獲取緩存值 |
keys | keys rex | 按正則表達(dá)式過濾緩存鍵,列出匹配的緩存項(xiàng) 數(shù)據(jù)量大的時(shí)候性能很差 |
scan | scan ${cursor} match ${rex} count ${limit} eg. scan 0 match key99* count 1000 | 漸進(jìn)式遍歷鍵 * 遍歷完成會(huì)返回游標(biāo)0 |
del | del $key | 刪除指定緩存項(xiàng) |
`` | `` | |
`` | `` |
批量刪需自行實(shí)現(xiàn):
可用redis-cli+lua腳本實(shí)現(xiàn)批量模糊化刪除:redis-cli eval "redis.call('del', unpack(redis.call('keys','$pattern')))" 0
維護(hù)
flushdb:清除當(dāng)前數(shù)據(jù)庫的所有Key
info:查看服務(wù)器情況
查看連接數(shù):info clients
查看鏈接列表:CLIENT LIST
kill指定鏈接:CLIENT KILL ip:port
以上這篇Java使用RedisTemplate模糊刪除key操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java異常處理中同時(shí)有finally和return語句的執(zhí)行問題
這篇文章主要介紹了Java異常處理中同時(shí)有finally和return語句的執(zhí)行問題,首先確定的是一般finally語句都會(huì)被執(zhí)行...然后,需要的朋友可以參考下2015-11-11spring boot jar部署控制臺(tái)日志亂碼的解決
這篇文章主要介紹了spring boot jar部署控制臺(tái)日志亂碼的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09MyBatis-Plus+達(dá)夢數(shù)據(jù)庫實(shí)現(xiàn)高效數(shù)據(jù)持久化的示例
這篇文章主要介紹了MyBatis-Plus和達(dá)夢數(shù)據(jù)庫實(shí)現(xiàn)高效數(shù)據(jù)持久化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08mybatis一級(jí)緩存和二級(jí)緩存的區(qū)別及說明
這篇文章主要介紹了mybatis一級(jí)緩存和二級(jí)緩存的區(qū)別及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11IDEA創(chuàng)建父項(xiàng)目和子項(xiàng)目的實(shí)現(xiàn)步驟
本文主要介紹了IDEA創(chuàng)建父項(xiàng)目和子項(xiàng)目的實(shí)現(xiàn)步驟,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07