mc_seg.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. package dao
  2. import (
  3. "context"
  4. "fmt"
  5. "strconv"
  6. "go-common/app/interface/main/dm2/model"
  7. "go-common/library/cache/memcache"
  8. "go-common/library/log"
  9. )
  10. const (
  11. _keyDuration = "d_" // video duration
  12. _keySegMC = "sg_%d_%d_%d_%d"
  13. )
  14. func keyXMLSeg(tp int32, oid, cnt, num int64) string {
  15. return fmt.Sprintf("%d_%d_%d_%d", tp, oid, cnt, num)
  16. }
  17. func keySegMC(tp int32, oid, total, num int64) string {
  18. return fmt.Sprintf(_keySegMC, tp, oid, total, num)
  19. }
  20. // keyDuration return video duration key.
  21. func keyDuration(oid int64) string {
  22. return _keyDuration + strconv.FormatInt(oid, 10)
  23. }
  24. // XMLSegCache get dm segment xml content from memcache.
  25. func (d *Dao) XMLSegCache(c context.Context, tp int32, oid, cnt, num int64) (res []byte, err error) {
  26. var (
  27. conn = d.dmMC.Get(c)
  28. key = keyXMLSeg(tp, oid, cnt, num)
  29. rp *memcache.Item
  30. )
  31. defer conn.Close()
  32. if rp, err = conn.Get(key); err != nil {
  33. if err == memcache.ErrNotFound {
  34. err = nil
  35. PromCacheMiss("dm_xml_seg", 1)
  36. } else {
  37. log.Error("mc.Get(%s) error(%v)", key, err)
  38. }
  39. return
  40. }
  41. PromCacheHit("dm_xml_seg", 1)
  42. if err = conn.Scan(rp, &res); err != nil {
  43. log.Error("mc.Scan() error(%v)", err)
  44. }
  45. return
  46. }
  47. // SetXMLSegCache set dm xml content into memcache.
  48. func (d *Dao) SetXMLSegCache(c context.Context, tp int32, oid, cnt, num int64, value []byte) (err error) {
  49. key := keyXMLSeg(tp, oid, cnt, num)
  50. conn := d.dmMC.Get(c)
  51. item := memcache.Item{
  52. Key: key,
  53. Value: value,
  54. Expiration: d.dmExpire,
  55. Flags: memcache.FlagRAW,
  56. }
  57. if err = conn.Set(&item); err != nil {
  58. log.Error("mc.Set(%v) error(%v)", item, err)
  59. }
  60. conn.Close()
  61. return
  62. }
  63. // DurationCache return duration of video.
  64. func (d *Dao) DurationCache(c context.Context, oid int64) (duration int64, err error) {
  65. var (
  66. key = keyDuration(oid)
  67. conn = d.dmMC.Get(c)
  68. item *memcache.Item
  69. )
  70. defer conn.Close()
  71. if item, err = conn.Get(key); err != nil {
  72. if err == memcache.ErrNotFound {
  73. duration = model.NotFound
  74. err = nil
  75. PromCacheMiss("video_duration", 1)
  76. } else {
  77. log.Error("conn.Get(%s) error(%v)", key, err)
  78. }
  79. return
  80. }
  81. PromCacheHit("video_duration", 1)
  82. if duration, err = strconv.ParseInt(string(item.Value), 10, 64); err != nil {
  83. log.Error("strconv.ParseInt(%s) error(%v)", item.Value, err)
  84. }
  85. return
  86. }
  87. // SetDurationCache set video duration to redis.
  88. func (d *Dao) SetDurationCache(c context.Context, oid, duration int64) (err error) {
  89. key := keyDuration(oid)
  90. conn := d.dmMC.Get(c)
  91. item := memcache.Item{
  92. Key: key,
  93. Value: []byte(fmt.Sprint(duration)),
  94. Expiration: d.dmExpire,
  95. Flags: memcache.FlagRAW,
  96. }
  97. if err = conn.Set(&item); err != nil {
  98. log.Error("mc.Set(%v) error(%v)", item, err)
  99. }
  100. conn.Close()
  101. return
  102. }
  103. // SetDMSegCache set segment dm to cache.
  104. func (d *Dao) SetDMSegCache(c context.Context, tp int32, oid, total, num int64, dmSeg *model.DMSeg) (err error) {
  105. key := keySegMC(tp, oid, total, num)
  106. conn := d.dmSegMC.Get(c)
  107. item := memcache.Item{
  108. Key: key,
  109. Object: dmSeg,
  110. Expiration: d.dmSegMCExpire,
  111. Flags: memcache.FlagProtobuf | memcache.FlagGzip,
  112. }
  113. if err = conn.Set(&item); err != nil {
  114. log.Error("conn.Set(%v) error(%v)", item, err)
  115. }
  116. conn.Close()
  117. return
  118. }
  119. // DMSegCache dm segment pb cache.
  120. func (d *Dao) DMSegCache(c context.Context, tp int32, oid, total, num int64) (dmSeg *model.DMSeg, err error) {
  121. var (
  122. key = keySegMC(tp, oid, total, num)
  123. conn = d.dmSegMC.Get(c)
  124. item *memcache.Item
  125. )
  126. dmSeg = new(model.DMSeg)
  127. defer conn.Close()
  128. if item, err = conn.Get(key); err != nil {
  129. if err == memcache.ErrNotFound {
  130. err = nil
  131. dmSeg = nil
  132. } else {
  133. log.Error("mc.Get(%s) error(%v)", key, err)
  134. }
  135. return
  136. }
  137. if err = conn.Scan(item, dmSeg); err != nil {
  138. log.Error("conn.Scan() error(%v)", err)
  139. }
  140. return
  141. }