python批量删除redis key

生产环境中要禁止使用keys *查询key, 因为redis低版本是单线程,如果key非常多的话,直接使用keys *会导致阻塞,所以应当使用scan命令,scan命令介绍请参考其他文档。

python 复制代码
# -*- coding: utf-8 -*-
# @Time    : 2025/01/09
# @Author  : 养乐多
# @Mail    : oct_hao@163.com
# @File    : redis_del_keys.py
# @Use     : 利用scan命令批量删除redis key


import redis


class Redis:
    def __init__(self, host, port, db=0):
        '''
        初始化redis连接
        :param host: redis host
        :param port: redis port
        :param db: redis db
        '''
        self.redis_host = host
        self.redis_port = port
        self.redis_db = db
        try:
            # 连接redis
            self.redis_client = self._connect()
        except Exception as e:
            print('redis连接失败', e)

    def _connect(self):
        '''
        连接redis
        '''
        return redis.StrictRedis(host=self.redis_host, port=self.redis_port, db=self.redis_db)

    def _close(self):
        '''
        关闭redis连接
        '''
        self.redis_client.close()

    def batch_delete_keys(self, pattern, batch_size=1000):
        """
        使用 SCAN 命令批量删除匹配给定模式的 Redis 键
        :param pattern: 要删除的键的模式
        :param batch_size: 每次扫描时的键的批量大小
        """
        # 初始化游标
        cursor = 0 

        while True:
            # 使用 SCAN 命令遍历键
            cursor, keys = self.redis_client.scan(cursor=cursor, match=pattern, count=batch_size)
            # 删除匹配的键
            if keys:
                self.redis_client.delete(*keys)
                print('删除了%s个key' % len(keys))
            else:
                break

            if cursor == 0:
                break

        self._close()
    
    def get_all_key_count(self, pattern, batch_size=1000):
        '''
        使用 SCAN 命令批量删除匹配给定模式的 Redis 键
        :param pattern: 要删除的键的模式
        :param batch_size: 每次扫描时的键的批量大小
        '''
        # 初始化游标
        cursor = 0
        # 初始化计数器
        count = 0  

        while True:
            # 使用 SCAN 命令遍历键
            cursor, keys = self.redis_client.scan(cursor=cursor, match=pattern, count=batch_size)
            # 统计匹配的键的数量
            if keys:
                count += len(keys)
            else:
                break

            if cursor == 0:
                break

        self._close()
        return count

if __name__ == "__main__":
    redis_host = '172.30.11.132'
    redis_port = 6379
    redis_db = 0
    pattern = '*123'
    batch_size = 1000

    # 连接到 Redis
    r = Redis(redis_host, redis_port, redis_db)
    # 查询key总数
    print(r.get_all_key_count(pattern=pattern, batch_size=batch_size))
    # 删除key
    # r.batch_delete_keys(pattern=pattern, batch_size=batch_size)
相关推荐
blues_C11 分钟前
Pytest-Bdd-Playwright 系列教程(完结篇):本框架的功能参数说明
自动化测试·python·pytest·测试框架·bdd
nvvas15 分钟前
Pytest安装Allure生成自动化测试报告
python·测试工具·pytest
Bruce-li__1 小时前
django解决跨域问题
后端·python·django
qq_273900231 小时前
pytorch torch.isclose函数介绍
人工智能·pytorch·python
生信与遗传解读2 小时前
XGBoost算法在自定义数据集中预测疾病风险
人工智能·python·算法·数据分析
程序员谷美2 小时前
Redis 性能优化:利用 MGET 和 Pipeline 提升效率
java·redis·性能优化
代码代码快快显灵3 小时前
Redis 优化秒杀(异步秒杀)
数据库·redis·缓存
一条小小yu3 小时前
java 从零开始手写 redis(六)redis AOF 持久化原理详解及实现
java·redis·spring
极客先躯3 小时前
Redis 安装与配置指南
数据库·redis·数据验证·安装说明·编译和安装·redis 集群配置·查看集群
小湿哥3 小时前
RedisDB双机主从同步性能测试
redis·nosql·性能测试·同步性能