31 lines
		
	
	
		
			876 B
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			876 B
		
	
	
	
		
			Ruby
		
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| # Interface to the Redis-backed cache store to keep track of complete cache keys
 | |
| # for a ReactiveCache resource.
 | |
| module Gitlab
 | |
|   class ReactiveCacheSetCache < Gitlab::SetCache
 | |
|     attr_reader :expires_in
 | |
| 
 | |
|     def initialize(expires_in: 10.minutes)
 | |
|       @expires_in = expires_in
 | |
|     end
 | |
| 
 | |
|     def clear_cache!(key)
 | |
|       with do |redis|
 | |
|         keys = read(key).map { |value| "#{cache_namespace}:#{value}" }
 | |
|         keys << cache_key(key)
 | |
| 
 | |
|         Gitlab::Instrumentation::RedisClusterValidator.allow_cross_slot_commands do
 | |
|           if Gitlab::Redis::ClusterUtil.cluster?(redis)
 | |
|             Gitlab::Redis::ClusterUtil.batch_unlink(keys, redis)
 | |
|           else
 | |
|             redis.pipelined do |pipeline|
 | |
|               keys.each_slice(1000) { |subset| pipeline.unlink(*subset) }
 | |
|             end
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |