memcache.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package archive
  2. import (
  3. "context"
  4. "strconv"
  5. "go-common/app/interface/main/app-view/model/view"
  6. "go-common/app/service/main/archive/api"
  7. "go-common/app/service/main/archive/model/archive"
  8. "go-common/library/cache/memcache"
  9. "go-common/library/log"
  10. "github.com/pkg/errors"
  11. )
  12. const (
  13. _prefixRelate = "al_"
  14. _prefixViewStatic = "avp_"
  15. _prefixStat = "stp_"
  16. _prefixArchive = "a3p_"
  17. _prefixViewContribute = "avpc_"
  18. )
  19. func keyRl(aid int64) string {
  20. return _prefixRelate + strconv.FormatInt(aid, 10)
  21. }
  22. func keyView(aid int64) string {
  23. return _prefixViewStatic + strconv.FormatInt(aid, 10)
  24. }
  25. func keyStat(aid int64) string {
  26. return _prefixStat + strconv.FormatInt(aid, 10)
  27. }
  28. func keyArc(aid int64) string {
  29. return _prefixArchive + strconv.FormatInt(aid, 10)
  30. }
  31. func keyViewContribute(mid int64) string {
  32. return _prefixViewContribute + strconv.FormatInt(mid, 10)
  33. }
  34. // AddRelatesCache add relates
  35. func (d *Dao) AddRelatesCache(aid int64, rls []*view.Relate) {
  36. d.addCache(func() {
  37. d.addRelatesCache(context.TODO(), aid, rls)
  38. })
  39. }
  40. // RelatesCache get relates.
  41. func (d *Dao) RelatesCache(c context.Context, aid int64) (rls []*view.Relate, err error) {
  42. conn := d.arcMc.Get(c)
  43. key := keyRl(aid)
  44. defer conn.Close()
  45. r, err := conn.Get(key)
  46. if err != nil {
  47. if err == memcache.ErrNotFound {
  48. err = nil
  49. return
  50. }
  51. err = errors.Wrapf(err, "conn.Get(%s)", key)
  52. return
  53. }
  54. if err = conn.Scan(r, &rls); err != nil {
  55. err = errors.Wrapf(err, "conn.Scan(%s)", r.Value)
  56. }
  57. return
  58. }
  59. // addRelatesCache add relates cache.
  60. func (d *Dao) addRelatesCache(c context.Context, aid int64, rls []*view.Relate) (err error) {
  61. conn := d.arcMc.Get(c)
  62. key := keyRl(aid)
  63. item := &memcache.Item{Key: key, Object: rls, Flags: memcache.FlagJSON, Expiration: d.expireRlt}
  64. if err = conn.Set(item); err != nil {
  65. err = errors.Wrapf(err, "conn.Set(%s,%v,%d)", key, rls, d.expireRlt)
  66. }
  67. conn.Close()
  68. return
  69. }
  70. // viewCache get view cache from remote memecache .
  71. func (d *Dao) viewCache(c context.Context, aid int64) (vs *archive.View3, err error) {
  72. conn := d.arcMc.Get(c)
  73. key := keyView(aid)
  74. defer conn.Close()
  75. r, err := conn.Get(key)
  76. if err != nil {
  77. if err == memcache.ErrNotFound {
  78. err = nil
  79. return
  80. }
  81. err = errors.Wrapf(err, "conn.Get(%s)", key)
  82. return
  83. }
  84. vs = &archive.View3{Archive3: &archive.Archive3{}}
  85. if err = conn.Scan(r, vs); err != nil {
  86. vs = nil
  87. err = errors.Wrapf(err, "conn.Scan(%s)", r.Value)
  88. }
  89. return
  90. }
  91. // statCache get a archive stat from cache.
  92. func (d *Dao) statCache(c context.Context, aid int64) (st *api.Stat, err error) {
  93. conn := d.arcMc.Get(c)
  94. key := keyStat(aid)
  95. defer conn.Close()
  96. r, err := conn.Get(key)
  97. if err != nil {
  98. if err == memcache.ErrNotFound {
  99. err = nil
  100. return
  101. }
  102. err = errors.Wrapf(err, "conn.Get(%s)", key)
  103. return
  104. }
  105. st = &api.Stat{}
  106. if err = conn.Scan(r, st); err != nil {
  107. st = nil
  108. err = errors.Wrapf(err, "conn.Scan(%s)", r.Value)
  109. }
  110. return
  111. }
  112. // statsCache get stat cache by aids
  113. func (d *Dao) statsCache(c context.Context, aids []int64) (cached map[int64]*api.Stat, missed []int64, err error) {
  114. cached = make(map[int64]*api.Stat, len(aids))
  115. conn := d.arcMc.Get(c)
  116. defer conn.Close()
  117. keys := make([]string, 0, len(aids))
  118. for _, aid := range aids {
  119. keys = append(keys, keyStat(aid))
  120. }
  121. rs, err := conn.GetMulti(keys)
  122. if err != nil {
  123. err = errors.Wrapf(err, "conn.GetMulti(%v)", keys)
  124. return
  125. }
  126. for _, item := range rs {
  127. var st = &api.Stat{}
  128. if err = conn.Scan(item, st); err != nil {
  129. err = nil
  130. log.Error("conn.Scan(%v) error(%v)", item, err)
  131. continue
  132. }
  133. cached[st.Aid] = st
  134. }
  135. if len(cached) == len(aids) {
  136. return
  137. }
  138. for _, aid := range aids {
  139. if _, ok := cached[aid]; !ok {
  140. missed = append(missed, aid)
  141. }
  142. }
  143. return
  144. }
  145. // arcsCache get archives cache.
  146. func (d *Dao) arcsCache(c context.Context, aids []int64) (cached map[int64]*api.Arc, missed []int64, err error) {
  147. cached = make(map[int64]*api.Arc, len(aids))
  148. conn := d.arcMc.Get(c)
  149. defer conn.Close()
  150. keys := make([]string, 0, len(aids))
  151. aidmap := make(map[string]int64, len(aids))
  152. for _, aid := range aids {
  153. k := keyArc(aid)
  154. if _, ok := aidmap[k]; !ok {
  155. keys = append(keys, k)
  156. aidmap[k] = aid
  157. }
  158. }
  159. rs, err := conn.GetMulti(keys)
  160. if err != nil {
  161. err = errors.Wrapf(err, "conn.GetMulti(%v)", keys)
  162. return
  163. }
  164. for k, r := range rs {
  165. a := &api.Arc{}
  166. if err = conn.Scan(r, a); err != nil {
  167. log.Error("conn.Scan(%s) error(%v)", r.Value, err)
  168. err = nil
  169. continue
  170. }
  171. cached[aidmap[k]] = a
  172. // delete hit key
  173. delete(aidmap, k)
  174. }
  175. // missed key
  176. missed = make([]int64, 0, len(aidmap))
  177. for _, aid := range aidmap {
  178. missed = append(missed, aid)
  179. }
  180. return
  181. }
  182. // arcCache get archive cache.
  183. func (d *Dao) arcCache(c context.Context, aid int64) (a *api.Arc, err error) {
  184. conn := d.arcMc.Get(c)
  185. key := keyArc(aid)
  186. defer conn.Close()
  187. r, err := conn.Get(key)
  188. if err != nil {
  189. if err == memcache.ErrNotFound {
  190. err = nil
  191. return
  192. }
  193. err = errors.Wrapf(err, "conn.Get(%s)", key)
  194. return
  195. }
  196. a = &api.Arc{}
  197. if err = conn.Scan(r, a); err != nil {
  198. a = nil
  199. err = errors.Wrapf(err, "conn.Scan(%s)", r.Value)
  200. }
  201. return
  202. }
  203. // ViewContributeCache get archive cache.
  204. func (d *Dao) ViewContributeCache(c context.Context, mid int64) (aids []int64, err error) {
  205. conn := d.arcMc.Get(c)
  206. key := keyViewContribute(mid)
  207. defer conn.Close()
  208. r, err := conn.Get(key)
  209. if err != nil {
  210. if err == memcache.ErrNotFound {
  211. err = nil
  212. return
  213. }
  214. err = errors.Wrapf(err, "conn.Get(%s)", key)
  215. return
  216. }
  217. if err = conn.Scan(r, &aids); err != nil {
  218. err = errors.Wrapf(err, "conn.Scan(%s)", r.Value)
  219. }
  220. return
  221. }
  222. func (d *Dao) pingMC(c context.Context) (err error) {
  223. conn := d.arcMc.Get(c)
  224. err = conn.Set(&memcache.Item{Key: "ping", Object: []byte{1}, Flags: memcache.FlagJSON, Expiration: 0})
  225. conn.Close()
  226. return
  227. }