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

217 lines
5.5 KiB
Go

package fav
import (
"context"
"fmt"
favmdl "go-common/app/service/main/favorite/model"
"go-common/library/cache/memcache"
"go-common/library/log"
"strconv"
)
const (
_folder = "f_%d_%d" // key:f_{mid%100}_{fid},value:{*Fodler}.pb
_relationFids = "rof_%d_%d_%d" // key:rof_{type}_{mid}_{oid},value:{[]int64}.pb
_oidCount = "oc_%d_%d" // key:oc_{type}_{oid},value:int64
_batchOids = "bo_%d_%d" // key:oc_{type}_{mid},value:{[]int64}.pb
_recentOids = "rcto_%d_%d" // key:rcto_{type}_{mid},value:{[]int64}.pb
_recentRes = "rctr_%d_%d" // key:rcto_{type}_{mid},value:{[]*Resource}.pb
)
// folderMcKey
func folderMcKey(mid, fid int64) string {
return fmt.Sprintf(_folder, mid%100, fid)
}
// relationFidsKey
func relationFidsKey(typ int8, mid, oid int64) string {
return fmt.Sprintf(_relationFids, typ, mid, oid)
}
func oidCountKey(typ int8, oid int64) string {
return fmt.Sprintf(_oidCount, typ, oid)
}
func batchOidsKey(typ int8, mid int64) string {
return fmt.Sprintf(_batchOids, typ, mid)
}
func recentOidsKey(typ int8, mid int64) string {
return fmt.Sprintf(_recentOids, typ, mid)
}
func recentResKey(typ int8, mid int64) string {
return fmt.Sprintf(_recentRes, typ, mid)
}
// pingMC ping mc is ok.
func (d *Dao) pingMC(c context.Context) error {
conn := d.mc.Get(c)
defer conn.Close()
item := memcache.Item{Key: "ping", Value: []byte{1}, Expiration: d.mcExpire}
return conn.Set(&item)
}
// SetFoldersMc add folders mc cache.
func (d *Dao) SetFoldersMc(c context.Context, vs ...*favmdl.Folder) (err error) {
conn := d.mc.Get(c)
defer conn.Close()
for _, v := range vs {
if v == nil {
continue
}
item := &memcache.Item{Key: folderMcKey(v.Mid, v.ID), Object: v, Flags: memcache.FlagProtobuf, Expiration: d.mcExpire}
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", folderMcKey(v.Mid, v.ID), err)
return
}
}
return
}
// FolderMc return one folder from mc.
func (d *Dao) FolderMc(c context.Context, typ int8, mid, fid int64) (f *favmdl.Folder, err error) {
var (
key = folderMcKey(mid, fid)
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
} else {
log.Error("memcache.Get(%s) error(%v)", key, err)
}
return
}
f = new(favmdl.Folder)
if err = conn.Scan(item, f); err != nil {
log.Error("conn.Scan(%s) error(%v)", item.Value, err)
f = nil
}
return
}
// SetRelaitonFidsMc set fids binary data to mc.
func (d *Dao) SetRelaitonFidsMc(c context.Context, typ int8, mid, oid int64, fids []int64) (err error) {
key := relationFidsKey(typ, mid, oid)
conn := d.mc.Get(c)
defer conn.Close()
bytes := favmdl.ToBytes(fids)
item := &memcache.Item{Key: key, Value: bytes, Flags: memcache.FlagRAW, Expiration: d.mcExpire}
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", key, err)
return
}
return
}
// RelaitonFidsMc return fids from mc.
func (d *Dao) RelaitonFidsMc(c context.Context, typ int8, mid, oid int64) (fids []int64, err error) {
var (
key = relationFidsKey(typ, mid, oid)
item *memcache.Item
conn = d.mc.Get(c)
b []byte
)
defer conn.Close()
if item, err = conn.Get(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
} else {
log.Error("memcache.Get(%s) error(%v)", key, err)
}
return
}
if err = conn.Scan(item, &b); err != nil {
log.Error("conn.Scan(%s) error(%v)", item.Value, err)
fids = nil
return
}
if fids, err = favmdl.ToInt64s(b); err != nil {
log.Error("fs.SetIndex(%v) error(%v)", b, err)
err = nil
fids = nil
}
return
}
// DelRelationFidsMc delete oid's fid mc cache.
func (d *Dao) DelRelationFidsMc(c context.Context, typ int8, mid, oid int64) (err error) {
var (
key = relationFidsKey(typ, mid, oid)
conn = d.mc.Get(c)
)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
} else {
log.Error("conn.Delete(%s) error(%v)", key, err)
}
}
return
}
// SetOidCountMc return oid count from mc.
func (d *Dao) SetOidCountMc(c context.Context, typ int8, oid, count int64) (err error) {
var (
key = oidCountKey(typ, oid)
conn = d.mc.Get(c)
)
defer conn.Close()
bs := []byte(strconv.FormatInt(int64(count), 10))
item := &memcache.Item{Key: key, Value: bs, Flags: memcache.FlagRAW, Expiration: d.mcExpire}
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", key, err)
return
}
return
}
// DelBatchOidsMc delete oids mc cache.
func (d *Dao) DelBatchOidsMc(c context.Context, typ int8, mid int64) (err error) {
key := batchOidsKey(typ, mid)
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
} else {
log.Error("conn.Delete(%s) error(%v)", key, err)
}
}
return
}
// DelRecentOidsMc delete recent oids mc cache.
func (d *Dao) DelRecentOidsMc(c context.Context, typ int8, mid int64) (err error) {
key := recentOidsKey(typ, mid)
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
} else {
log.Error("conn.Delete(%s) error(%v)", key, err)
}
}
return
}
// DelRecentResMc delete recent oids mc cache.
func (d *Dao) DelRecentResMc(c context.Context, typ int8, mid int64) (err error) {
key := recentResKey(typ, mid)
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
} else {
log.Error("conn.Delete(%s) error(%v)", key, err)
}
}
return
}