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.

user_space_meta.go 2.5 kB

7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package metacache
  2. import (
  3. "context"
  4. "time"
  5. "gitlink.org.cn/cloudream/common/pkgs/logger"
  6. stgglb "gitlink.org.cn/cloudream/jcs-pub/common/globals"
  7. corrpc "gitlink.org.cn/cloudream/jcs-pub/common/pkgs/rpc/coordinator"
  8. "gitlink.org.cn/cloudream/jcs-pub/common/types"
  9. jcstypes "gitlink.org.cn/cloudream/jcs-pub/common/types"
  10. )
  11. func (m *MetaCacheHost) AddStorageMeta() *UserSpaceMeta {
  12. meta := &UserSpaceMeta{
  13. host: m,
  14. }
  15. meta.cache = NewSimpleMetaCache(SimpleMetaCacheConfig[types.UserSpaceID, types.UserSpaceDetail]{
  16. Getter: meta.load,
  17. Expire: time.Minute * 5,
  18. })
  19. m.caches = append(m.caches, meta)
  20. return meta
  21. }
  22. type UserSpaceMeta struct {
  23. host *MetaCacheHost
  24. cache *SimpleMetaCache[types.UserSpaceID, types.UserSpaceDetail]
  25. }
  26. func (s *UserSpaceMeta) Get(spaceID types.UserSpaceID) *types.UserSpaceDetail {
  27. v, ok := s.cache.Get(spaceID)
  28. if ok {
  29. return &v
  30. }
  31. return nil
  32. }
  33. func (s *UserSpaceMeta) GetMany(spaceIDs []types.UserSpaceID) []*types.UserSpaceDetail {
  34. vs, oks := s.cache.GetMany(spaceIDs)
  35. ret := make([]*types.UserSpaceDetail, len(vs))
  36. for i := range vs {
  37. if oks[i] {
  38. ret[i] = &vs[i]
  39. }
  40. }
  41. return ret
  42. }
  43. func (s *UserSpaceMeta) ClearOutdated() {
  44. s.cache.ClearOutdated()
  45. }
  46. func (s *UserSpaceMeta) Drop(keys []types.UserSpaceID) {
  47. s.cache.Drop(keys)
  48. }
  49. func (s *UserSpaceMeta) load(keys []types.UserSpaceID) ([]types.UserSpaceDetail, []bool) {
  50. vs := make([]types.UserSpaceDetail, len(keys))
  51. oks := make([]bool, len(keys))
  52. spaces, err := s.host.db.UserSpace().BatchGetByID(s.host.db.DefCtx(), keys)
  53. if err != nil {
  54. logger.Warnf("batch get user space by id: %v", err)
  55. return vs, oks
  56. }
  57. detailMap := make(map[types.UserSpaceID]*types.UserSpaceDetail)
  58. for i := range spaces {
  59. detailMap[spaces[i].UserSpaceID] = &types.UserSpaceDetail{
  60. UserID: stgglb.UserID,
  61. UserSpace: spaces[i],
  62. }
  63. }
  64. if !stgglb.StandaloneMode {
  65. coorCli := stgglb.CoordinatorRPCPool.Get()
  66. defer coorCli.Release()
  67. stgs := make([]jcstypes.StorageType, len(spaces))
  68. for i := range spaces {
  69. stgs[i] = spaces[i].Storage
  70. }
  71. selectHubs, cerr := coorCli.SelectStorageHub(context.Background(), &corrpc.SelectStorageHub{
  72. Storages: stgs,
  73. })
  74. if cerr != nil {
  75. logger.Warnf("get storage details: %v", cerr)
  76. return vs, oks
  77. }
  78. for i := range spaces {
  79. detailMap[spaces[i].UserSpaceID].RecommendHub = selectHubs.Hubs[i]
  80. }
  81. }
  82. for i := range keys {
  83. if detail, ok := detailMap[keys[i]]; ok {
  84. vs[i] = *detail
  85. oks[i] = true
  86. }
  87. }
  88. return vs, oks
  89. }

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