redisで特定のデータを一括で削除、操作をするスクリプト
redisで有効期限が設定されていないセッションデータを一括削除するスクリプト
今回は有効期限が設定されていないデータを削除するscriptを作りました。
シンプルに検索して、eachして、ifでチェックして該当すれば削除を行ってます。
session-delete.lua
redis.call('select', '1') --[[ DBの数字を選んでください ]]
local expresion = 'session*' --[[ 精査対象を正規表現で捉えてください ]]
local delete_count = 0
for _,session_key_id in ipairs(redis.call('keys', expresion))
do
if redis.call('TTL', session_key_id) == -1 then --[[ 有効期限が -1 (未設定)のものを削除します ]]
redis.call('DEL', session_key_id)
delete_count = delete_count + 1
end
end
return 'deleted:'..delete_count
実行方法は簡単
bash
redis-cli eval "$(cat search.lua)" 0
docker環境ならこんな感じで
bash
dc exec imdb redis-cli eval "$(cat search.lua)" 0
Author And Source
この問題について(redisで特定のデータを一括で削除、操作をするスクリプト), 我々は、より多くの情報をここで見つけました https://qiita.com/rorensu2236/items/17a72374313e4626ff30著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .