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.

batch_all_agent_check_cache.go 1.2 kB

2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142
  1. package tickevent
  2. import (
  3. "gitlink.org.cn/cloudream/common/pkgs/logger"
  4. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  5. scevt "gitlink.org.cn/cloudream/storage/common/pkgs/mq/scanner/event"
  6. "gitlink.org.cn/cloudream/storage/scanner/internal/event"
  7. )
  8. const AGENT_CHECK_CACHE_BATCH_SIZE = 2
  9. type BatchAllAgentCheckCache struct {
  10. stgIDs []cdssdk.StorageID
  11. }
  12. func NewBatchAllAgentCheckCache() *BatchAllAgentCheckCache {
  13. return &BatchAllAgentCheckCache{}
  14. }
  15. func (e *BatchAllAgentCheckCache) Execute(ctx ExecuteContext) {
  16. log := logger.WithType[BatchAllAgentCheckCache]("TickEvent")
  17. log.Debugf("begin")
  18. defer log.Debugf("end")
  19. if e.stgIDs == nil || len(e.stgIDs) == 0 {
  20. ids, err := ctx.Args.DB.Storage().GetAllIDs(ctx.Args.DB.DefCtx())
  21. if err != nil {
  22. log.Warnf("get all storages failed, err: %s", err.Error())
  23. return
  24. }
  25. log.Debugf("new check start, get all storages")
  26. e.stgIDs = ids
  27. }
  28. checkedCnt := 0
  29. for ; checkedCnt < len(e.stgIDs) && checkedCnt < AGENT_CHECK_CACHE_BATCH_SIZE; checkedCnt++ {
  30. // nil代表进行全量检查
  31. ctx.Args.EventExecutor.Post(event.NewAgentCheckCache(scevt.NewAgentCheckCache(e.stgIDs[checkedCnt])))
  32. }
  33. e.stgIDs = e.stgIDs[checkedCnt:]
  34. }

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