123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- package dao
- import (
- "context"
- "fmt"
- "strconv"
- "go-common/app/interface/main/dm2/model"
- "go-common/library/cache/memcache"
- "go-common/library/log"
- )
- const (
- _keyDuration = "d_" // video duration
- _keySegMC = "sg_%d_%d_%d_%d"
- )
- func keyXMLSeg(tp int32, oid, cnt, num int64) string {
- return fmt.Sprintf("%d_%d_%d_%d", tp, oid, cnt, num)
- }
- func keySegMC(tp int32, oid, total, num int64) string {
- return fmt.Sprintf(_keySegMC, tp, oid, total, num)
- }
- // keyDuration return video duration key.
- func keyDuration(oid int64) string {
- return _keyDuration + strconv.FormatInt(oid, 10)
- }
- // XMLSegCache get dm segment xml content from memcache.
- func (d *Dao) XMLSegCache(c context.Context, tp int32, oid, cnt, num int64) (res []byte, err error) {
- var (
- conn = d.dmMC.Get(c)
- key = keyXMLSeg(tp, oid, cnt, num)
- rp *memcache.Item
- )
- defer conn.Close()
- if rp, err = conn.Get(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- PromCacheMiss("dm_xml_seg", 1)
- } else {
- log.Error("mc.Get(%s) error(%v)", key, err)
- }
- return
- }
- PromCacheHit("dm_xml_seg", 1)
- if err = conn.Scan(rp, &res); err != nil {
- log.Error("mc.Scan() error(%v)", err)
- }
- return
- }
- // SetXMLSegCache set dm xml content into memcache.
- func (d *Dao) SetXMLSegCache(c context.Context, tp int32, oid, cnt, num int64, value []byte) (err error) {
- key := keyXMLSeg(tp, oid, cnt, num)
- conn := d.dmMC.Get(c)
- item := memcache.Item{
- Key: key,
- Value: value,
- Expiration: d.dmExpire,
- Flags: memcache.FlagRAW,
- }
- if err = conn.Set(&item); err != nil {
- log.Error("mc.Set(%v) error(%v)", item, err)
- }
- conn.Close()
- return
- }
- // DurationCache return duration of video.
- func (d *Dao) DurationCache(c context.Context, oid int64) (duration int64, err error) {
- var (
- key = keyDuration(oid)
- conn = d.dmMC.Get(c)
- item *memcache.Item
- )
- defer conn.Close()
- if item, err = conn.Get(key); err != nil {
- if err == memcache.ErrNotFound {
- duration = model.NotFound
- err = nil
- PromCacheMiss("video_duration", 1)
- } else {
- log.Error("conn.Get(%s) error(%v)", key, err)
- }
- return
- }
- PromCacheHit("video_duration", 1)
- if duration, err = strconv.ParseInt(string(item.Value), 10, 64); err != nil {
- log.Error("strconv.ParseInt(%s) error(%v)", item.Value, err)
- }
- return
- }
- // SetDurationCache set video duration to redis.
- func (d *Dao) SetDurationCache(c context.Context, oid, duration int64) (err error) {
- key := keyDuration(oid)
- conn := d.dmMC.Get(c)
- item := memcache.Item{
- Key: key,
- Value: []byte(fmt.Sprint(duration)),
- Expiration: d.dmExpire,
- Flags: memcache.FlagRAW,
- }
- if err = conn.Set(&item); err != nil {
- log.Error("mc.Set(%v) error(%v)", item, err)
- }
- conn.Close()
- return
- }
- // SetDMSegCache set segment dm to cache.
- func (d *Dao) SetDMSegCache(c context.Context, tp int32, oid, total, num int64, dmSeg *model.DMSeg) (err error) {
- key := keySegMC(tp, oid, total, num)
- conn := d.dmSegMC.Get(c)
- item := memcache.Item{
- Key: key,
- Object: dmSeg,
- Expiration: d.dmSegMCExpire,
- Flags: memcache.FlagProtobuf | memcache.FlagGzip,
- }
- if err = conn.Set(&item); err != nil {
- log.Error("conn.Set(%v) error(%v)", item, err)
- }
- conn.Close()
- return
- }
- // DMSegCache dm segment pb cache.
- func (d *Dao) DMSegCache(c context.Context, tp int32, oid, total, num int64) (dmSeg *model.DMSeg, err error) {
- var (
- key = keySegMC(tp, oid, total, num)
- conn = d.dmSegMC.Get(c)
- item *memcache.Item
- )
- dmSeg = new(model.DMSeg)
- defer conn.Close()
- if item, err = conn.Get(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- dmSeg = nil
- } else {
- log.Error("mc.Get(%s) error(%v)", key, err)
- }
- return
- }
- if err = conn.Scan(item, dmSeg); err != nil {
- log.Error("conn.Scan() error(%v)", err)
- }
- return
- }
|