Co-authored-by: Eugen Rochko <eugen@zeonfederated.com> Co-authored-by: Claire <claire.github-309c@sitedethib.com>
		
			
				
	
	
		
			28 lines
		
	
	
	
		
			686 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
	
		
			686 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class Scheduler::IndexingScheduler
 | |
|   include Sidekiq::Worker
 | |
|   include Redisable
 | |
| 
 | |
|   sidekiq_options retry: 0, lock: :until_executed, lock_ttl: 1.day.to_i
 | |
| 
 | |
|   IMPORT_BATCH_SIZE = 1000
 | |
|   SCAN_BATCH_SIZE = 10 * IMPORT_BATCH_SIZE
 | |
| 
 | |
|   def perform
 | |
|     return unless Chewy.enabled?
 | |
| 
 | |
|     indexes.each do |type|
 | |
|       with_redis do |redis|
 | |
|         redis.sscan_each("chewy:queue:#{type.name}", count: SCAN_BATCH_SIZE).each_slice(IMPORT_BATCH_SIZE) do |ids|
 | |
|           type.import!(ids)
 | |
|           redis.srem("chewy:queue:#{type.name}", ids)
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def indexes
 | |
|     [AccountsIndex, TagsIndex, PublicStatusesIndex, StatusesIndex]
 | |
|   end
 | |
| end
 |