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.

object.go 2.4 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package cmdline
  2. import (
  3. "fmt"
  4. "os"
  5. "path/filepath"
  6. "time"
  7. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  8. "gitlink.org.cn/cloudream/storage/common/pkgs/iterator"
  9. )
  10. // 必须添加的命令函数,用于处理对象上传。
  11. //
  12. // ctx: 命令上下文,提供必要的服务和环境配置。
  13. // packageID: 上传套餐的唯一标识。
  14. // rootPath: 本地文件系统中待上传文件的根目录。
  15. // nodeAffinity: 偏好的节点ID列表,上传任务可能会分配到这些节点上。
  16. // 返回值: 执行过程中遇到的任何错误。
  17. var _ = MustAddCmd(func(ctx CommandContext, packageID cdssdk.PackageID, rootPath string, nodeAffinity []cdssdk.NodeID) error {
  18. // 记录函数开始时间,用于计算执行时间。
  19. startTime := time.Now()
  20. defer func() {
  21. // 打印函数执行时间。
  22. fmt.Printf("%v\n", time.Since(startTime).Seconds())
  23. }()
  24. // 模拟或获取用户ID。
  25. userID := cdssdk.UserID(1)
  26. // 遍历根目录下所有文件,收集待上传的文件路径。
  27. var uploadFilePathes []string
  28. err := filepath.WalkDir(rootPath, func(fname string, fi os.DirEntry, err error) error {
  29. if err != nil {
  30. return nil
  31. }
  32. // 仅添加非目录文件路径。
  33. if !fi.IsDir() {
  34. uploadFilePathes = append(uploadFilePathes, fname)
  35. }
  36. return nil
  37. })
  38. if err != nil {
  39. // 目录遍历失败处理。
  40. return fmt.Errorf("open directory %s failed, err: %w", rootPath, err)
  41. }
  42. // 根据节点亲和性列表设置首选上传节点。
  43. var nodeAff *cdssdk.NodeID
  44. if len(nodeAffinity) > 0 {
  45. n := cdssdk.NodeID(nodeAffinity[0])
  46. nodeAff = &n
  47. }
  48. // 创建上传对象迭代器。
  49. objIter := iterator.NewUploadingObjectIterator(rootPath, uploadFilePathes)
  50. // 开始上传任务。
  51. taskID, err := ctx.Cmdline.Svc.ObjectSvc().StartUploading(userID, packageID, objIter, nodeAff)
  52. if err != nil {
  53. // 上传任务启动失败处理。
  54. return fmt.Errorf("update objects to package %d failed, err: %w", packageID, err)
  55. }
  56. // 循环等待上传任务完成。
  57. for {
  58. // 每5秒检查一次上传状态。
  59. complete, _, err := ctx.Cmdline.Svc.ObjectSvc().WaitUploading(taskID, time.Second*5)
  60. if complete {
  61. // 上传完成,检查是否有错误。
  62. if err != nil {
  63. return fmt.Errorf("uploading objects: %w", err)
  64. }
  65. return nil
  66. }
  67. // 等待过程中发生错误处理。
  68. if err != nil {
  69. return fmt.Errorf("wait updating: %w", err)
  70. }
  71. }
  72. }, "obj", "upload")

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