summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDouwe Maan <douwe@gitlab.com>2016-02-20 01:05:00 +0000
committerDouwe Maan <douwe@gitlab.com>2016-02-20 01:05:00 +0000
commitf81b55bd350761709b27b4668223305563be4afe (patch)
tree57146b43df0988b1e3f6383e716862a4b1edb0fc /lib
parentc352aaa008ea3240eaa754d4163769082bc0e8fc (diff)
parent44e4f07037ed192f9f86b575042164a3a106e4cb (diff)
downloadgitlab-ce-f81b55bd350761709b27b4668223305563be4afe.tar.gz
Merge branch 'refactor-scan' into 'master'
Improve readability of 'rake cache:clear' code See merge request !2892
Diffstat (limited to 'lib')
-rw-r--r--lib/tasks/cache.rake11
1 files changed, 5 insertions, 6 deletions
diff --git a/lib/tasks/cache.rake b/lib/tasks/cache.rake
index b262ea898d5..9e2fb429d57 100644
--- a/lib/tasks/cache.rake
+++ b/lib/tasks/cache.rake
@@ -1,22 +1,21 @@
namespace :cache do
- CLEAR_BATCH_SIZE = 1000
+ CLEAR_BATCH_SIZE = 1000 # The more the faster, but having too many can crash Ruby
REDIS_SCAN_START_STOP = '0' # Magic value, see http://redis.io/commands/scan
desc "GitLab | Clear redis cache"
task :clear => :environment do
redis_store = Rails.cache.instance_variable_get(:@data)
- cursor = [REDIS_SCAN_START_STOP, []]
+ cursor = REDIS_SCAN_START_STOP
loop do
- cursor = redis_store.scan(
- cursor.first,
+ cursor, keys = redis_store.scan(
+ cursor,
match: "#{Gitlab::REDIS_CACHE_NAMESPACE}*",
count: CLEAR_BATCH_SIZE
)
- keys = cursor.last
redis_store.del(*keys) if keys.any?
- break if cursor.first == REDIS_SCAN_START_STOP
+ break if cursor == REDIS_SCAN_START_STOP
end
end
end