登录
首页 >  Golang >  Go问答

读取整个数据的Redis/Golang客户端

来源:stackoverflow

时间:2024-03-11 22:09:22 346浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《读取整个数据的Redis/Golang客户端》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

问题内容

我有一个 redis 部署作为缓存层。缓存不是很大,我们希望从 golang 程序中一次读取所有项目(键/值)。我找到的唯一解决方案是迭代所有主服务器(它是一个 redis 集群),执行扫描以获取所有键,然后迭代键以获取值。

err := cch.client.ForEachMaster(func(cl *redis.Client) error {
    wg.Add(1)
    defer wg.Done()
    var cursor uint64
    var n int
    numFor := 0
    for {

        var keys []string
        var err error
        keys, cursor, err = cl.Scan(cursor, "*", 10).Result()
        if err != nil {
            panic(err)
        }
        n += len(keys)

        for _, keyval := range keys {
            var cont Content
            if err := cch.items.Get(keyval, &cont); err == nil {

            } else {
                log.Warnf("Error getting Key %s from cache: %s from master %s", keyval, err)
            }
        }

        if cursor == 0 {
            break
        }
    }
    return nil
})
wg.Wait()

有更好的方法吗?不敢相信我需要这么多次往返 redis 才能获取值。谢谢!


解决方案


1) 您可以使用KEYS命令获取所有密钥,然后访问每个密钥。但在某些情况下,这不是推荐的方式,因为大量缓存上的 KEYS 会导致 Redis 服务器中的长时间阻塞。但如果您只有一个很小的缓存,那么 KEYS 是您可以使用的简单而优雅的命令。

2) 您还可以使用 HSET 命令将相关键推送到哈希中。因此,您可以使用 HGETALL 立即获取这些键值。这样可以让你的缓存变得好看。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>