go-common/app/job/main/vip/dao/memcache.go
2019-04-22 18:49:16 +08:00

214 lines
4.7 KiB
Go

package dao
import (
"context"
"fmt"
"strconv"
"go-common/app/job/main/vip/model"
"go-common/library/cache/memcache"
"go-common/library/log"
"github.com/pkg/errors"
)
const (
_vipInfo = "vo:%d"
_vipMadel = "madel:%d"
_vipbuy = "vipbuy:%d"
_vipfrozen = "vipfrozen:%d"
madelExpired = 3600 * 24 * 15
vipbuyExpired = 3600 * 24 * 8
vipFrozenExpired = 60 * 30
vipFrozenFlag = 1
_prefixInfo = "i:"
)
func vipfrozen(mid int64) string {
return fmt.Sprintf(_vipfrozen, mid)
}
func vipbuy(mid int64) string {
return fmt.Sprintf(_vipbuy, mid)
}
func vipInfoKey(mid int64) string {
return fmt.Sprintf(_vipInfo, mid)
}
func vipMadel(mid int64) string {
return fmt.Sprintf(_vipMadel, mid)
}
func keyInfo(mid int64) string {
return _prefixInfo + strconv.FormatInt(mid, 10)
}
//SetVipFrozen .
func (d *Dao) SetVipFrozen(c context.Context, mid int64) (err error) {
var (
key = vipfrozen(mid)
)
conn := d.mc.Get(c)
defer conn.Close()
item := &memcache.Item{Key: key, Object: vipFrozenFlag, Expiration: vipFrozenExpired, Flags: memcache.FlagJSON}
if err = conn.Set(item); err != nil {
err = errors.Wrapf(err, "d.setVipFrozen")
d.errProm.Incr("vip frozen_mc")
return
}
return
}
//DelVipFrozen .
func (d *Dao) DelVipFrozen(c context.Context, mid int64) (err error) {
return d.delCache(c, vipfrozen(mid))
}
//SetVipMadelCache set vip madel cache
func (d *Dao) SetVipMadelCache(c context.Context, mid int64, val int64) (err error) {
var (
key = vipMadel(mid)
)
conn := d.mc.Get(c)
defer conn.Close()
item := &memcache.Item{Key: key, Object: val, Expiration: madelExpired, Flags: memcache.FlagJSON}
if err = conn.Set(item); err != nil {
err = errors.Wrap(err, "d.SetVipMadelCache")
d.errProm.Incr("vipmadel_mc")
}
return
}
//GetVipBuyCache get vipbuy cache by key
func (d *Dao) GetVipBuyCache(c context.Context, mid int64) (val int64, err error) {
var (
key = vipbuy(mid)
item *memcache.Item
)
conn := d.mc.Get(c)
defer conn.Close()
if item, err = conn.Get(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
err = errors.Wrapf(err, "conn.Get(%s)", key)
d.errProm.Incr("vipinfo_mc")
return
}
if err = conn.Scan(item, &val); err != nil {
err = errors.WithStack(err)
d.errProm.Incr("vipMadelCache_mc")
}
return
}
//SetVipBuyCache set vipbuy cache
func (d *Dao) SetVipBuyCache(c context.Context, mid int64, val int64) (err error) {
var (
key = vipbuy(mid)
)
conn := d.mc.Get(c)
defer conn.Close()
item := &memcache.Item{Key: key, Object: val, Expiration: vipbuyExpired, Flags: memcache.FlagJSON}
if err = conn.Set(item); err != nil {
err = errors.Wrap(err, "d.SetVipBuyCache")
d.errProm.Incr("vipbuy_mc")
}
return
}
//GetVipMadelCache get madel info by mid
func (d *Dao) GetVipMadelCache(c context.Context, mid int64) (val int64, err error) {
var (
key = vipMadel(mid)
item *memcache.Item
)
conn := d.mc.Get(c)
defer conn.Close()
if item, err = conn.Get(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
err = errors.Wrapf(err, "conn.Get(%s)", key)
d.errProm.Incr("vipinfo_mc")
return
}
if err = conn.Scan(item, &val); err != nil {
err = errors.WithStack(err)
d.errProm.Incr("vipMadelCache_mc")
}
return
}
// SetVipInfoCache set vip info cache.
func (d *Dao) SetVipInfoCache(c context.Context, mid int64, v *model.VipInfo) (err error) {
var (
key = vipInfoKey(mid)
)
conn := d.mc.Get(c)
defer conn.Close()
item := &memcache.Item{Key: key, Object: v, Expiration: d.mcExpire, Flags: memcache.FlagProtobuf}
if err = conn.Set(item); err != nil {
err = errors.Wrap(err, "d.SetVipInfo")
d.errProm.Incr("vipinfo_mc")
}
return
}
// DelVipInfoCache del vip info cache.
func (d *Dao) DelVipInfoCache(c context.Context, mid int64) (err error) {
err = d.delCache(c, vipInfoKey(mid))
return
}
// DelInfoCache del vip info cache.
func (d *Dao) DelInfoCache(c context.Context, mid int64) (err error) {
if err = d.delCache(c, keyInfo(mid)); err != nil {
log.Error("del vipinfo cache(mid:%d) error(%+v)", mid, err)
}
return
}
func (d *Dao) delCache(c context.Context, key string) (err error) {
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
} else {
err = errors.Wrapf(err, "conn.Delete(%s)", key)
d.errProm.Incr("del_mc")
}
}
return
}
// AddTransferLock add lock.
func (d *Dao) AddTransferLock(c context.Context, key string) (succeed bool) {
var (
conn = d.mc.Get(c)
)
defer conn.Close()
item := &memcache.Item{
Key: key,
Value: []byte("0"),
Expiration: 3600,
}
if err := conn.Add(item); err != nil {
if err != memcache.ErrNotStored {
log.Error("conn.Add(%s) error(%v)", key, err)
}
} else {
succeed = true
}
return
}