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.

cache.go 1.7 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package cmdline
  2. import (
  3. "fmt"
  4. "time"
  5. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  6. )
  7. // CacheMovePackage 移动缓存包到指定节点。
  8. // ctx: 命令上下文环境。
  9. // packageID: 待移动的包ID。
  10. // nodeID: 目标节点ID。
  11. // 返回值: 移动成功返回nil,失败返回error。
  12. func CacheMovePackage(ctx CommandContext, packageID cdssdk.PackageID, nodeID cdssdk.NodeID) error {
  13. startTime := time.Now()
  14. defer func() {
  15. // 打印函数执行时间
  16. fmt.Printf("%v\n", time.Since(startTime).Seconds())
  17. }()
  18. // 开始移动缓存包任务
  19. taskID, err := ctx.Cmdline.Svc.CacheSvc().StartCacheMovePackage(1, packageID, nodeID)
  20. if err != nil {
  21. return fmt.Errorf("start cache moving package: %w", err)
  22. }
  23. // 循环等待缓存包移动完成
  24. for {
  25. complete, err := ctx.Cmdline.Svc.CacheSvc().WaitCacheMovePackage(nodeID, taskID, time.Second*10)
  26. if complete {
  27. if err != nil {
  28. return fmt.Errorf("moving complete with: %w", err)
  29. }
  30. return nil
  31. }
  32. if err != nil {
  33. return fmt.Errorf("wait moving: %w", err)
  34. }
  35. }
  36. }
  37. // CacheRemovePackage 从缓存中移除指定的包。
  38. // ctx: 命令上下文环境。
  39. // packageID: 待移除的包ID。
  40. // nodeID: 缓存节点ID。
  41. // 返回值: 移除成功返回nil,失败返回error。
  42. func CacheRemovePackage(ctx CommandContext, packageID cdssdk.PackageID, nodeID cdssdk.NodeID) error {
  43. return ctx.Cmdline.Svc.CacheSvc().CacheRemovePackage(packageID, nodeID)
  44. }
  45. // 初始化命令列表
  46. func init() {
  47. // 添加移动缓存包命令
  48. commands.Add(CacheMovePackage, "cache", "move")
  49. // 添加移除缓存包命令
  50. commands.Add(CacheRemovePackage, "cache", "remove")
  51. }

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