生产Redis批量删除数据

生产Redis不能直接删除大量的Key,避免占用主线程阻塞正常业务,因此需要批量多次删除。一下代码经过生成磨炼,可以直接测试使用。

bash 复制代码
#!/bin/bash

# Redis服务器地址
REDIS_HOST="127.0.0.1"
# Redis端口
REDIS_PORT=6379
# 匹配的键模式
KEY_PATTERN="ACCOUNT_OVER*"
# 每批次处理的键数量
BATCH_SIZE=1000

# 使用redis-cli连接到Redis服务
redis_cli="redis-cli -h $REDIS_HOST -p $REDIS_PORT -a redis -c"

# 初始化游标
cursor=0

while true; do
    # 执行SCAN命令获取一批键
    keys=$($redis_cli --raw SCAN $cursor MATCH "$KEY_PATTERN" COUNT $BATCH_SIZE)
    
    # 检查是否成功执行了SCAN命令
    if [ $? -ne 0 ]; then
        echo "Failed to execute SCAN command, exiting..."
        exit 1
    fi
    
    # 分割输出以获得新游标值和其他键
    readarray -t parts <<< "$keys"
    cursor=${parts[0]}
    unset parts[0]
    
    # 如果没有更多键,则退出循环
    if [ ${#parts[@]} -eq 0 ]; then
        break
    fi
    
    # 将键列表转换为适合UNLINK命令使用的格式
    # key_list=$(printf ' "%s"' "${parts[@]}")
    # key_list="${key_list:1}"  # 去掉第一个多余的空格
    
    # 删除这批键
    # if ! $redis_cli UNLINK $key_list; then
    #    echo "Failed to delete keys, exiting..."
    #    exit 1
    # fi

    # 逐个删除键
    for key in "${parts[@]}"; do
        if ! $redis_cli UNLINK "$key"; then
            echo "Failed to delete key: $key, exiting..."
            exit 1
        fi
    done

    echo "Deleted a batch of keys, new cursor is $cursor"
    
    # 可选:这里可以添加延迟,以便控制删除速度
    sleep 1
done

echo "All matching keys have been deleted."

有用点赞,收藏,谢谢!

相关推荐
艾德金的溪2 小时前
redis-7.4.6部署安装
前端·数据库·redis·缓存
东城绝神3 小时前
《Linux运维总结:基于ARM64+X86_64架构CPU使用docker-compose一键离线部署redis 7.4.5容器版分片集群》
linux·运维·redis·架构·分片集群
我的offer在哪里4 小时前
Redis
数据库·redis·缓存
阿维的博客日记7 小时前
从夯到拉的Redis和MySQL双写一致性解决方案排名
redis·分布式·mysql
好玩的Matlab(NCEPU)7 小时前
Redis vs RabbitMQ 对比总结
数据库·redis·rabbitmq
en-route7 小时前
基于 Redis 的基数统计:高效的大规模去重与计数
redis·基数统计
深圳蔓延科技7 小时前
Redis,什么是缓存穿透/击穿/雪崩,如何解决它们
redis
蹦跑的蜗牛8 小时前
Spring Boot使用Redis实现消息队列
spring boot·redis·后端
馍馍菜10 小时前
Redis Insight黑屏,页面空白
redis·redis insight
你想考研啊14 小时前
二、redis集群部署(3主3从)
数据库·redis·缓存