记一次golang读取redis缓存,统计日活的过程

最近有一个需求是从redis缓存中读取日活,redis缓存中保存着每天每个游戏的日活与局数,类型是hashset,key是$game_id:$log_date,value是玩家ID以及对应的局数,结构如下:

34e438852ad5d721740544701dca62e796f.jpg

表示在2018-07-18日,game_id=1的游戏的日活与对应局数如下:

user_id局数
12
23
34
45

虽然能够知道所有的game_id,但是有些游戏可能没有日活,,一个一个game_id去取日活效率不是很高,所以可以执行redis的keys命令来获取有日活的所有key:

c6bc2caf5df617465c17f915956f7e71664.jpg

然后遍历每个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)
	}
}

对应的输出如下:

04d458fc0da34bbfce84d7a58a36a86cc7d.jpg

转载于:https://my.oschina.net/u/3400816/blog/1914936

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值