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.

update_cache.go 1.3 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package task
  2. import (
  3. tskcst "gitlink.org.cn/cloudream/common/consts/task"
  4. mysql "gitlink.org.cn/cloudream/db/sql"
  5. "gitlink.org.cn/cloudream/utils/logger"
  6. )
  7. type UpdateCacheTaskEntry struct {
  8. FileHash string
  9. NodeID int
  10. Operation string
  11. }
  12. func NewUpdateCacheTaskEntry(fileHash string, nodeID int, op string) UpdateCacheTaskEntry {
  13. return UpdateCacheTaskEntry{
  14. FileHash: fileHash,
  15. NodeID: nodeID,
  16. Operation: op,
  17. }
  18. }
  19. type UpdateCacheTask struct {
  20. Entries []UpdateCacheTaskEntry
  21. }
  22. func NewUpdateCacheTask(entries []UpdateCacheTaskEntry) UpdateCacheTask {
  23. return UpdateCacheTask{
  24. Entries: entries,
  25. }
  26. }
  27. func (t *UpdateCacheTask) TryMerge(other Task) bool {
  28. chkTask, ok := other.(*UpdateCacheTask)
  29. if !ok {
  30. return false
  31. }
  32. // TODO 可以考虑合并同FileHash和NodeID的记录
  33. t.Entries = append(t.Entries, chkTask.Entries...)
  34. return true
  35. }
  36. func (t *UpdateCacheTask) Execute(execCtx *ExecuteContext, execOpts ExecuteOption) {
  37. for _, entry := range t.Entries {
  38. switch entry.Operation {
  39. case tskcst.UPDATE_CACHE_OP_UNTEMP:
  40. err := mysql.Cache.DeleteTemp(execCtx.DB.SQLCtx(), entry.FileHash, entry.NodeID)
  41. if err != nil {
  42. logger.WithField("FileHash", entry.FileHash).
  43. WithField("NodeID", entry.NodeID).
  44. Warnf("delete temp cache failed, err: %s", err.Error())
  45. }
  46. }
  47. }
  48. }

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