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.

storage.go 2.9 kB

2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package services
  2. import (
  3. "fmt"
  4. "time"
  5. "gitlink.org.cn/cloudream/common/models"
  6. "gitlink.org.cn/cloudream/storage/client/internal/task"
  7. "gitlink.org.cn/cloudream/storage/common/globals"
  8. agtmq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/agent"
  9. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  10. )
  11. type StorageService struct {
  12. *Service
  13. }
  14. func (svc *Service) StorageSvc() *StorageService {
  15. return &StorageService{Service: svc}
  16. }
  17. func (svc *StorageService) StartStorageLoadPackage(userID int64, packageID int64, storageID int64) (string, error) {
  18. tsk := svc.TaskMgr.StartNew(task.NewStorageLoadPackage(userID, packageID, storageID))
  19. return tsk.ID(), nil
  20. }
  21. func (svc *StorageService) WaitStorageLoadPackage(taskID string, waitTimeout time.Duration) (bool, error) {
  22. tsk := svc.TaskMgr.FindByID(taskID)
  23. if tsk.WaitTimeout(waitTimeout) {
  24. return true, tsk.Error()
  25. }
  26. return false, nil
  27. }
  28. func (svc *StorageService) DeleteStoragePackage(userID int64, packageID int64, storageID int64) error {
  29. // TODO
  30. panic("not implement yet")
  31. }
  32. // 请求节点启动从Storage中上传文件的任务。会返回节点ID和任务ID
  33. func (svc *StorageService) StartStorageCreatePackage(userID int64, bucketID int64, name string, storageID int64, path string, redundancy models.TypedRedundancyInfo) (int64, string, error) {
  34. coorCli, err := globals.CoordinatorMQPool.Acquire()
  35. if err != nil {
  36. return 0, "", fmt.Errorf("new coordinator client: %w", err)
  37. }
  38. defer coorCli.Close()
  39. stgResp, err := coorCli.GetStorageInfo(coormq.NewGetStorageInfo(userID, storageID))
  40. if err != nil {
  41. return 0, "", fmt.Errorf("getting storage info: %w", err)
  42. }
  43. agentCli, err := globals.AgentMQPool.Acquire(stgResp.NodeID)
  44. if err != nil {
  45. return 0, "", fmt.Errorf("new agent client: %w", err)
  46. }
  47. defer agentCli.Close()
  48. startResp, err := agentCli.StartStorageCreatePackage(agtmq.NewStartStorageCreatePackage(userID, bucketID, name, storageID, path, redundancy))
  49. if err != nil {
  50. return 0, "", fmt.Errorf("start storage upload package: %w", err)
  51. }
  52. return stgResp.NodeID, startResp.TaskID, nil
  53. }
  54. func (svc *StorageService) WaitStorageCreatePackage(nodeID int64, taskID string, waitTimeout time.Duration) (bool, int64, error) {
  55. agentCli, err := globals.AgentMQPool.Acquire(nodeID)
  56. if err != nil {
  57. // TODO 失败是否要当做任务已经结束?
  58. return true, 0, fmt.Errorf("new agent client: %w", err)
  59. }
  60. defer agentCli.Close()
  61. waitResp, err := agentCli.WaitStorageCreatePackage(agtmq.NewWaitStorageCreatePackage(taskID, waitTimeout.Milliseconds()))
  62. if err != nil {
  63. // TODO 请求失败是否要当做任务已经结束?
  64. return true, 0, fmt.Errorf("wait storage upload package: %w", err)
  65. }
  66. if !waitResp.IsComplete {
  67. return false, 0, nil
  68. }
  69. if waitResp.Error != "" {
  70. return true, 0, fmt.Errorf("%s", waitResp.Error)
  71. }
  72. return true, waitResp.PackageID, nil
  73. }

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