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)用場(chǎ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è)對(duì)緩存值進(jìn)行運(yùn)算的命令、且這些命令底層是原子操作(類似Java的AtomicLong)、不需要擔(dān)心并發(fā)問題,因?yàn)樵撎匦浴⒃蛹夹g(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)用場(chǎ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è)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
