最近有一个需求是从redis缓存中读取日活,redis缓存中保存着每天每个游戏的日活与局数,类型是hashset,key是$game_id:$log_date,value是玩家ID以及对应的局数,结构如下:
表示在2018-07-18日,game_id=1的游戏的日活与对应局数如下:
user_id | 局数 |
1 | 2 |
2 | 3 |
3 | 4 |
4 | 5 |
虽然能够知道所有的game_id,但是有些游戏可能没有日活,,一个一个game_id去取日活效率不是很高,所以可以执行redis的keys命令来获取有日活的所有key:
然后遍历每个key,调用hgetall命令来获取每个key对应的日活与局数信息,就可以得出每个游戏的日活与局数,对应到golang的代码如下:
import (
"testing"
"github.com/garyburd/redigo/redis"
)
func TestRedis(t *testing.T){
// 连接redis
con,err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
t.Errorf("连接redis出错:err:%v\n", err)
}
defer con.Close()
// 查询所有的keys
cacheName := "*:20180718"
keys,err := redis.Strings(con.Do("keys", cacheName))
for _,key := range keys {
activeInfo,err := redis.IntMap(con.Do("hgetall", key))
if err != nil {
t.Errorf("查询单个key的日活信息出错:err:%v\n", err)
}
t.Logf("key-%v, activeInfo-%+v\n", key, activeInfo)
}
}
对应的输出如下: