Class: Ci::JobArtifacts::DestroyAllExpiredService
- Inherits:
 - 
      Object
      
        
- Object
 - Ci::JobArtifacts::DestroyAllExpiredService
 
 
- Includes:
 - Gitlab::ExclusiveLeaseHelpers, Gitlab::LoopHelpers
 
- Defined in:
 - app/services/ci/job_artifacts/destroy_all_expired_service.rb
 
Constant Summary collapse
- BATCH_SIZE =
 100- LOOP_LIMIT =
 500- LOOP_TIMEOUT =
 5.minutes
- LOCK_TIMEOUT =
 6.minutes
- EXCLUSIVE_LOCK_KEY =
 'expired_job_artifacts:destroy:lock'
Constants included from Gitlab::ExclusiveLeaseHelpers
Gitlab::ExclusiveLeaseHelpers::FailedToObtainLockError
Instance Method Summary collapse
- 
  
    
      #execute  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Destroy expired job artifacts on GitLab instance.
 - 
  
    
      #initialize  ⇒ DestroyAllExpiredService 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    
A new instance of DestroyAllExpiredService.
 
Methods included from Gitlab::LoopHelpers
Methods included from Gitlab::ExclusiveLeaseHelpers
Constructor Details
#initialize ⇒ DestroyAllExpiredService
Returns a new instance of DestroyAllExpiredService.
      15 16 17 18  | 
    
      # File 'app/services/ci/job_artifacts/destroy_all_expired_service.rb', line 15 def initialize @removed_artifacts_count = 0 @start_at = Time.current end  | 
  
Instance Method Details
#execute ⇒ Object
Destroy expired job artifacts on GitLab instance
This destroy process cannot run for more than 6 minutes. This is for preventing multiple ‘ExpireBuildArtifactsWorker` CRON jobs run concurrently, which is scheduled every 7 minutes.
      26 27 28 29 30 31 32  | 
    
      # File 'app/services/ci/job_artifacts/destroy_all_expired_service.rb', line 26 def execute in_lock(EXCLUSIVE_LOCK_KEY, ttl: LOCK_TIMEOUT, retries: 1) do destroy_unlocked_job_artifacts end @removed_artifacts_count end  |