You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

139 lines
3.3 KiB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
  1. package redis3
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/chrislusf/seaweedfs/weed/glog"
  6. "github.com/chrislusf/seaweedfs/weed/util/skiplist"
  7. "github.com/go-redis/redis/v8"
  8. )
  9. const maxNameBatchSizeLimit = 1000
  10. func insertChild(ctx context.Context, redisStore *UniversalRedis3Store, key string, name string) error {
  11. // lock and unlock
  12. mutex := redisStore.redsync.NewMutex(key+"lock")
  13. if err := mutex.Lock(); err != nil {
  14. return fmt.Errorf("lock %s: %v", key, err)
  15. }
  16. defer func() {
  17. mutex.Unlock()
  18. }()
  19. client := redisStore.Client
  20. data, err := client.Get(ctx, key).Result()
  21. if err != nil {
  22. if err != redis.Nil {
  23. return fmt.Errorf("read %s: %v", key, err)
  24. }
  25. }
  26. store := newSkipListElementStore(key, client)
  27. nameList := skiplist.LoadNameList([]byte(data), store, maxNameBatchSizeLimit)
  28. if err := nameList.WriteName(name); err != nil {
  29. glog.Errorf("add %s %s: %v", key, name, err)
  30. return err
  31. }
  32. if !nameList.HasChanges() {
  33. return nil
  34. }
  35. if err := client.Set(ctx, key, nameList.ToBytes(), 0).Err(); err != nil {
  36. return err
  37. }
  38. return nil
  39. }
  40. func removeChild(ctx context.Context, redisStore *UniversalRedis3Store, key string, name string) error {
  41. // lock and unlock
  42. mutex := redisStore.redsync.NewMutex(key+"lock")
  43. if err := mutex.Lock(); err != nil {
  44. return fmt.Errorf("lock %s: %v", key, err)
  45. }
  46. defer mutex.Unlock()
  47. client := redisStore.Client
  48. data, err := client.Get(ctx, key).Result()
  49. if err != nil {
  50. if err != redis.Nil {
  51. return fmt.Errorf("read %s: %v", key, err)
  52. }
  53. }
  54. store := newSkipListElementStore(key, client)
  55. nameList := skiplist.LoadNameList([]byte(data), store, maxNameBatchSizeLimit)
  56. if err := nameList.DeleteName(name); err != nil {
  57. return err
  58. }
  59. if !nameList.HasChanges() {
  60. return nil
  61. }
  62. if err := client.Set(ctx, key, nameList.ToBytes(), 0).Err(); err != nil {
  63. return err
  64. }
  65. return nil
  66. }
  67. func removeChildren(ctx context.Context, redisStore *UniversalRedis3Store, key string, onDeleteFn func(name string) error) error {
  68. // lock and unlock
  69. mutex := redisStore.redsync.NewMutex(key+"lock")
  70. if err := mutex.Lock(); err != nil {
  71. return fmt.Errorf("lock %s: %v", key, err)
  72. }
  73. defer mutex.Unlock()
  74. client := redisStore.Client
  75. data, err := client.Get(ctx, key).Result()
  76. if err != nil {
  77. if err != redis.Nil {
  78. return fmt.Errorf("read %s: %v", key, err)
  79. }
  80. }
  81. store := newSkipListElementStore(key, client)
  82. nameList := skiplist.LoadNameList([]byte(data), store, maxNameBatchSizeLimit)
  83. if err = nameList.ListNames("", func(name string) bool {
  84. if err := onDeleteFn(name); err != nil {
  85. glog.Errorf("delete %s child %s: %v", key, name, err)
  86. return false
  87. }
  88. return true
  89. }); err != nil {
  90. return err
  91. }
  92. if err = nameList.RemoteAllListElement(); err != nil {
  93. return err
  94. }
  95. return nil
  96. }
  97. func listChildren(ctx context.Context, redisStore *UniversalRedis3Store, key string, startFileName string, eachFn func(name string) bool) error {
  98. client := redisStore.Client
  99. data, err := client.Get(ctx, key).Result()
  100. if err != nil {
  101. if err != redis.Nil {
  102. return fmt.Errorf("read %s: %v", key, err)
  103. }
  104. }
  105. store := newSkipListElementStore(key, client)
  106. nameList := skiplist.LoadNameList([]byte(data), store, maxNameBatchSizeLimit)
  107. if err = nameList.ListNames(startFileName, func(name string) bool {
  108. return eachFn(name)
  109. }); err != nil {
  110. return err
  111. }
  112. return nil
  113. }