diff options
author | Douwe Maan <douwe@gitlab.com> | 2016-02-20 01:05:00 +0000 |
---|---|---|
committer | Douwe Maan <douwe@gitlab.com> | 2016-02-20 01:05:00 +0000 |
commit | f81b55bd350761709b27b4668223305563be4afe (patch) | |
tree | 57146b43df0988b1e3f6383e716862a4b1edb0fc /lib | |
parent | c352aaa008ea3240eaa754d4163769082bc0e8fc (diff) | |
parent | 44e4f07037ed192f9f86b575042164a3a106e4cb (diff) | |
download | gitlab-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.rake | 11 |
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 |