Make namespace deletion asynchronous
Instead of deleting a namespace synchronously as before, we now mark the namespace for deletion, disable it, and rename it. A worker then comes along and deletes the namespace in the background. This results in a *significantly* better user experience, as the namespace deletion operation now "completes" in under a second, where before it could take 10s of minutes at the worse. Fixes https://jira.coreos.com/browse/QUAY-838
This commit is contained in:
		
							parent
							
								
									d9015a1863
								
							
						
					
					
						commit
						8bc55a5676
					
				
					 21 changed files with 244 additions and 129 deletions
				
			
		
							
								
								
									
										7
									
								
								app.py
									
										
									
									
									
								
							
							
						
						
									
										7
									
								
								app.py
									
										
									
									
									
								
							|  | @ -228,8 +228,13 @@ secscan_notification_queue = WorkQueue(app.config['SECSCAN_NOTIFICATION_QUEUE_NA | |||
|                                        has_namespace=False, | ||||
|                                        metric_queue=metric_queue) | ||||
| 
 | ||||
| # Note: We set `has_namespace` to `False` here, as we explicitly want this queue to not be emptied | ||||
| # when a namespace is marked for deletion. | ||||
| namespace_gc_queue = WorkQueue(app.config['NAMESPACE_GC_QUEUE_NAME'], tf, has_namespace=False, | ||||
|                                metric_queue=metric_queue) | ||||
| 
 | ||||
| all_queues = [image_replication_queue, dockerfile_build_queue, notification_queue, | ||||
|               secscan_notification_queue, chunk_cleanup_queue] | ||||
|               secscan_notification_queue, chunk_cleanup_queue, namespace_gc_queue] | ||||
| 
 | ||||
| secscan_api = SecurityScannerAPI(app, app.config, storage) | ||||
| tuf_metadata_api = TUFMetadataAPI(app, app.config) | ||||
|  |  | |||
		Reference in a new issue