bilibili-backup/app/service/main/secure/dao/memcache.go

57 lines
1.3 KiB
Go
Raw Normal View History

2019-04-22 10:59:20 +08:00
package dao
import (
"context"
"strconv"
"go-common/app/service/main/secure/model"
gmc "go-common/library/cache/memcache"
"go-common/library/log"
)
const (
_prefixLocs = "locs_"
)
func locsKey(mid int64) string {
return _prefixLocs + strconv.FormatInt(mid, 10)
}
func (d *Dao) pingMC(c context.Context) (err error) {
conn := d.mc.Get(c)
if err = conn.Set(&gmc.Item{Key: "ping", Value: []byte{1}, Expiration: d.locsExpire}); err != nil {
log.Error("conn.Store(set, ping, 1) error(%v)", err)
}
conn.Close()
return
}
// AddLocsCache add login locs count to cache.
func (d *Dao) AddLocsCache(c context.Context, mid int64, locs *model.Locs) (err error) {
item := &gmc.Item{Key: locsKey(mid), Object: locs, Expiration: d.locsExpire, Flags: gmc.FlagProtobuf}
conn := d.mc.Get(c)
if err = conn.Set(item); err != nil {
log.Error("AddLocs err(%v)", err)
}
conn.Close()
return
}
// LocsCache get login locs count.
func (d *Dao) LocsCache(c context.Context, mid int64) (locs map[int64]int64, err error) {
conn := d.mc.Get(c)
defer conn.Close()
item, err := conn.Get(locsKey(mid))
if err != nil {
if err == gmc.ErrNotFound {
err = nil
}
return
}
loc := &model.Locs{}
if err = conn.Scan(item, loc); err != nil {
log.Error("Locs err(%v)", err)
}
locs = loc.LocsCount
return
}