redis.go 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. package ads
  2. import (
  3. "context"
  4. "fmt"
  5. "go-common/library/cache/redis"
  6. "go-common/library/log"
  7. "github.com/dgryski/go-farm"
  8. )
  9. const (
  10. _prefixBuvid = "buvid:%d"
  11. )
  12. func (d *Dao) keyBuvid(buvid string) (key string) {
  13. num := int64(farm.Hash32([]byte(buvid)))
  14. key = fmt.Sprintf(_prefixBuvid, num%d.c.HashNum)
  15. return
  16. }
  17. // ExistsAuth if existes buvid in redis.
  18. func (d *Dao) ExistsAuth(c context.Context, key string) (ok bool, err error) {
  19. var conn = d.redis.Get(c)
  20. defer conn.Close()
  21. if ok, err = redis.Bool(conn.Do("EXISTS", key)); err != nil {
  22. log.Error("EXISTS key(%s), error(%v)", key, err)
  23. }
  24. return
  25. }
  26. // BuvidCount get buvid count info from redis.
  27. func (d *Dao) BuvidCount(c context.Context, faid int64, buvid string) (res int64, err error) {
  28. var (
  29. key = d.keyBuvid(buvid)
  30. conn = d.redis.Get(c)
  31. field = faid
  32. )
  33. defer conn.Close()
  34. if res, err = redis.Int64(conn.Do("HGET", key, field)); err != nil {
  35. if err != redis.ErrNil {
  36. log.Error("BuvidCount conn.Send HGET(%v, %v) error(%v)", key, field, err)
  37. return
  38. }
  39. err = nil
  40. }
  41. return
  42. }
  43. // AddBuvidCount add buvid count info into redis.
  44. func (d *Dao) AddBuvidCount(c context.Context, buvidCounts map[string]map[int64]int64) (err error) {
  45. var (
  46. key string
  47. count int
  48. conn = d.redis.Get(c)
  49. faid int64
  50. playCount int64
  51. ok bool
  52. )
  53. defer conn.Close()
  54. for buvid, buvidCount := range buvidCounts {
  55. key = d.keyBuvid(buvid)
  56. if ok, err = d.ExistsAuth(c, key); err != nil {
  57. log.Error("EXISTS key(%s) error(%v)", key, err)
  58. return
  59. }
  60. for faid, playCount = range buvidCount {
  61. if err = conn.Send("HSET", key, faid, playCount); err != nil {
  62. log.Error("HSET key(%s) field(%d) playCount(%d) error(%v)", key, faid, playCount, err)
  63. return
  64. }
  65. count++
  66. }
  67. if !ok {
  68. if err = conn.Send("EXPIRE", key, d.expire); err != nil {
  69. log.Error("EXPIRE key(%s) expire(%v) error(%v)", key, d.expire, err)
  70. return
  71. }
  72. count++
  73. }
  74. }
  75. if err = conn.Flush(); err != nil {
  76. log.Error("BuvidCount conn.Flush error(%v)", err)
  77. return
  78. }
  79. for i := 0; i < count; i++ {
  80. if _, err = conn.Receive(); err != nil {
  81. log.Error("BuvidCount conn.Receive error(%v)", err)
  82. return
  83. }
  84. }
  85. return
  86. }