You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

access_stat.go 1.6 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. package accessstat
  2. import (
  3. "fmt"
  4. "sync"
  5. "time"
  6. "gitlink.org.cn/cloudream/common/pkgs/logger"
  7. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  8. "gitlink.org.cn/cloudream/common/utils/sync2"
  9. stgglb "gitlink.org.cn/cloudream/storage/common/globals"
  10. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  11. )
  12. type AccessStatEvent interface{}
  13. type AccessStat struct {
  14. cfg Config
  15. stats []coormq.AddAccessStatEntry
  16. lock sync.Mutex
  17. }
  18. func NewAccessStat(cfg Config) *AccessStat {
  19. return &AccessStat{
  20. cfg: cfg,
  21. }
  22. }
  23. func (p *AccessStat) AddAccessCounter(objID cdssdk.ObjectID, pkgID cdssdk.PackageID, nodeID cdssdk.NodeID, value float64) {
  24. p.lock.Lock()
  25. defer p.lock.Unlock()
  26. p.stats = append(p.stats, coormq.AddAccessStatEntry{
  27. ObjectID: objID,
  28. PackageID: pkgID,
  29. NodeID: nodeID,
  30. Counter: value,
  31. })
  32. }
  33. func (p *AccessStat) Start() *sync2.UnboundChannel[AccessStatEvent] {
  34. ch := sync2.NewUnboundChannel[AccessStatEvent]()
  35. go func() {
  36. coorCli, err := stgglb.CoordinatorMQPool.Acquire()
  37. if err != nil {
  38. ch.Send(fmt.Errorf("new coordinator client: %w", err))
  39. }
  40. defer stgglb.CoordinatorMQPool.Release(coorCli)
  41. ticker := time.NewTicker(p.cfg.ReportInterval)
  42. for {
  43. <-ticker.C
  44. p.lock.Lock()
  45. st := p.stats
  46. p.stats = nil
  47. p.lock.Unlock()
  48. err := coorCli.AddAccessStat(coormq.ReqAddAccessStat(st))
  49. if err != nil {
  50. logger.Errorf("add all package access stat counter: %v", err)
  51. p.lock.Lock()
  52. p.stats = append(p.stats, st...)
  53. p.lock.Unlock()
  54. continue
  55. }
  56. }
  57. }()
  58. return ch
  59. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。