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

12345678910111213141516171819202122232425262728293031323334353637383940
  1. package tickevent
  2. import (
  3. "github.com/samber/lo"
  4. "gitlink.org.cn/cloudream/common/utils/logger"
  5. "gitlink.org.cn/cloudream/db/model"
  6. mysql "gitlink.org.cn/cloudream/db/sql"
  7. "gitlink.org.cn/cloudream/scanner/internal/event"
  8. )
  9. const AGENT_CHECK_CACHE_BATCH_SIZE = 2
  10. type BatchAllAgentCheckCache struct {
  11. nodeIDs []int
  12. }
  13. func NewBatchAllAgentCheckCache() *BatchAllAgentCheckCache {
  14. return &BatchAllAgentCheckCache{}
  15. }
  16. func (e *BatchAllAgentCheckCache) Execute(ctx ExecuteContext) {
  17. if e.nodeIDs == nil || len(e.nodeIDs) == 0 {
  18. nodes, err := mysql.Node.GetAllNodes(ctx.Args.DB.SQLCtx())
  19. if err != nil {
  20. logger.Warnf("get all nodes failed, err: %s", err.Error())
  21. return
  22. }
  23. e.nodeIDs = lo.Map(nodes, func(node model.Node, index int) int { return node.NodeID })
  24. logger.Debugf("new check start, get all nodes")
  25. }
  26. checkedCnt := 0
  27. for ; checkedCnt < len(e.nodeIDs) && checkedCnt < AGENT_CHECK_CACHE_BATCH_SIZE; checkedCnt++ {
  28. // nil代表进行全量检查
  29. ctx.Args.EventExecutor.Post(event.NewAgentCheckCache(e.nodeIDs[checkedCnt], nil))
  30. }
  31. e.nodeIDs = e.nodeIDs[checkedCnt:]
  32. }

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