当前位置: 首页 > article >正文

生产Redis批量删除数据

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

#!/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."

有用点赞,收藏,谢谢!


http://www.kler.cn/a/414554.html

相关文章:

  • spring知识点复习--针对面试的
  • 鼠标前进后退键改双击,键盘映射(AutoHotkey)
  • 微知-git如何添加空目录的几种方式?(.gitkeep, githook, gitconfig)
  • PHP 函数的未来发展有哪些变化呢
  • [MRCTF2020]Transform
  • 电子应用设计方案-28:智能云饭锅系统方案设计
  • 【Maven】Nexus私服
  • 【C++打怪之路Lv16】-- map set
  • 【新人系列】Python 入门(十三):函数进阶
  • 【jvm】什么是动态编译
  • 【金猿案例展】京东物流UData——物流行业数据分析智能体解决方案
  • Perplexica - AI 驱动的搜索引擎
  • 亚马逊反爬二之限流
  • FreeRTOS之链表源码分析
  • Android Studio 使用插件Database Navigation 连接 sqlite数据库
  • PHP学习_1
  • 【通俗理解】Transformer中位置编码与词嵌入的分离
  • GAMES101:现代计算机图形学入门-笔记-09
  • yolov5的pt模型转化为rk3588的rknn,并在rk3588上调用api进行前向推理
  • 鸿蒙启航日志:探索华为科技之旅的第一天
  • 【Bug】el-date-picker组件时间差
  • 23种设计模式-装饰器(Decorator)设计模式
  • Python websocket
  • BC-Linux8.6上面手动安装Postgresql17(Docker版)
  • 永久免费的PDF万能水印删除工具
  • AD软件如何快速切换三维视图,由2D切换至3D,以及如何恢复