ZBLOG

这种写法太慢了

如果你需要高效地批量删除大量的 Redis 键,可以考虑使用 Redis 的 SCAN 命令来批量迭代并删除键。这种方式可以减少网络交互次数,提高删除效率。

以下是一个示例代码:

import (
    "github.com/go-redis/redis/v8"
)

func DeleteKeys(client *redis.Client, pattern string) error {
    var cursor uint64 = 0
    batchSize := 1000

    for {
        keys, newCursor, err := client.Scan(context.Background(), cursor, pattern, batchSize).Result()
        if err != nil {
            return err
        }

        if len(keys) > 0 {
            _, err := client.Del(context.Background(), keys...).Result()
            if err != nil {
                return err
            }
        }

        cursor = newCursor
        if cursor == 0 {
            break
        }
    }

    return nil
}

在上述代码中,我们使用 SCAN 命令进行批量迭代获取满足给定模式(pattern)的键,并设置了每次迭代返回的键数量为 batchSize。然后,我们通过一次性调用 DEL 命令来删除获取到的所有键。

请注意,在批量删除时要小心控制批处理大小,以避免对 Redis 服务器造成过大的负载压力。你可以根据实际情况调整 batchSize 的值。

希望这种方法能够提高删除效率!如有其他问题,请随时提问。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=13576

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?