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.4 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package accessstat
  2. import (
  3. "sync"
  4. "time"
  5. "gitlink.org.cn/cloudream/common/pkgs/logger"
  6. "gitlink.org.cn/cloudream/common/utils/sync2"
  7. "gitlink.org.cn/cloudream/storage2/client/internal/db"
  8. clitypes "gitlink.org.cn/cloudream/storage2/client/types"
  9. )
  10. type AccessStatEvent interface{}
  11. type AccessStat struct {
  12. cfg Config
  13. stats []db.AddAccessStatEntry
  14. lock sync.Mutex
  15. db *db.DB
  16. }
  17. func NewAccessStat(cfg Config, db *db.DB) *AccessStat {
  18. return &AccessStat{
  19. cfg: cfg,
  20. db: db,
  21. }
  22. }
  23. func (p *AccessStat) AddAccessCounter(objID clitypes.ObjectID, pkgID clitypes.PackageID, spaceID clitypes.UserSpaceID, value float64) {
  24. p.lock.Lock()
  25. defer p.lock.Unlock()
  26. p.stats = append(p.stats, db.AddAccessStatEntry{
  27. ObjectID: objID,
  28. PackageID: pkgID,
  29. UserSpaceID: spaceID,
  30. Counter: value,
  31. })
  32. }
  33. func (p *AccessStat) Start() *sync2.UnboundChannel[AccessStatEvent] {
  34. ch := sync2.NewUnboundChannel[AccessStatEvent]()
  35. go func() {
  36. ticker := time.NewTicker(p.cfg.ReportInterval)
  37. for {
  38. <-ticker.C
  39. p.lock.Lock()
  40. st := p.stats
  41. p.stats = nil
  42. p.lock.Unlock()
  43. if len(st) == 0 {
  44. continue
  45. }
  46. err := db.DoTx10(p.db, p.db.Package().BatchAddPackageAccessStat, st)
  47. if err != nil {
  48. logger.Errorf("add all package access stat counter: %v", err)
  49. p.lock.Lock()
  50. p.stats = append(p.stats, st...)
  51. p.lock.Unlock()
  52. continue
  53. }
  54. }
  55. }()
  56. return ch
  57. }

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